From cc577e1bfb4c20aa045fbafceb1057e43df1a8c0 Mon Sep 17 00:00:00 2001 From: yuyi Date: Wed, 29 Dec 2021 19:44:08 +0800 Subject: [PATCH] parser: check variable redefinition error (#12992) --- .../tests/assign_var_redefinition_err.out | 7 ++++ .../tests/assign_var_redefinition_err.vv | 8 +++++ vlib/v/parser/assign.v | 36 +++++++++---------- 3 files changed, 33 insertions(+), 18 deletions(-) create mode 100644 vlib/v/checker/tests/assign_var_redefinition_err.out create mode 100644 vlib/v/checker/tests/assign_var_redefinition_err.vv diff --git a/vlib/v/checker/tests/assign_var_redefinition_err.out b/vlib/v/checker/tests/assign_var_redefinition_err.out new file mode 100644 index 0000000000..37ba8cfb15 --- /dev/null +++ b/vlib/v/checker/tests/assign_var_redefinition_err.out @@ -0,0 +1,7 @@ +vlib/v/checker/tests/assign_var_redefinition_err.vv:6:2: error: redefinition of `aaaa` + 4 | + 5 | fn test(aaaa string) string { + 6 | aaaa := 'bbbb' + aaaa + | ~~~~ + 7 | return aaaa + 8 | } diff --git a/vlib/v/checker/tests/assign_var_redefinition_err.vv b/vlib/v/checker/tests/assign_var_redefinition_err.vv new file mode 100644 index 0000000000..714cc7e5a4 --- /dev/null +++ b/vlib/v/checker/tests/assign_var_redefinition_err.vv @@ -0,0 +1,8 @@ +fn main() { + println(test('whatever')) +} + +fn test(aaaa string) string { + aaaa := 'bbbb' + aaaa + return aaaa +} diff --git a/vlib/v/parser/assign.v b/vlib/v/parser/assign.v index 1591ca8e21..383abcaded 100644 --- a/vlib/v/parser/assign.v +++ b/vlib/v/parser/assign.v @@ -144,24 +144,6 @@ fn (mut p Parser) partial_assign_stmt(left []ast.Expr, left_comments []ast.Comme comments << right_comments end_comments := p.eat_comments(same_line: true) mut has_cross_var := false - if op == .decl_assign { - // a, b := a + 1, b - for r in right { - p.check_undefined_variables(left, r) or { return p.error_with_pos(err.msg, pos) } - } - } else if left.len > 1 { - // a, b = b, a - for r in right { - has_cross_var = p.check_cross_variables(left, r) - if op !in [.assign, .decl_assign] { - return p.error_with_pos('unexpected $op.str(), expecting := or = or comma', - pos) - } - if has_cross_var { - break - } - } - } mut is_static := false mut is_volatile := false for i, lx in left { @@ -232,6 +214,24 @@ fn (mut p Parser) partial_assign_stmt(left []ast.Expr, left_comments []ast.Comme } } } + if op == .decl_assign { + // a, b := a + 1, b + for r in right { + p.check_undefined_variables(left, r) or { return p.error_with_pos(err.msg, pos) } + } + } else if left.len > 1 { + // a, b = b, a + for r in right { + has_cross_var = p.check_cross_variables(left, r) + if op !in [.assign, .decl_assign] { + return p.error_with_pos('unexpected $op.str(), expecting := or = or comma', + pos) + } + if has_cross_var { + break + } + } + } pos.update_last_line(p.prev_tok.line_nr) return ast.AssignStmt{ op: op