2009-05-02 05:04:19 -04:00
|
|
|
#include "master.hpp"
|
|
|
|
|
2009-05-04 02:46:13 -04:00
|
|
|
namespace factor
|
|
|
|
{
|
|
|
|
|
2009-05-02 05:04:19 -04:00
|
|
|
/* push a new tuple on the stack */
|
2009-09-23 14:05:46 -04:00
|
|
|
tuple *factor_vm::allot_tuple(cell layout_)
|
2009-05-02 05:04:19 -04:00
|
|
|
{
|
2009-08-17 16:37:09 -04:00
|
|
|
gc_root<tuple_layout> layout(layout_,this);
|
|
|
|
gc_root<tuple> t(allot<tuple>(tuple_size(layout.untagged())),this);
|
2009-05-04 05:50:24 -04:00
|
|
|
t->layout = layout.value();
|
|
|
|
return t.untagged();
|
2009-05-02 05:04:19 -04:00
|
|
|
}
|
|
|
|
|
2009-09-27 14:42:18 -04:00
|
|
|
void factor_vm::primitive_tuple()
|
2009-05-02 05:04:19 -04:00
|
|
|
{
|
2009-08-17 16:37:09 -04:00
|
|
|
gc_root<tuple_layout> layout(dpop(),this);
|
2009-05-04 05:50:24 -04:00
|
|
|
tuple *t = allot_tuple(layout.value());
|
|
|
|
fixnum i;
|
2009-05-02 10:19:09 -04:00
|
|
|
for(i = tuple_size(layout.untagged()) - 1; i >= 0; i--)
|
2009-10-18 21:26:21 -04:00
|
|
|
t->data()[i] = false_object;
|
2009-05-02 05:04:19 -04:00
|
|
|
|
2009-05-04 05:50:24 -04:00
|
|
|
dpush(tag<tuple>(t));
|
2009-05-02 05:04:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* push a new tuple on the stack, filling its slots from the stack */
|
2009-09-27 14:42:18 -04:00
|
|
|
void factor_vm::primitive_tuple_boa()
|
2009-05-02 05:04:19 -04:00
|
|
|
{
|
2009-08-17 16:37:09 -04:00
|
|
|
gc_root<tuple_layout> layout(dpop(),this);
|
|
|
|
gc_root<tuple> t(allot_tuple(layout.value()),this);
|
2009-05-04 05:50:24 -04:00
|
|
|
cell size = untag_fixnum(layout.untagged()->size) * sizeof(cell);
|
|
|
|
memcpy(t->data(),(cell *)(ds - (size - sizeof(cell))),size);
|
2009-05-02 10:19:09 -04:00
|
|
|
ds -= size;
|
2009-05-04 05:50:24 -04:00
|
|
|
dpush(t.value());
|
2009-05-02 05:04:19 -04:00
|
|
|
}
|
2009-05-04 02:46:13 -04:00
|
|
|
|
|
|
|
}
|