cgen: map init struct fields & fn type arg fix
parent
c808430643
commit
e13bbd8c40
|
@ -656,12 +656,18 @@ fn (g mut Gen) fn_args(args []table.Arg, is_variadic bool) {
|
||||||
if arg_type_sym.kind == .function {
|
if arg_type_sym.kind == .function {
|
||||||
info := arg_type_sym.info as table.FnType
|
info := arg_type_sym.info as table.FnType
|
||||||
func := info.func
|
func := info.func
|
||||||
|
if !info.is_anon {
|
||||||
|
g.write(arg_type_name + ' ' + arg.name)
|
||||||
|
g.definitions.write(arg_type_name + ' ' + arg.name)
|
||||||
|
}
|
||||||
|
else {
|
||||||
g.write('${g.typ(func.return_type)} (*$arg.name)(')
|
g.write('${g.typ(func.return_type)} (*$arg.name)(')
|
||||||
g.definitions.write('${g.typ(func.return_type)} (*$arg.name)(')
|
g.definitions.write('${g.typ(func.return_type)} (*$arg.name)(')
|
||||||
g.fn_args(func.args, func.is_variadic)
|
g.fn_args(func.args, func.is_variadic)
|
||||||
g.write(')')
|
g.write(')')
|
||||||
g.definitions.write(')')
|
g.definitions.write(')')
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else if no_names {
|
else if no_names {
|
||||||
g.write(arg_type_name)
|
g.write(arg_type_name)
|
||||||
g.definitions.write(arg_type_name)
|
g.definitions.write(arg_type_name)
|
||||||
|
@ -2099,6 +2105,11 @@ fn (g &Gen) type_default(typ table.Type) string {
|
||||||
elem_type := 'int'
|
elem_type := 'int'
|
||||||
return 'new_array(0, 1, sizeof($elem_type))'
|
return 'new_array(0, 1, sizeof($elem_type))'
|
||||||
}
|
}
|
||||||
|
if sym.kind == .map {
|
||||||
|
value_sym := g.table.get_type_symbol(sym.map_info().value_type)
|
||||||
|
value_typ_str := value_sym.name.replace('.', '__')
|
||||||
|
return 'new_map(1, sizeof($value_typ_str))'
|
||||||
|
}
|
||||||
// Always set pointers to 0
|
// Always set pointers to 0
|
||||||
if table.type_is_ptr(typ) {
|
if table.type_is_ptr(typ) {
|
||||||
return '0'
|
return '0'
|
||||||
|
|
Loading…
Reference in New Issue