2004-08-04 03:12:55 -04:00
|
|
|
#include "factor.h"
|
|
|
|
|
|
|
|
void primitive_exit(void)
|
|
|
|
{
|
2004-08-12 17:36:36 -04:00
|
|
|
exit(to_fixnum(dpop()));
|
2004-08-04 03:12:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void primitive_os_env(void)
|
|
|
|
{
|
2004-09-19 17:39:28 -04:00
|
|
|
char* name = unbox_c_string();
|
2004-08-04 03:12:55 -04:00
|
|
|
char* value = getenv(name);
|
|
|
|
if(value == NULL)
|
2004-09-19 17:39:28 -04:00
|
|
|
dpush(F);
|
2004-08-04 03:12:55 -04:00
|
|
|
else
|
2004-09-19 17:39:28 -04:00
|
|
|
box_c_string(getenv(name));
|
2004-08-04 03:12:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void primitive_eq(void)
|
|
|
|
{
|
2004-08-12 17:36:36 -04:00
|
|
|
dpush(tag_boolean(dpop() == dpop()));
|
2004-08-04 03:12:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void primitive_millis(void)
|
|
|
|
{
|
|
|
|
struct timeval t;
|
|
|
|
gettimeofday(&t,NULL);
|
2004-09-05 20:14:37 -04:00
|
|
|
dpush(tag_object(s48_long_long_to_bignum(
|
|
|
|
(long long)t.tv_sec * 1000 + t.tv_usec/1000)));
|
2004-08-04 03:12:55 -04:00
|
|
|
}
|
2004-08-04 18:25:29 -04:00
|
|
|
|
|
|
|
void primitive_init_random(void)
|
|
|
|
{
|
2004-08-04 23:09:33 -04:00
|
|
|
#ifdef HAVE_SRANDOMDEV
|
2004-08-04 18:25:29 -04:00
|
|
|
srandomdev();
|
2004-08-04 23:09:33 -04:00
|
|
|
#else
|
|
|
|
struct timeval t;
|
|
|
|
gettimeofday(&t,NULL);
|
|
|
|
srandom(t.tv_sec);
|
|
|
|
#endif
|
2004-08-04 18:25:29 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void primitive_random_int(void)
|
|
|
|
{
|
2004-08-25 02:00:52 -04:00
|
|
|
dpush(tag_object(s48_long_to_bignum(random())));
|
2004-08-04 18:25:29 -04:00
|
|
|
}
|
2004-08-24 23:46:55 -04:00
|
|
|
|
|
|
|
void primitive_dump(void)
|
|
|
|
{
|
|
|
|
/* Take an object, and print its memory. Later, return a vector */
|
|
|
|
CELL obj = dpop();
|
|
|
|
CELL size = object_size(obj);
|
|
|
|
int i;
|
|
|
|
for(i = 0; i < size; i += CELLS)
|
2004-08-27 23:20:10 -04:00
|
|
|
fprintf(stderr,"%lx\n",get(UNTAG(obj) + i));
|
2004-08-24 23:46:55 -04:00
|
|
|
}
|