factor/native/misc.c

56 lines
953 B
C
Raw Normal View History

2004-08-04 03:12:55 -04:00
#include "factor.h"
void primitive_exit(void)
{
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)
{
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
}
void primitive_init_random(void)
{
2004-08-04 23:09:33 -04:00
#ifdef HAVE_SRANDOMDEV
srandomdev();
2004-08-04 23:09:33 -04:00
#else
struct timeval t;
gettimeofday(&t,NULL);
srandom(t.tv_sec);
#endif
}
void primitive_random_int(void)
{
2004-08-25 02:00:52 -04:00
dpush(tag_object(s48_long_to_bignum(random())));
}
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
}