parser: require `(` on same line as name token for fn call or cast (#6160)

pull/6163/head
Nick Treleaven 2020-08-19 01:37:17 +01:00 committed by GitHub
parent 51bd69cdd8
commit e69f091bbd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 17 additions and 10 deletions

View File

@ -966,7 +966,7 @@ pub fn (mut p Parser) name_expr() ast.Expr {
// `chan typ{...}` // `chan typ{...}`
if p.tok.lit == 'chan' { if p.tok.lit == 'chan' {
first_pos := p.tok.position() first_pos := p.tok.position()
mut last_pos := p.tok.position() mut last_pos := first_pos
chan_type := p.parse_chan_type() chan_type := p.parse_chan_type()
mut has_cap := false mut has_cap := false
mut cap_expr := ast.Expr{} mut cap_expr := ast.Expr{}
@ -992,13 +992,8 @@ pub fn (mut p Parser) name_expr() ast.Expr {
last_pos = p.tok.position() last_pos = p.tok.position()
p.check(.rcbr) p.check(.rcbr)
} }
pos := token.Position{
line_nr: first_pos.line_nr
pos: first_pos.pos
len: last_pos.pos - first_pos.pos + last_pos.len
}
return ast.ChanInit{ return ast.ChanInit{
pos: pos pos: first_pos.extend(last_pos)
has_cap: has_cap has_cap: has_cap
cap_expr: cap_expr cap_expr: cap_expr
typ: chan_type typ: chan_type
@ -1034,10 +1029,13 @@ pub fn (mut p Parser) name_expr() ast.Expr {
} }
lit0_is_capital := p.tok.lit[0].is_capital() lit0_is_capital := p.tok.lit[0].is_capital()
// p.warn('name expr $p.tok.lit $p.peek_tok.str()') // p.warn('name expr $p.tok.lit $p.peek_tok.str()')
// fn call or type cast same_line := p.tok.line_nr == p.peek_tok.line_nr
if p.peek_tok.kind == .lpar || // `(` must be on same line as name token otherwise it's a ParExpr
if !same_line && p.peek_tok.kind == .lpar {
node = p.parse_ident(language)
} else if p.peek_tok.kind == .lpar ||
(p.peek_tok.kind == .lt && !lit0_is_capital && p.peek_tok2.kind == .name && p.peek_tok3.kind == .gt) { (p.peek_tok.kind == .lt && !lit0_is_capital && p.peek_tok2.kind == .name && p.peek_tok3.kind == .gt) {
// foo() or foo<int>() // foo(), foo<int>() or type() cast
mut name := p.tok.lit mut name := p.tok.lit
if mod.len > 0 { if mod.len > 0 {
name = '${mod}.$name' name = '${mod}.$name'

View File

@ -0,0 +1,9 @@
fn test_name_lpar() {
mut v := 2
// check ParExpr is parsed, not CallExpr
mut p := &v
(*p)++
_ = v
(*p)++
assert v == 4
}