cgen: fix struct init with multi nested embed update expr (#13529)
parent
dbae2d6af4
commit
75ebac006d
|
@ -230,15 +230,21 @@ fn (mut g Gen) struct_init(node ast.StructInit) {
|
||||||
g.write('.')
|
g.write('.')
|
||||||
}
|
}
|
||||||
if node.is_update_embed {
|
if node.is_update_embed {
|
||||||
embed_sym := g.table.sym(node.typ)
|
update_sym := g.table.sym(node.update_expr_type)
|
||||||
embed_name := embed_sym.embed_name()
|
_, embeds := g.table.find_field_from_embeds(update_sym, field.name) or {
|
||||||
g.write(embed_name)
|
ast.StructField{}, []ast.Type{}
|
||||||
if node.typ.is_ptr() {
|
}
|
||||||
|
for embed in embeds {
|
||||||
|
esym := g.table.sym(embed)
|
||||||
|
ename := esym.embed_name()
|
||||||
|
g.write(ename)
|
||||||
|
if embed.is_ptr() {
|
||||||
g.write('->')
|
g.write('->')
|
||||||
} else {
|
} else {
|
||||||
g.write('.')
|
g.write('.')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
g.write(field.name)
|
g.write(field.name)
|
||||||
} else {
|
} else {
|
||||||
if !g.zero_struct_field(field) {
|
if !g.zero_struct_field(field) {
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
module main
|
||||||
|
|
||||||
|
struct Animal {
|
||||||
|
Duck
|
||||||
|
id int
|
||||||
|
}
|
||||||
|
|
||||||
|
struct Duck {
|
||||||
|
RedDuck
|
||||||
|
action string
|
||||||
|
}
|
||||||
|
|
||||||
|
struct RedDuck {
|
||||||
|
color string
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_struct_init_with_multi_nested_embed_update() {
|
||||||
|
d := Animal{Duck{RedDuck{'red'}, 'fly'}, 1}
|
||||||
|
println(d)
|
||||||
|
|
||||||
|
e := Animal{
|
||||||
|
...d
|
||||||
|
id: 2
|
||||||
|
}
|
||||||
|
println(e)
|
||||||
|
assert d.id == 1
|
||||||
|
assert e.id == 2
|
||||||
|
}
|
Loading…
Reference in New Issue