2004-07-16 02:26:21 -04:00
|
|
|
#include "factor.h"
|
|
|
|
|
2004-09-03 18:49:04 -04:00
|
|
|
CELL cons(CELL car, CELL cdr)
|
2004-07-16 02:26:21 -04:00
|
|
|
{
|
2004-12-10 21:46:42 -05:00
|
|
|
F_CONS* cons = allot(sizeof(F_CONS));
|
2004-07-16 02:26:21 -04:00
|
|
|
cons->car = car;
|
|
|
|
cons->cdr = cdr;
|
2004-09-03 18:49:04 -04:00
|
|
|
return tag_cons(cons);
|
2004-07-16 02:26:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void primitive_cons(void)
|
|
|
|
{
|
2004-10-12 23:49:43 -04:00
|
|
|
CELL car, cdr;
|
|
|
|
maybe_garbage_collection();
|
|
|
|
cdr = dpop();
|
|
|
|
car = dpop();
|
2004-09-03 18:49:04 -04:00
|
|
|
dpush(cons(car,cdr));
|
2004-07-16 02:26:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void primitive_car(void)
|
|
|
|
{
|
2004-08-12 17:36:36 -04:00
|
|
|
drepl(car(dpeek()));
|
2004-07-16 02:26:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void primitive_cdr(void)
|
|
|
|
{
|
2004-08-12 17:36:36 -04:00
|
|
|
drepl(cdr(dpeek()));
|
2004-07-16 02:26:21 -04:00
|
|
|
}
|