parser: check var names in for loops
parent
155891a4e0
commit
5c3742fbd2
|
@ -73,12 +73,23 @@ fn (var p Parser) for_stmt() ast.Stmt {
|
||||||
p.check(.comma)
|
p.check(.comma)
|
||||||
key_var_name = val_var_name
|
key_var_name = val_var_name
|
||||||
val_var_name = p.check_name()
|
val_var_name = p.check_name()
|
||||||
|
if p.scope.known_var(key_var_name) {
|
||||||
|
p.error('redefinition of `$key_var_name`')
|
||||||
|
}
|
||||||
|
if p.scope.known_var(val_var_name) {
|
||||||
|
p.error('redefinition of `$val_var_name`')
|
||||||
|
}
|
||||||
p.scope.register(key_var_name, ast.Var{
|
p.scope.register(key_var_name, ast.Var{
|
||||||
name: key_var_name
|
name: key_var_name
|
||||||
typ: table.int_type
|
typ: table.int_type
|
||||||
})
|
})
|
||||||
|
} else if p.scope.known_var(val_var_name) {
|
||||||
|
p.error('redefinition of `$val_var_name`')
|
||||||
}
|
}
|
||||||
p.check(.key_in)
|
p.check(.key_in)
|
||||||
|
if p.tok.kind == .name && p.tok.lit in [key_var_name, val_var_name] {
|
||||||
|
p.error('redefinition of `$p.tok.lit`')
|
||||||
|
}
|
||||||
// arr_expr
|
// arr_expr
|
||||||
cond := p.expr(0)
|
cond := p.expr(0)
|
||||||
// 0 .. 10
|
// 0 .. 10
|
||||||
|
|
Loading…
Reference in New Issue