Skip to content

Commit

Permalink
checker: check match return mismatch type (fix #6826) (#7109)
Browse files Browse the repository at this point in the history
  • Loading branch information
yuyi98 authored Dec 3, 2020
1 parent d590ce7 commit 9b6a155
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 9 deletions.
20 changes: 11 additions & 9 deletions vlib/v/checker/checker.v
Original file line number Diff line number Diff line change
Expand Up @@ -3434,8 +3434,13 @@ pub fn (mut c Checker) match_expr(mut node ast.MatchExpr) table.Type {
mut stmt := branch.stmts[branch.stmts.len - 1]
match mut stmt {
ast.ExprStmt {
ret_type = c.expr(stmt.expr)
stmt.typ = ret_type
if ret_type == table.void_type {
ret_type = c.expr(stmt.expr)
stmt.typ = ret_type
} else if node.is_expr && ret_type != c.expr(stmt.expr) {
sym := c.table.get_type_symbol(ret_type)
c.error('return type mismatch, it should be `$sym.name`', stmt.expr.position())
}
}
else {
// TODO: ask alex about this
Expand Down Expand Up @@ -4009,14 +4014,11 @@ pub fn (mut c Checker) if_expr(mut node ast.IfExpr) table.Type {
} else if node.typ == table.any_flt_type {
node.typ = table.f64_type
}
if expr_required {
if !node.has_else {
d := if node.is_comptime { '$' } else { '' }
c.error('`$if_kind` expression needs `${d}else` clause', node.pos)
}
return node.typ
if expr_required && !node.has_else {
d := if node.is_comptime { '$' } else { '' }
c.error('`$if_kind` expression needs `${d}else` clause', node.pos)
}
return table.bool_type
return node.typ
}

// comp_if_branch checks the condition of a compile-time `if` branch. It returns a `bool` that
Expand Down
7 changes: 7 additions & 0 deletions vlib/v/checker/tests/match_return_mismatch_type_err.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
vlib/v/checker/tests/match_return_mismatch_type_err.vv:4:10: error: return type mismatch, it should be `string`
2 | a := match 1 {
3 | 1 { 'aa' }
4 | else { 22 }
| ~~
5 | }
6 | println(a)
7 changes: 7 additions & 0 deletions vlib/v/checker/tests/match_return_mismatch_type_err.vv
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
fn main() {
a := match 1 {
1 { 'aa' }
else { 22 }
}
println(a)
}

0 comments on commit 9b6a155

Please sign in to comment.