mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
parent
286350aa9b
commit
c2eb4d7065
@ -521,7 +521,6 @@ fn (mut g Gen) assign_stmt(node_ ast.AssignStmt) {
|
|||||||
fn (mut g Gen) gen_multi_return_assign(node &ast.AssignStmt, return_type ast.Type) {
|
fn (mut g Gen) gen_multi_return_assign(node &ast.AssignStmt, return_type ast.Type) {
|
||||||
// multi return
|
// multi return
|
||||||
// TODO Handle in if_expr
|
// TODO Handle in if_expr
|
||||||
is_opt := return_type.has_flag(.option) || return_type.has_flag(.result)
|
|
||||||
mr_var_name := 'mr_${node.pos.pos}'
|
mr_var_name := 'mr_${node.pos.pos}'
|
||||||
mr_styp := g.typ(return_type.clear_flag(.option).clear_flag(.result))
|
mr_styp := g.typ(return_type.clear_flag(.option).clear_flag(.result))
|
||||||
g.write('${mr_styp} ${mr_var_name} = ')
|
g.write('${mr_styp} ${mr_var_name} = ')
|
||||||
@ -551,34 +550,16 @@ fn (mut g Gen) gen_multi_return_assign(node &ast.AssignStmt, return_type ast.Typ
|
|||||||
g.expr(lx)
|
g.expr(lx)
|
||||||
noscan := if is_auto_heap { g.check_noscan(return_type) } else { '' }
|
noscan := if is_auto_heap { g.check_noscan(return_type) } else { '' }
|
||||||
if g.is_arraymap_set {
|
if g.is_arraymap_set {
|
||||||
if is_opt {
|
if is_auto_heap {
|
||||||
mr_base_styp := g.base_type(return_type)
|
g.writeln('HEAP${noscan}(${styp}, ${mr_var_name}.arg${i}) });')
|
||||||
if is_auto_heap {
|
|
||||||
g.writeln('HEAP${noscan}(${mr_base_styp}, ${mr_var_name}.arg${i}) });')
|
|
||||||
} else {
|
|
||||||
g.writeln('${mr_var_name}.arg${i} });')
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if is_auto_heap {
|
g.writeln('${mr_var_name}.arg${i} });')
|
||||||
g.writeln('HEAP${noscan}(${styp}, ${mr_var_name}.arg${i}) });')
|
|
||||||
} else {
|
|
||||||
g.writeln('${mr_var_name}.arg${i} });')
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if is_opt {
|
if is_auto_heap {
|
||||||
mr_base_styp := g.base_type(return_type)
|
g.writeln(' = HEAP${noscan}(${styp}, ${mr_var_name}.arg${i});')
|
||||||
if is_auto_heap {
|
|
||||||
g.writeln(' = HEAP${noscan}(${mr_base_styp}, ${mr_var_name}.arg${i});')
|
|
||||||
} else {
|
|
||||||
g.writeln(' = ${mr_var_name}.arg${i};')
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if is_auto_heap {
|
g.writeln(' = ${mr_var_name}.arg${i};')
|
||||||
g.writeln(' = HEAP${noscan}(${styp}, ${mr_var_name}.arg${i});')
|
|
||||||
} else {
|
|
||||||
g.writeln(' = ${mr_var_name}.arg${i};')
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
15
vlib/v/tests/multiret_with_result_test.v
Normal file
15
vlib/v/tests/multiret_with_result_test.v
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
[heap]
|
||||||
|
struct Foo {
|
||||||
|
a string
|
||||||
|
b int
|
||||||
|
}
|
||||||
|
|
||||||
|
fn ret() !(int, Foo) {
|
||||||
|
return 0, Foo{}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_multiret_with_result() {
|
||||||
|
_, foo := ret()!
|
||||||
|
println(foo)
|
||||||
|
assert true
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user