Skip to content

Commit

Permalink
fix
Browse files Browse the repository at this point in the history
  • Loading branch information
felipensp committed Jan 3, 2025
1 parent 2945629 commit 6501145
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 11 deletions.
15 changes: 11 additions & 4 deletions vlib/v/checker/checker.v
Original file line number Diff line number Diff line change
Expand Up @@ -2959,10 +2959,17 @@ pub fn (mut c Checker) expr(mut node ast.Expr) ast.Type {
c.table.used_features.as_cast = true
}
if mut node.expr is ast.Ident {
if !node.typ.has_flag(.option) && node.expr.obj.typ.has_flag(.option)
&& node.expr.or_expr.kind == .absent {
c.error('variable `${node.expr.name}` is an Option, it must be unwrapped first',
node.expr.pos)
if mut node.expr.obj is ast.Var {
ident_typ := if node.expr.obj.smartcasts.len > 0 {
node.expr.obj.smartcasts.last()
} else {
node.expr.obj.typ
}
if !node.typ.has_flag(.option) && ident_typ.has_flag(.option)
&& node.expr.or_expr.kind == .absent {
c.error('variable `${node.expr.name}` is an Option, it must be unwrapped first',
node.expr.pos)
}
}
}
if expr_type_sym.kind == .sum_type {
Expand Down
6 changes: 3 additions & 3 deletions vlib/v/tests/options/option_concatexpr_test.v
Original file line number Diff line number Diff line change
Expand Up @@ -12,17 +12,17 @@ fn foo(f int) !(int, ?int) {

fn test_main() {
a, b := foo(-1) or { 2, 2 }
c := b as int
c := b? as int
assert a == 2
assert c == 2

a2, b2 := foo(0) or { 2, 2 }
c2 := b2 as int
c2 := b2? as int
assert a2 == 0
assert c2 == 0

a3, b3 := foo(1) or { 2, 2 }
c3 := b3 as int
c3 := b3? as int
assert a3 == 1
assert c3 == 1
}
8 changes: 4 additions & 4 deletions vlib/v/tests/options/option_unwrap_as_cast_test.v
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,9 @@ fn get_opt_int(a int) ?int {
fn test_option_unwrap_as_cast() {
x := get_opt(1)
d := get_opt_int(12)
dump(d as int == 12)
dump('${x as string}' == 'success')
dump(d? as int == 12)
dump('${x? as string}' == 'success')

assert d as int == 12
assert x as string == 'success'
assert d? as int == 12
assert x? as string == 'success'
}

0 comments on commit 6501145

Please sign in to comment.