errors: use more distinct and detailed name redefinition messages
parent
bea918bb87
commit
8b5573a6f3
|
@ -191,7 +191,7 @@ fn (mut p Parser) fn_decl() ast.FnDecl {
|
|||
name = p.prepend_mod(name)
|
||||
}
|
||||
if _ := p.table.find_fn(name) {
|
||||
p.error('redefinition of `$name`')
|
||||
p.error('redefinition of function `$name`')
|
||||
}
|
||||
p.table.register_fn(table.Fn{
|
||||
name: name
|
||||
|
|
|
@ -74,21 +74,21 @@ fn (mut p Parser) for_stmt() ast.Stmt {
|
|||
key_var_name = val_var_name
|
||||
val_var_name = p.check_name()
|
||||
if p.scope.known_var(key_var_name) {
|
||||
p.error('redefinition of `$key_var_name`')
|
||||
p.error('redefinition of key iteration variable `$key_var_name`')
|
||||
}
|
||||
if p.scope.known_var(val_var_name) {
|
||||
p.error('redefinition of `$val_var_name`')
|
||||
p.error('redefinition of value iteration variable `$val_var_name`')
|
||||
}
|
||||
p.scope.register(key_var_name, ast.Var{
|
||||
name: key_var_name
|
||||
typ: table.int_type
|
||||
})
|
||||
} else if p.scope.known_var(val_var_name) {
|
||||
p.error('redefinition of `$val_var_name`')
|
||||
p.error('redefinition of value iteration variable `$val_var_name`')
|
||||
}
|
||||
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`')
|
||||
p.error('in a `for x in array` loop, the key or value iteration variable `$p.tok.lit` can not be the same as the array variable')
|
||||
}
|
||||
// arr_expr
|
||||
cond := p.expr(0)
|
||||
|
|
Loading…
Reference in New Issue