v.gen.c: use `const type* const_x` for `const_x &type` fn args
parent
2158597831
commit
033b027361
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue