From d5642b61340a550564b322890942229b0e2889ff Mon Sep 17 00:00:00 2001 From: yuyi Date: Fri, 29 Oct 2021 22:14:49 +0800 Subject: [PATCH] cgen: fix error of nested match expr (#12334) --- vlib/v/gen/c/cgen.v | 2 +- vlib/v/tests/match_expr_nested_test.v | 35 +++++++++++++++++++++++++++ 2 files changed, 36 insertions(+), 1 deletion(-) create mode 100644 vlib/v/tests/match_expr_nested_test.v diff --git a/vlib/v/gen/c/cgen.v b/vlib/v/gen/c/cgen.v index e1dbea82d7..79581e360d 100644 --- a/vlib/v/gen/c/cgen.v +++ b/vlib/v/gen/c/cgen.v @@ -1557,7 +1557,7 @@ fn (mut g Gen) stmt(node ast.Stmt) { // } old_is_void_expr_stmt := g.is_void_expr_stmt g.is_void_expr_stmt = !node.is_expr - if node.typ != ast.void_type && g.expected_cast_type != 0 { + if node.typ != ast.void_type && g.expected_cast_type != 0 && node.expr !is ast.MatchExpr { g.expr_with_cast(node.expr, node.typ, g.expected_cast_type) } else { g.expr(node.expr) diff --git a/vlib/v/tests/match_expr_nested_test.v b/vlib/v/tests/match_expr_nested_test.v new file mode 100644 index 0000000000..46e5d26391 --- /dev/null +++ b/vlib/v/tests/match_expr_nested_test.v @@ -0,0 +1,35 @@ +struct Abc {} + +type Test = Abc | bool | int + +fn test(a Test) Test { + return match a { + Abc { + 20 + } + int { + match a { + 1 { true } + 2 { false } + else { -1 } + } + } + bool { + 1 + } + } +} + +fn test_nested_match_expr() { + println(test(1)) + assert test(1) == Test(true) + + println(test(2)) + assert test(2) == Test(false) + + println(test(3)) + assert test(3) == Test(-1) + + println(test(true)) + assert test(true) == Test(1) +}