ast: fix generic nested struct init (#12405)
parent
1c12186701
commit
9ec1262734
|
@ -1661,11 +1661,10 @@ pub fn (mut t Table) generic_insts_to_concrete() {
|
||||||
generic_names := parent_info.generic_types.map(t.get_type_symbol(it).name)
|
generic_names := parent_info.generic_types.map(t.get_type_symbol(it).name)
|
||||||
for i in 0 .. fields.len {
|
for i in 0 .. fields.len {
|
||||||
if fields[i].typ.has_flag(.generic) {
|
if fields[i].typ.has_flag(.generic) {
|
||||||
sym := t.get_type_symbol(fields[i].typ)
|
if fields[i].typ.idx() != info.parent_idx {
|
||||||
if sym.kind == .struct_ && fields[i].typ.idx() != info.parent_idx {
|
|
||||||
fields[i].typ = t.unwrap_generic_type(fields[i].typ,
|
fields[i].typ = t.unwrap_generic_type(fields[i].typ,
|
||||||
generic_names, info.concrete_types)
|
generic_names, info.concrete_types)
|
||||||
} else {
|
}
|
||||||
if t_typ := t.resolve_generic_to_concrete(fields[i].typ,
|
if t_typ := t.resolve_generic_to_concrete(fields[i].typ,
|
||||||
generic_names, info.concrete_types)
|
generic_names, info.concrete_types)
|
||||||
{
|
{
|
||||||
|
@ -1673,7 +1672,6 @@ pub fn (mut t Table) generic_insts_to_concrete() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
parent_info.is_generic = false
|
parent_info.is_generic = false
|
||||||
parent_info.concrete_types = info.concrete_types.clone()
|
parent_info.concrete_types = info.concrete_types.clone()
|
||||||
parent_info.fields = fields
|
parent_info.fields = fields
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
struct Foo<T> {
|
||||||
|
foo T
|
||||||
|
}
|
||||||
|
|
||||||
|
struct Bar<T> {
|
||||||
|
mut:
|
||||||
|
foos []Foo<T>
|
||||||
|
}
|
||||||
|
|
||||||
|
fn (mut b Bar<T>) add(v T) {
|
||||||
|
b.foos << Foo<T>{
|
||||||
|
foo: v
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_nested_generics_struct_init() {
|
||||||
|
mut bar := Bar<string>{}
|
||||||
|
bar.add('bar')
|
||||||
|
println(bar)
|
||||||
|
|
||||||
|
result := '$bar'
|
||||||
|
assert result.contains('Bar<string>{')
|
||||||
|
assert result.contains('foos: [Foo<string>{')
|
||||||
|
assert result.contains("foo: 'bar'")
|
||||||
|
}
|
Loading…
Reference in New Issue