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 {
start := s.pos
s.pos++
@ -232,14 +237,14 @@ fn (mut s Scanner) ident_name() string {
}
break
}
name := s.text[start..s.pos]
name := s.stext(start, s.pos)
s.pos--
return name
}
fn (s Scanner) num_lit(start int, end int) string {
if s.is_fmt {
return s.text[start..end]
return s.stext(start, end)
}
unsafe {
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 {
mut has_wrong_digit := false
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-- {
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`')
}
}
@ -512,7 +518,7 @@ fn (mut s Scanner) ident_number() string {
}
}
[direct_array_access; inline]
[direct_array_access]
fn (mut s Scanner) skip_whitespace() {
for s.pos < s.text.len {
c := s.text[s.pos]
@ -917,11 +923,11 @@ fn (mut s Scanner) text_scan() token.Token {
s.ignore_line()
if nextc == `!` {
// 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"')
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)
}
`>` {
@ -938,7 +944,7 @@ fn (mut s Scanner) text_scan() token.Token {
// e.g. ...Bar<int, []Foo<int>, Baz_, [20]f64, map[string][]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 {
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
typs.all(it.len > 0
&& ((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--
}
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
// Find out if this comment is on its own line (for vfmt)
mut is_separate_line_comment := true
@ -1085,7 +1091,7 @@ fn (mut s Scanner) text_scan() token.Token {
}
s.pos++
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') {
comment = '\x01' + comment
}
@ -1113,7 +1119,7 @@ fn (mut s Scanner) text_scan() token.Token {
fn (mut s Scanner) invalid_character() {
len := utf8_char_len(s.text[s.pos])
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`')
}
@ -1245,7 +1251,7 @@ fn (mut s Scanner) ident_string() string {
end++
}
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 {
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
}
[direct_array_access]
fn (mut s Scanner) ident_char() string {
start := s.pos
slash := `\\`
@ -1317,7 +1324,7 @@ fn (mut s Scanner) ident_char() string {
}
}
len--
c := s.text[start + 1..s.pos]
c := s.stext(start + 1, s.pos)
if len != 1 {
u := c.runes()
if u.len != 1 {