X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=src%2Fmodule.c;h=811d4e40429c713b3619b065fd9776f082e00ae5;hp=b8d23008ffcaa4f73139b92224c29f9631234636;hb=596f215b67dd267284df4fe0e11f0ca4d197bfc1;hpb=3c53642a0adccd4b602d147833da24eb4b73bccc diff --git a/src/module.c b/src/module.c index b8d2300..811d4e4 100644 --- a/src/module.c +++ b/src/module.c @@ -360,17 +360,20 @@ void psi_to_array(zval *return_value, token_t t, impl_val *ret_val, set_value *s set_value *sub_set = set->inner[i]; decl_var *sub_var = sub_set->vars->vars[0]; decl_arg *sub_arg = sub_var->arg; - token_t t = real_decl_type(sub_arg->type)->type; - void *ptr = malloc(sub_arg->layout->len); - - memcpy(ptr, (char *) ret_val->ptr + sub_arg->layout->pos, - sub_arg->layout->len); - tmp_ptr = enref_impl_val(ptr, sub_arg->var); - sub_set->func->handler(&ztmp, t, tmp_ptr, sub_set, sub_var); - add_assoc_zval(return_value, sub_var->name, &ztmp); - free(tmp_ptr); - if (tmp_ptr != ptr) { - free(ptr); + + if (sub_arg) { + token_t t = real_decl_type(sub_arg->type)->type; + void *ptr = malloc(sub_arg->layout->len); + + memcpy(ptr, (char *) ret_val->ptr + sub_arg->layout->pos, + sub_arg->layout->len); + tmp_ptr = enref_impl_val(ptr, sub_arg->var); + sub_set->func->handler(&ztmp, t, tmp_ptr, sub_set, sub_var); + add_assoc_zval(return_value, sub_var->name, &ztmp); + free(tmp_ptr); + if (tmp_ptr != ptr) { + free(ptr); + } } } } @@ -613,15 +616,20 @@ void psi_do_return(zval *return_value, return_stmt *ret, impl_val *ret_val) void psi_do_free(free_stmt *fre) { - size_t i; + size_t i, j; + impl_val dummy, *argps[0x20]; - for (i = 0; i < fre->vars->count; ++i) { - decl_var *dvar = fre->vars->vars[i]; + for (i = 0; i < fre->calls->count; ++i) { + free_call *f = fre->calls->list[i]; - if (dvar->arg && dvar->arg->let->out.ptr) { - free(dvar->arg->let->out.ptr); - dvar->arg->let->out.ptr = NULL; + for (j = 0; j < f->vars->count; ++j) { + decl_var *dvar = f->vars->vars[j]; + decl_arg *darg = dvar->arg; + + argps[j] = &darg->let->out; } + + PSI_ContextCall(&PSI_G(context), &dummy, f->decl, argps); } }