v.gen.c: use `const type* const_x` for `const_x &type` fn args

pull/11005/head
Delyan Angelov 2021-07-31 08:42:40 +03:00
parent 2158597831
commit 033b027361
No known key found for this signature in database
GPG Key ID: 66886C0F12D595ED
1 changed files with 10 additions and 4 deletions

View File

@ -71,7 +71,7 @@ fn (mut g Gen) process_fn_decl(node ast.FnDecl) {
unsafe { unsafe {
g.fn_decl = &node g.fn_decl = &node
} }
if node.name == 'main.main' { if node.is_main {
g.has_main = true g.has_main = true
} }
if node.name == 'backtrace' || node.name == 'backtrace_symbols' if node.name == 'backtrace' || node.name == 'backtrace_symbols'
@ -196,8 +196,8 @@ fn (mut g Gen) gen_fn_decl(node &ast.FnDecl, skip bool) {
name = g.generic_fn_name(g.table.cur_concrete_types, name, true) name = g.generic_fn_name(g.table.cur_concrete_types, name, true)
if g.pref.obfuscate && g.cur_mod.name == 'main' && name.starts_with('main__') if g.pref.obfuscate && g.cur_mod.name == 'main' && name.starts_with('main__') && !node.is_main
&& name != 'main__main' && node.name != 'str' { && node.name != 'str' {
mut key := node.name mut key := node.name
if node.is_method { if node.is_method {
sym := g.table.get_type_symbol(node.receiver.typ) sym := g.table.get_type_symbol(node.receiver.typ)
@ -435,7 +435,13 @@ fn (mut g Gen) fn_args(args []ast.Param, is_variadic bool, scope &ast.Scope) ([]
} }
} }
var_name_prefix := if heap_prom { '_v_toheap_' } else { '' } var_name_prefix := if heap_prom { '_v_toheap_' } else { '' }
s := '$arg_type_name $var_name_prefix$caname' const_prefix := if arg.typ.is_any_kind_of_pointer() && !arg.is_mut
&& arg.name.starts_with('const_') {
'const '
} else {
''
}
s := '$const_prefix$arg_type_name $var_name_prefix$caname'
g.write(s) g.write(s)
g.definitions.write_string(s) g.definitions.write_string(s)
fargs << caname fargs << caname