checker: add a missing return regression test for if branches too
parent
ebfd259333
commit
dd1717af34
|
@ -0,0 +1,12 @@
|
||||||
|
vlib/v/checker/tests/return_missing_if_else_simple.vv:1:1: error: missing return at end of function `if_no_returns`
|
||||||
|
1 | fn if_no_returns() int {
|
||||||
|
| ~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
2 | if true {
|
||||||
|
3 | println('no return in then')
|
||||||
|
vlib/v/checker/tests/return_missing_if_else_simple.vv:10:1: error: missing return at end of function `if_no_return_in_else`
|
||||||
|
8 | }
|
||||||
|
9 |
|
||||||
|
10 | fn if_no_return_in_else() int {
|
||||||
|
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
11 | if true {
|
||||||
|
12 | return 123
|
|
@ -0,0 +1,35 @@
|
||||||
|
fn if_no_returns() int {
|
||||||
|
if true {
|
||||||
|
println('no return in then')
|
||||||
|
} else {
|
||||||
|
println('no return in else')
|
||||||
|
}
|
||||||
|
println('hello')
|
||||||
|
}
|
||||||
|
|
||||||
|
fn if_no_return_in_else() int {
|
||||||
|
if true {
|
||||||
|
return 123
|
||||||
|
} else {
|
||||||
|
println('no return in else')
|
||||||
|
}
|
||||||
|
println('hello')
|
||||||
|
}
|
||||||
|
|
||||||
|
fn if_returns_in_both_branches() int {
|
||||||
|
// The if here always returns, so the function
|
||||||
|
// returns too:
|
||||||
|
if true {
|
||||||
|
return 123
|
||||||
|
} else {
|
||||||
|
return 456
|
||||||
|
}
|
||||||
|
// TODO: should produce a warning/error about a statement after a return.
|
||||||
|
println('hello')
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
println(if_no_returns())
|
||||||
|
println(if_no_return_in_else())
|
||||||
|
println(if_returns_in_both_branches())
|
||||||
|
}
|
Loading…
Reference in New Issue