fix optional struct field assignment
parent
54707ff81d
commit
560d1383d1
|
@ -1441,7 +1441,7 @@ fn ($v.name mut $v.typ) ${p.cur_fn.name}(...) {
|
||||||
expr := p.cgen.cur_line[pos..]
|
expr := p.cgen.cur_line[pos..]
|
||||||
left := p.cgen.cur_line[..pos]
|
left := p.cgen.cur_line[..pos]
|
||||||
typ := expr_type.replace('Option_', '')
|
typ := expr_type.replace('Option_', '')
|
||||||
p.cgen.resetln(left + 'opt_ok($expr, sizeof($typ))')
|
p.cgen.resetln(left + 'opt_ok(($typ[]){ $expr }, sizeof($typ))')
|
||||||
}
|
}
|
||||||
else if expr_type.starts_with('Option_') &&
|
else if expr_type.starts_with('Option_') &&
|
||||||
p.assigned_type == expr_type['Option_'.len..] && p.tok == .key_orelse
|
p.assigned_type == expr_type['Option_'.len..] && p.tok == .key_orelse
|
||||||
|
|
|
@ -73,7 +73,7 @@ fn test_opt_default() {
|
||||||
|
|
||||||
fn foo_ok() ?int {
|
fn foo_ok() ?int {
|
||||||
return 777
|
return 777
|
||||||
}
|
}
|
||||||
|
|
||||||
fn foo_str() ?string {
|
fn foo_str() ?string {
|
||||||
return 'something'
|
return 'something'
|
||||||
|
@ -81,7 +81,7 @@ fn foo_str() ?string {
|
||||||
|
|
||||||
fn test_q() {
|
fn test_q() {
|
||||||
//assert foo_ok()? == true
|
//assert foo_ok()? == true
|
||||||
}
|
}
|
||||||
|
|
||||||
struct Person {
|
struct Person {
|
||||||
mut:
|
mut:
|
||||||
|
@ -112,3 +112,15 @@ fn test_field_or() {
|
||||||
}
|
}
|
||||||
assert mytitle == 'default'
|
assert mytitle == 'default'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct Thing {
|
||||||
|
mut:
|
||||||
|
opt ?int
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_opt_field() {
|
||||||
|
mut t := Thing{}
|
||||||
|
t.opt = 5
|
||||||
|
val := t.opt or { return }
|
||||||
|
assert val == 5
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue