'apply' calls given procedure by trampoline
This commit is contained in:
parent
d3a3c78829
commit
c3b45c6d16
22
src/proc.c
22
src/proc.c
|
@ -85,20 +85,38 @@ pic_proc_proc_p(pic_state *pic)
|
|||
static pic_value
|
||||
pic_proc_apply(pic_state *pic)
|
||||
{
|
||||
static struct pic_code iseq[3];
|
||||
struct pic_proc *proc;
|
||||
pic_value *args, arg_list;
|
||||
pic_value *args;
|
||||
size_t argc;
|
||||
pic_value v, arg_list;
|
||||
|
||||
pic_get_args(pic, "l*", &proc, &argc, &args);
|
||||
|
||||
if (argc == 0) {
|
||||
pic_error(pic, "apply: wrong number of arguments");
|
||||
}
|
||||
|
||||
arg_list = args[--argc];
|
||||
while (argc--) {
|
||||
arg_list = pic_cons(pic, args[argc], arg_list);
|
||||
}
|
||||
return pic_apply(pic, proc, arg_list);
|
||||
|
||||
*pic->ci->fp++ = pic_obj_value(proc);
|
||||
pic_for_each (v, arg_list) {
|
||||
*pic->ci->fp++ = v;
|
||||
}
|
||||
|
||||
iseq[0].insn = OP_JMP; /* OP_NOP */
|
||||
iseq[0].u.i = 1;
|
||||
iseq[1].insn = OP_CALL;
|
||||
iseq[1].u.i = pic_length(pic, arg_list) + 1;
|
||||
iseq[2].insn = OP_RET;
|
||||
pic->ci->ip = iseq;
|
||||
|
||||
/* the last argument is pushed by the VM */
|
||||
pic->ci->fp--;
|
||||
return v;
|
||||
}
|
||||
|
||||
static pic_value
|
||||
|
|
Loading…
Reference in New Issue