VM: Refactor tuples.cpp/hpp to Factor style
parent
93b586da31
commit
5b1a9d753e
|
@ -1,34 +1,32 @@
|
|||
#include "master.hpp"
|
||||
|
||||
namespace factor
|
||||
{
|
||||
namespace factor {
|
||||
|
||||
/* push a new tuple on the stack, filling its slots with f */
|
||||
/* Allocates memory */
|
||||
void factor_vm::primitive_tuple()
|
||||
{
|
||||
data_root<tuple_layout> layout(ctx->pop(),this);
|
||||
tagged<tuple> t(allot<tuple>(tuple_size(layout.untagged())));
|
||||
t->layout = layout.value();
|
||||
void factor_vm::primitive_tuple() {
|
||||
data_root<tuple_layout> layout(ctx->pop(), this);
|
||||
tagged<tuple> t(allot<tuple>(tuple_size(layout.untagged())));
|
||||
t->layout = layout.value();
|
||||
|
||||
memset_cell(t->data(),false_object,tuple_size(layout.untagged()) - sizeof(cell));
|
||||
memset_cell(t->data(), false_object,
|
||||
tuple_size(layout.untagged()) - sizeof(cell));
|
||||
|
||||
ctx->push(t.value());
|
||||
ctx->push(t.value());
|
||||
}
|
||||
|
||||
/* push a new tuple on the stack, filling its slots from the stack */
|
||||
/* Allocates memory */
|
||||
void factor_vm::primitive_tuple_boa()
|
||||
{
|
||||
data_root<tuple_layout> layout(ctx->pop(),this);
|
||||
tagged<tuple> t(allot<tuple>(tuple_size(layout.untagged())));
|
||||
t->layout = layout.value();
|
||||
void factor_vm::primitive_tuple_boa() {
|
||||
data_root<tuple_layout> layout(ctx->pop(), this);
|
||||
tagged<tuple> t(allot<tuple>(tuple_size(layout.untagged())));
|
||||
t->layout = layout.value();
|
||||
|
||||
cell size = untag_fixnum(layout.untagged()->size) * sizeof(cell);
|
||||
memcpy(t->data(),(cell *)(ctx->datastack - size + sizeof(cell)),size);
|
||||
ctx->datastack -= size;
|
||||
cell size = untag_fixnum(layout.untagged()->size) * sizeof(cell);
|
||||
memcpy(t->data(), (cell*)(ctx->datastack - size + sizeof(cell)), size);
|
||||
ctx->datastack -= size;
|
||||
|
||||
ctx->push(t.value());
|
||||
ctx->push(t.value());
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1,10 +1,8 @@
|
|||
namespace factor
|
||||
{
|
||||
namespace factor {
|
||||
|
||||
inline static cell tuple_size(const tuple_layout *layout)
|
||||
{
|
||||
cell size = untag_fixnum(layout->size);
|
||||
return sizeof(tuple) + size * sizeof(cell);
|
||||
inline static cell tuple_size(const tuple_layout* layout) {
|
||||
cell size = untag_fixnum(layout->size);
|
||||
return sizeof(tuple) + size * sizeof(cell);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue