scanner: better interpolation names + disable vweb html test for now

pull/2056/head
Alexander Medvednikov 2019-09-21 01:27:13 +03:00
parent 6ebd62020a
commit 90e26a34c5
2 changed files with 18 additions and 16 deletions

View File

@ -21,8 +21,8 @@ mut:
pos int pos int
line_nr int line_nr int
inside_string bool inside_string bool
dollar_start bool // for hacky string interpolation TODO simplify inter_start bool // for hacky string interpolation TODO simplify
dollar_end bool inter_end bool
debug bool debug bool
line_comment string line_comment string
started bool started bool
@ -264,12 +264,12 @@ fn (s mut Scanner) scan() ScanRes {
s.skip_whitespace() s.skip_whitespace()
} }
// End of $var, start next string // End of $var, start next string
if s.dollar_end { if s.inter_end {
if s.text[s.pos] == `\'` { if s.text[s.pos] == `\'` {
s.dollar_end = false s.inter_end = false
return scan_res(.str, '') return scan_res(.str, '')
} }
s.dollar_end = false s.inter_end = false
return scan_res(.str, s.ident_string()) return scan_res(.str, s.ident_string())
} }
s.skip_whitespace() s.skip_whitespace()
@ -296,14 +296,14 @@ fn (s mut Scanner) scan() ScanRes {
// at the next ', skip it // at the next ', skip it
if s.inside_string { if s.inside_string {
if next_char == `\'` { if next_char == `\'` {
s.dollar_end = true s.inter_end = true
s.dollar_start = false s.inter_start = false
s.inside_string = false s.inside_string = false
} }
} }
if s.dollar_start && next_char != `.` { if s.inter_start && next_char != `.` {
s.dollar_end = true s.inter_end = true
s.dollar_start = false s.inter_start = false
} }
if s.pos == 0 && next_char == ` ` { if s.pos == 0 && next_char == ` ` {
s.pos++ s.pos++
@ -386,7 +386,7 @@ fn (s mut Scanner) scan() ScanRes {
// s = `hello ${name} !` // s = `hello ${name} !`
if s.inside_string { if s.inside_string {
s.pos++ s.pos++
// TODO UN.neEDED? // TODO UNNEEDED?
if s.text[s.pos] == `\'` { if s.text[s.pos] == `\'` {
s.inside_string = false s.inside_string = false
return scan_res(.str, '') return scan_res(.str, '')
@ -728,7 +728,7 @@ fn (s mut Scanner) ident_string() string {
// $var // $var
if (c.is_letter() || c == `_`) && prevc == `$` && s.count_symbol_before(s.pos-2, `\\`) % 2 == 0 { if (c.is_letter() || c == `_`) && prevc == `$` && s.count_symbol_before(s.pos-2, `\\`) % 2 == 0 {
s.inside_string = true s.inside_string = true
s.dollar_start = true s.inter_start = true
s.pos -= 2 s.pos -= 2
break break
} }
@ -788,8 +788,8 @@ fn (s mut Scanner) peek() Token {
pos := s.pos pos := s.pos
line := s.line_nr line := s.line_nr
inside_string := s.inside_string inside_string := s.inside_string
dollar_start := s.dollar_start inter_start := s.inter_start
dollar_end := s.dollar_end inter_end := s.inter_end
res := s.scan() res := s.scan()
tok := res.tok tok := res.tok
@ -798,8 +798,8 @@ fn (s mut Scanner) peek() Token {
s.pos = pos s.pos = pos
s.line_nr = line s.line_nr = line
s.inside_string = inside_string s.inside_string = inside_string
s.dollar_start = dollar_start s.inter_start = inter_start
s.dollar_end = dollar_end s.inter_end = inter_end
return tok return tok
} }

View File

@ -24,11 +24,13 @@ pub fn (app mut App) json_endpoint() {
app.vweb.json('{"a": 3}') app.vweb.json('{"a": 3}')
} }
/*
pub fn (app mut App) index() { pub fn (app mut App) index() {
app.cnt ++ app.cnt ++
$vweb.html() $vweb.html()
} }
*/
pub fn (app mut App) text() { pub fn (app mut App) text() {
app.vweb.text('hello world') app.vweb.text('hello world')