From 791972ebc9912881e706a55f1491f0684b0218ca Mon Sep 17 00:00:00 2001 From: yuyi Date: Tue, 11 Jan 2022 15:50:20 +0800 Subject: [PATCH] checker: check error for match conditions with parenthesis (#13130) --- vlib/v/checker/match.v | 4 ++++ .../tests/match_cond_with_parenthesis_err.out | 7 ++++++ .../tests/match_cond_with_parenthesis_err.vv | 22 +++++++++++++++++++ 3 files changed, 33 insertions(+) create mode 100644 vlib/v/checker/tests/match_cond_with_parenthesis_err.out create mode 100644 vlib/v/checker/tests/match_cond_with_parenthesis_err.vv diff --git a/vlib/v/checker/match.v b/vlib/v/checker/match.v index bc053b8384..a9b60b979d 100644 --- a/vlib/v/checker/match.v +++ b/vlib/v/checker/match.v @@ -8,6 +8,10 @@ import strings pub fn (mut c Checker) match_expr(mut node ast.MatchExpr) ast.Type { node.is_expr = c.expected_type != ast.void_type node.expected_type = c.expected_type + if node.cond is ast.ParExpr { + c.error('unnecessary `()` in `match` condition, use `match expr {` instead of `match (expr) {`.', + node.cond.pos) + } cond_type := c.expr(node.cond) // we setting this here rather than at the end of the method // since it is used in c.match_exprs() it saves checking twice diff --git a/vlib/v/checker/tests/match_cond_with_parenthesis_err.out b/vlib/v/checker/tests/match_cond_with_parenthesis_err.out new file mode 100644 index 0000000000..f11b9bd9d2 --- /dev/null +++ b/vlib/v/checker/tests/match_cond_with_parenthesis_err.out @@ -0,0 +1,7 @@ +vlib/v/checker/tests/match_cond_with_parenthesis_err.vv:14:15: error: unnecessary `()` in `match` condition, use `match expr {` instead of `match (expr) {`. + 12 | + 13 | fn bar() bool { + 14 | return match (foo()) { + | ~~~~~~~ + 15 | .a { true } + 16 | .b, .c { false } diff --git a/vlib/v/checker/tests/match_cond_with_parenthesis_err.vv b/vlib/v/checker/tests/match_cond_with_parenthesis_err.vv new file mode 100644 index 0000000000..2e69c2f649 --- /dev/null +++ b/vlib/v/checker/tests/match_cond_with_parenthesis_err.vv @@ -0,0 +1,22 @@ +module main + +enum Enum { + a + b + c +} + +fn foo() ?Enum { + return .a +} + +fn bar() bool { + return match (foo()) { + .a { true } + .b, .c { false } + } +} + +fn main() { + bar() +}