1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00

v.scanner: reduce memory consumption for Scanner.ident_name

This commit is contained in:
Delyan Angelov 2021-12-11 16:38:13 +02:00
parent ba06eba39c
commit b18cd37e59
No known key found for this signature in database
GPG Key ID: 66886C0F12D595ED

View File

@ -220,7 +220,12 @@ fn (mut s Scanner) new_multiline_token(tok_kind token.Kind, lit string, len int,
} }
} }
[direct_array_access; inline] [inline]
fn (s &Scanner) stext(start int, end int) string {
return unsafe { (s.text.str + start).vstring_literal_with_len(end - start) }
}
[direct_array_access]
fn (mut s Scanner) ident_name() string { fn (mut s Scanner) ident_name() string {
start := s.pos start := s.pos
s.pos++ s.pos++
@ -232,14 +237,14 @@ fn (mut s Scanner) ident_name() string {
} }
break break
} }
name := s.text[start..s.pos] name := s.stext(start, s.pos)
s.pos-- s.pos--
return name return name
} }
fn (s Scanner) num_lit(start int, end int) string { fn (s Scanner) num_lit(start int, end int) string {
if s.is_fmt { if s.is_fmt {
return s.text[start..end] return s.stext(start, end)
} }
unsafe { unsafe {
txt := s.text.str txt := s.text.str
@ -256,6 +261,7 @@ fn (s Scanner) num_lit(start int, end int) string {
} }
} }
[direct_array_access]
fn (mut s Scanner) ident_bin_number() string { fn (mut s Scanner) ident_bin_number() string {
mut has_wrong_digit := false mut has_wrong_digit := false
mut first_wrong_digit_pos := 0 mut first_wrong_digit_pos := 0
@ -448,7 +454,7 @@ fn (mut s Scanner) ident_dec_number() string {
for i := s.pos - 2; i > 0 && s.text[i - 1].is_digit(); i-- { for i := s.pos - 2; i > 0 && s.text[i - 1].is_digit(); i-- {
symbol_length++ symbol_length++
} }
float_symbol := s.text[s.pos - 2 - symbol_length..s.pos - 1] float_symbol := s.stext(s.pos - 2 - symbol_length, s.pos - 1)
s.warn('float literals should have a digit after the decimal point, e.g. `${float_symbol}.0`') s.warn('float literals should have a digit after the decimal point, e.g. `${float_symbol}.0`')
} }
} }
@ -512,7 +518,7 @@ fn (mut s Scanner) ident_number() string {
} }
} }
[direct_array_access; inline] [direct_array_access]
fn (mut s Scanner) skip_whitespace() { fn (mut s Scanner) skip_whitespace() {
for s.pos < s.text.len { for s.pos < s.text.len {
c := s.text[s.pos] c := s.text[s.pos]
@ -917,11 +923,11 @@ fn (mut s Scanner) text_scan() token.Token {
s.ignore_line() s.ignore_line()
if nextc == `!` { if nextc == `!` {
// treat shebang line (#!) as a comment // treat shebang line (#!) as a comment
comment := s.text[start - 1..s.pos].trim_space() comment := s.stext(start - 1, s.pos).trim_space()
// s.fgenln('// shebang line "$s.line_comment"') // s.fgenln('// shebang line "$s.line_comment"')
return s.new_token(.comment, comment, comment.len + 2) return s.new_token(.comment, comment, comment.len + 2)
} }
hash := s.text[start..s.pos].trim_space() hash := s.stext(start, s.pos).trim_space()
return s.new_token(.hash, hash, hash.len + 2) return s.new_token(.hash, hash, hash.len + 2)
} }
`>` { `>` {
@ -938,7 +944,7 @@ fn (mut s Scanner) text_scan() token.Token {
// e.g. ...Bar<int, []Foo<int>, Baz_, [20]f64, map[string][]bool>> => // e.g. ...Bar<int, []Foo<int>, Baz_, [20]f64, map[string][]bool>> =>
// <int, Baz_, [20]f64, map[string][]bool => int, Baz_, f64, bool // <int, Baz_, [20]f64, map[string][]bool => int, Baz_, f64, bool
is_generic := if s.last_lt >= 0 && s.pos - s.last_lt < 100 { is_generic := if s.last_lt >= 0 && s.pos - s.last_lt < 100 {
typs := s.text[s.last_lt + 1..s.pos].split(',').map(it.trim_space().trim_right('>').after(']')) typs := s.stext(s.last_lt + 1, s.pos).split(',').map(it.trim_space().trim_right('>').after(']'))
// if any typ is neither Type nor builtin, then the case is non-generic // if any typ is neither Type nor builtin, then the case is non-generic
typs.all(it.len > 0 typs.all(it.len > 0
&& ((it[0].is_capital() && it[1..].bytes().all(it.is_alnum() && ((it[0].is_capital() && it[1..].bytes().all(it.is_alnum()
@ -1040,7 +1046,7 @@ fn (mut s Scanner) text_scan() token.Token {
s.line_nr-- s.line_nr--
} }
if s.should_parse_comment() { if s.should_parse_comment() {
s.line_comment = s.text[start + 1..comment_line_end] s.line_comment = s.stext(start + 1, comment_line_end)
mut comment := s.line_comment mut comment := s.line_comment
// Find out if this comment is on its own line (for vfmt) // Find out if this comment is on its own line (for vfmt)
mut is_separate_line_comment := true mut is_separate_line_comment := true
@ -1085,7 +1091,7 @@ fn (mut s Scanner) text_scan() token.Token {
} }
s.pos++ s.pos++
if s.should_parse_comment() { if s.should_parse_comment() {
mut comment := s.text[start..(s.pos - 1)].trim(' ') mut comment := s.stext(start, s.pos - 1).trim(' ')
if !comment.contains('\n') { if !comment.contains('\n') {
comment = '\x01' + comment comment = '\x01' + comment
} }
@ -1113,7 +1119,7 @@ fn (mut s Scanner) text_scan() token.Token {
fn (mut s Scanner) invalid_character() { fn (mut s Scanner) invalid_character() {
len := utf8_char_len(s.text[s.pos]) len := utf8_char_len(s.text[s.pos])
end := mathutil.min(s.pos + len, s.text.len) end := mathutil.min(s.pos + len, s.text.len)
c := s.text[s.pos..end] c := s.stext(s.pos, end)
s.error('invalid character `$c`') s.error('invalid character `$c`')
} }
@ -1245,7 +1251,7 @@ fn (mut s Scanner) ident_string() string {
end++ end++
} }
if start <= s.pos { if start <= s.pos {
mut string_so_far := s.text[start..end] mut string_so_far := s.stext(start, end)
if !s.is_fmt && u_escapes_pos.len > 0 { if !s.is_fmt && u_escapes_pos.len > 0 {
string_so_far = decode_u_escapes(string_so_far, start, u_escapes_pos) string_so_far = decode_u_escapes(string_so_far, start, u_escapes_pos)
} }
@ -1295,6 +1301,7 @@ fn trim_slash_line_break(s string) string {
return ret_str return ret_str
} }
[direct_array_access]
fn (mut s Scanner) ident_char() string { fn (mut s Scanner) ident_char() string {
start := s.pos start := s.pos
slash := `\\` slash := `\\`
@ -1317,7 +1324,7 @@ fn (mut s Scanner) ident_char() string {
} }
} }
len-- len--
c := s.text[start + 1..s.pos] c := s.stext(start + 1, s.pos)
if len != 1 { if len != 1 {
u := c.runes() u := c.runes()
if u.len != 1 { if u.len != 1 {