cgen: map init struct fields & fn type arg fix

pull/4107/head
Joe Conigliaro 2020-03-23 21:17:14 +11:00
parent c808430643
commit e13bbd8c40
1 changed files with 16 additions and 5 deletions

View File

@ -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'