cgen: fix generics with variadic generic args (#10700)
parent
6f234ee34a
commit
310bb1a8a6
|
@ -1173,12 +1173,10 @@ fn (mut g Gen) call_args(node ast.CallExpr) {
|
||||||
mut arr_info := arr_sym.info as ast.Array
|
mut arr_info := arr_sym.info as ast.Array
|
||||||
if varg_type.has_flag(.generic) {
|
if varg_type.has_flag(.generic) {
|
||||||
if fn_def := g.table.find_fn(node.name) {
|
if fn_def := g.table.find_fn(node.name) {
|
||||||
varg_type_name := g.table.type_to_str(varg_type)
|
if utyp := g.table.resolve_generic_to_concrete(arr_info.elem_type, fn_def.generic_names,
|
||||||
for i, fn_gen_name in fn_def.generic_names {
|
node.concrete_types)
|
||||||
if fn_gen_name == varg_type_name {
|
{
|
||||||
arr_info.elem_type = node.concrete_types[i]
|
arr_info.elem_type = utyp
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
g.error('unable to find function $node.name', node.pos)
|
g.error('unable to find function $node.name', node.pos)
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
struct Node<T> {
|
||||||
|
mut:
|
||||||
|
data T
|
||||||
|
next &Node<T> = 0
|
||||||
|
}
|
||||||
|
|
||||||
|
struct SinglyLinkedList<T> {
|
||||||
|
mut:
|
||||||
|
first_node &Node<T> = 0
|
||||||
|
}
|
||||||
|
|
||||||
|
fn init_singlylinkedlist<T>(nodes ...Node<T>) SinglyLinkedList<T> {
|
||||||
|
mut current_node := &nodes[0]
|
||||||
|
|
||||||
|
for i in 0 .. nodes.len - 1 {
|
||||||
|
current_node = &nodes[i]
|
||||||
|
current_node.next = &nodes[i + 1]
|
||||||
|
}
|
||||||
|
|
||||||
|
return SinglyLinkedList{&nodes[0]}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_generic_with_variadic_generic_args() {
|
||||||
|
sll := init_singlylinkedlist<int>(Node<int>{ data: 1 }, Node<int>{
|
||||||
|
data: 2
|
||||||
|
}, Node<int>{
|
||||||
|
data: 798
|
||||||
|
})
|
||||||
|
println(sll.first_node.next)
|
||||||
|
assert sll.first_node.next.data == 2
|
||||||
|
}
|
Loading…
Reference in New Issue