add trampoline helper
This commit is contained in:
parent
845961e7f9
commit
2ef426d90b
|
@ -173,6 +173,7 @@ pic_value pic_load(pic_state *, const char *);
|
||||||
|
|
||||||
pic_value pic_apply(pic_state *pic, struct pic_proc *, pic_value);
|
pic_value pic_apply(pic_state *pic, struct pic_proc *, pic_value);
|
||||||
pic_value pic_apply_argv(pic_state *pic, struct pic_proc *, size_t, ...);
|
pic_value pic_apply_argv(pic_state *pic, struct pic_proc *, size_t, ...);
|
||||||
|
pic_value pic_trampoline(pic_state *, struct pic_proc *, pic_value);
|
||||||
struct pic_proc *pic_compile(pic_state *, pic_value);
|
struct pic_proc *pic_compile(pic_state *, pic_value);
|
||||||
pic_value pic_macroexpand(pic_state *, pic_value);
|
pic_value pic_macroexpand(pic_state *, pic_value);
|
||||||
|
|
||||||
|
|
24
src/vm.c
24
src/vm.c
|
@ -814,3 +814,27 @@ pic_apply(pic_state *pic, struct pic_proc *proc, pic_value argv)
|
||||||
}
|
}
|
||||||
} VM_LOOP_END;
|
} VM_LOOP_END;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct pic_code trampoline_iseq[] = {
|
||||||
|
{ OP_NOP, {0} },
|
||||||
|
{ OP_CALL, {0} },
|
||||||
|
{ OP_RET, {0} },
|
||||||
|
};
|
||||||
|
|
||||||
|
pic_value
|
||||||
|
pic_trampoline(pic_state *pic, struct pic_proc *proc, pic_value args)
|
||||||
|
{
|
||||||
|
pic_value v, call_list;
|
||||||
|
|
||||||
|
call_list = pic_cons(pic, pic_obj_value(proc), args);
|
||||||
|
|
||||||
|
pic_for_each (v, call_list) {
|
||||||
|
*pic->ci->fp++ = v;
|
||||||
|
}
|
||||||
|
|
||||||
|
trampoline_iseq[1].u.i = pic_length(pic, call_list);
|
||||||
|
|
||||||
|
pic->ci->ip = trampoline_iseq;
|
||||||
|
pic->ci->fp--; /* the last argument is pushed by the VM */
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue