diff options
| author | gingerBill <bill@gingerbill.org> | 2018-03-04 11:25:23 +0000 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2018-03-04 11:25:23 +0000 |
| commit | 6db95b554f4c480d6d30c061a0df3c174fb526b6 (patch) | |
| tree | b9e4215d20311a9abc37a9b688b0cc03ca0ea269 /src | |
| parent | 105de7705a797e397b4cb8900f2c1f771684e2db (diff) | |
`__args__: []cstring`
Diffstat (limited to 'src')
| -rw-r--r-- | src/ir.cpp | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/src/ir.cpp b/src/ir.cpp index 211834519..d14535d2c 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -8566,9 +8566,9 @@ void ir_gen_tree(irGen *s) { array_init(&proc_params->Tuple.variables, a, 2); array_init(&proc_results->Tuple.variables, a, 1); - Type *char_ptr_ptr = make_type_pointer(a, make_type_pointer(a, t_u8)); + Type *cstring_ptr = make_type_pointer(a, t_cstring); proc_params->Tuple.variables[0] = make_entity_param(a, proc_scope, make_token_ident(str_lit("argc")), t_i32, false, false); - proc_params->Tuple.variables[1] = make_entity_param(a, proc_scope, make_token_ident(str_lit("argv")), char_ptr_ptr, false, false); + proc_params->Tuple.variables[1] = make_entity_param(a, proc_scope, make_token_ident(str_lit("argv")), cstring_ptr, false, false); proc_results->Tuple.variables[0] = make_entity_param(a, proc_scope, empty_token, t_i32, false, false); @@ -8606,11 +8606,9 @@ void ir_gen_tree(irGen *s) { irValue *argc = ir_emit_load(proc, *map_get(&proc->module->values, hash_entity(proc_params->Tuple.variables[0]))); irValue *argv = ir_emit_load(proc, *map_get(&proc->module->values, hash_entity(proc_params->Tuple.variables[1]))); - irValue *global_argc = ir_find_global_variable(proc, str_lit("__argc__")); - irValue *global_argv = ir_find_global_variable(proc, str_lit("__argv__")); + irValue *global_args = ir_find_global_variable(proc, str_lit("__args__")); - ir_emit_store(proc, global_argc, argc); - ir_emit_store(proc, global_argv, argv); + ir_fill_slice(proc, global_args, argv, ir_emit_conv(proc, argc, t_int)); ir_emit(proc, ir_alloc_instr(proc, irInstr_StartupRuntime)); { |