factor/vm/tuples.cpp

33 lines
880 B
C++
Raw Normal View History

2009-05-02 05:04:19 -04:00
#include "master.hpp"
/* push a new tuple on the stack */
2009-05-02 10:19:09 -04:00
F_TUPLE *allot_tuple(CELL layout_)
2009-05-02 05:04:19 -04:00
{
2009-05-02 10:19:09 -04:00
gc_root<F_TUPLE_LAYOUT> layout(layout_);
gc_root<F_TUPLE> tuple(allot<F_TUPLE>(tuple_size(layout.untagged())));
tuple->layout = layout.value();
return tuple.untagged();
2009-05-02 05:04:19 -04:00
}
void primitive_tuple(void)
{
2009-05-02 10:19:09 -04:00
gc_root<F_TUPLE_LAYOUT> layout(dpop());
F_TUPLE *tuple = allot_tuple(layout.value());
2009-05-02 05:04:19 -04:00
F_FIXNUM i;
2009-05-02 10:19:09 -04:00
for(i = tuple_size(layout.untagged()) - 1; i >= 0; i--)
2009-05-02 05:04:19 -04:00
put(AREF(tuple,i),F);
dpush(tag_tuple(tuple));
}
/* push a new tuple on the stack, filling its slots from the stack */
void primitive_tuple_boa(void)
{
2009-05-02 10:19:09 -04:00
gc_root<F_TUPLE_LAYOUT> layout(dpop());
gc_root<F_TUPLE> tuple(allot_tuple(layout.value()));
CELL size = untag_fixnum_fast(layout.untagged()->size) * CELLS;
memcpy(tuple.untagged() + 1,(CELL *)(ds - (size - CELLS)),size);
ds -= size;
dpush(tuple.value());
2009-05-02 05:04:19 -04:00
}