2004-07-16 02:26:21 -04:00
|
|
|
#include "factor.h"
|
|
|
|
|
|
|
|
XT primitives[] = {
|
2004-08-04 22:43:58 -04:00
|
|
|
undefined,
|
2004-08-23 01:13:09 -04:00
|
|
|
docol,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_execute,
|
|
|
|
primitive_call,
|
|
|
|
primitive_ifte,
|
|
|
|
primitive_cons,
|
|
|
|
primitive_car,
|
|
|
|
primitive_cdr,
|
|
|
|
primitive_set_car,
|
|
|
|
primitive_set_cdr,
|
|
|
|
primitive_vector,
|
|
|
|
primitive_vector_length,
|
|
|
|
primitive_set_vector_length,
|
|
|
|
primitive_vector_nth,
|
|
|
|
primitive_set_vector_nth,
|
|
|
|
primitive_string_length,
|
|
|
|
primitive_string_nth,
|
|
|
|
primitive_string_compare,
|
|
|
|
primitive_string_eq,
|
|
|
|
primitive_string_hashcode,
|
|
|
|
primitive_index_of,
|
|
|
|
primitive_substring,
|
2004-09-06 22:39:12 -04:00
|
|
|
primitive_string_reverse,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_sbuf,
|
|
|
|
primitive_sbuf_length,
|
|
|
|
primitive_set_sbuf_length,
|
|
|
|
primitive_sbuf_nth,
|
|
|
|
primitive_set_sbuf_nth,
|
|
|
|
primitive_sbuf_append,
|
|
|
|
primitive_sbuf_to_string,
|
2004-08-25 20:51:19 -04:00
|
|
|
primitive_sbuf_reverse,
|
|
|
|
primitive_sbuf_clone,
|
2004-08-12 01:07:22 -04:00
|
|
|
primitive_sbuf_eq,
|
2004-09-26 21:34:25 -04:00
|
|
|
primitive_sbuf_hashcode,
|
2004-09-19 00:33:40 -04:00
|
|
|
primitive_arithmetic_type,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_numberp,
|
|
|
|
primitive_to_fixnum,
|
|
|
|
primitive_to_bignum,
|
2004-08-05 17:33:02 -04:00
|
|
|
primitive_to_float,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_numerator,
|
|
|
|
primitive_denominator,
|
2004-09-18 22:29:29 -04:00
|
|
|
primitive_to_fraction,
|
|
|
|
primitive_from_fraction,
|
2004-08-05 17:33:02 -04:00
|
|
|
primitive_str_to_float,
|
|
|
|
primitive_float_to_str,
|
2004-08-06 02:51:32 -04:00
|
|
|
primitive_float_to_bits,
|
2004-08-05 20:29:52 -04:00
|
|
|
primitive_real,
|
|
|
|
primitive_imaginary,
|
|
|
|
primitive_to_rect,
|
|
|
|
primitive_from_rect,
|
2004-09-19 00:33:40 -04:00
|
|
|
primitive_fixnum_eq,
|
|
|
|
primitive_fixnum_add,
|
|
|
|
primitive_fixnum_subtract,
|
|
|
|
primitive_fixnum_multiply,
|
|
|
|
primitive_fixnum_divint,
|
|
|
|
primitive_fixnum_divfloat,
|
|
|
|
primitive_fixnum_mod,
|
|
|
|
primitive_fixnum_divmod,
|
|
|
|
primitive_fixnum_and,
|
|
|
|
primitive_fixnum_or,
|
|
|
|
primitive_fixnum_xor,
|
|
|
|
primitive_fixnum_not,
|
|
|
|
primitive_fixnum_shift,
|
|
|
|
primitive_fixnum_less,
|
|
|
|
primitive_fixnum_lesseq,
|
|
|
|
primitive_fixnum_greater,
|
|
|
|
primitive_fixnum_greatereq,
|
|
|
|
primitive_bignum_eq,
|
|
|
|
primitive_bignum_add,
|
|
|
|
primitive_bignum_subtract,
|
|
|
|
primitive_bignum_multiply,
|
|
|
|
primitive_bignum_divint,
|
|
|
|
primitive_bignum_divfloat,
|
|
|
|
primitive_bignum_mod,
|
|
|
|
primitive_bignum_divmod,
|
|
|
|
primitive_bignum_and,
|
|
|
|
primitive_bignum_or,
|
|
|
|
primitive_bignum_xor,
|
|
|
|
primitive_bignum_not,
|
|
|
|
primitive_bignum_shift,
|
|
|
|
primitive_bignum_less,
|
|
|
|
primitive_bignum_lesseq,
|
|
|
|
primitive_bignum_greater,
|
|
|
|
primitive_bignum_greatereq,
|
|
|
|
primitive_float_eq,
|
|
|
|
primitive_float_add,
|
|
|
|
primitive_float_subtract,
|
|
|
|
primitive_float_multiply,
|
|
|
|
primitive_float_divfloat,
|
|
|
|
primitive_float_less,
|
|
|
|
primitive_float_lesseq,
|
|
|
|
primitive_float_greater,
|
|
|
|
primitive_float_greatereq,
|
2004-08-06 18:40:44 -04:00
|
|
|
primitive_facos,
|
|
|
|
primitive_fasin,
|
|
|
|
primitive_fatan,
|
|
|
|
primitive_fatan2,
|
|
|
|
primitive_fcos,
|
|
|
|
primitive_fexp,
|
|
|
|
primitive_fcosh,
|
|
|
|
primitive_flog,
|
|
|
|
primitive_fpow,
|
|
|
|
primitive_fsin,
|
|
|
|
primitive_fsinh,
|
|
|
|
primitive_fsqrt,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_word,
|
2004-08-29 04:03:16 -04:00
|
|
|
primitive_word_hashcode,
|
2004-09-06 02:32:04 -04:00
|
|
|
primitive_word_xt,
|
|
|
|
primitive_set_word_xt,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_word_primitive,
|
|
|
|
primitive_set_word_primitive,
|
|
|
|
primitive_word_parameter,
|
|
|
|
primitive_set_word_parameter,
|
|
|
|
primitive_word_plist,
|
|
|
|
primitive_set_word_plist,
|
|
|
|
primitive_drop,
|
|
|
|
primitive_dup,
|
|
|
|
primitive_swap,
|
|
|
|
primitive_over,
|
|
|
|
primitive_pick,
|
|
|
|
primitive_nip,
|
|
|
|
primitive_tuck,
|
|
|
|
primitive_rot,
|
|
|
|
primitive_to_r,
|
|
|
|
primitive_from_r,
|
|
|
|
primitive_eq,
|
|
|
|
primitive_getenv,
|
|
|
|
primitive_setenv,
|
|
|
|
primitive_open_file,
|
2004-08-29 23:30:54 -04:00
|
|
|
primitive_stat,
|
2004-08-30 00:36:44 -04:00
|
|
|
primitive_read_dir,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_gc,
|
|
|
|
primitive_save_image,
|
|
|
|
primitive_datastack,
|
|
|
|
primitive_callstack,
|
|
|
|
primitive_set_datastack,
|
|
|
|
primitive_set_callstack,
|
|
|
|
primitive_exit,
|
2004-08-18 15:23:42 -04:00
|
|
|
primitive_client_socket,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_server_socket,
|
2004-08-20 01:49:14 -04:00
|
|
|
primitive_close,
|
2004-08-15 22:45:08 -04:00
|
|
|
primitive_add_accept_io_task,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_accept_fd,
|
2004-08-15 21:50:44 -04:00
|
|
|
primitive_can_read_line,
|
|
|
|
primitive_add_read_line_io_task,
|
2004-08-20 01:49:14 -04:00
|
|
|
primitive_read_line_8,
|
|
|
|
primitive_can_read_count,
|
|
|
|
primitive_add_read_count_io_task,
|
|
|
|
primitive_read_count_8,
|
2004-08-15 21:50:44 -04:00
|
|
|
primitive_can_write,
|
|
|
|
primitive_add_write_io_task,
|
2004-08-20 01:49:14 -04:00
|
|
|
primitive_write_8,
|
2004-08-28 22:25:59 -04:00
|
|
|
primitive_add_copy_io_task,
|
2004-09-02 21:51:19 -04:00
|
|
|
primitive_pending_io_error,
|
2004-08-15 21:50:44 -04:00
|
|
|
primitive_next_io_task,
|
2004-08-04 22:43:58 -04:00
|
|
|
primitive_room,
|
|
|
|
primitive_os_env,
|
|
|
|
primitive_millis,
|
|
|
|
primitive_init_random,
|
2004-08-06 02:51:32 -04:00
|
|
|
primitive_random_int,
|
2004-09-18 22:29:29 -04:00
|
|
|
primitive_type,
|
|
|
|
primitive_size,
|
2004-08-29 03:20:19 -04:00
|
|
|
primitive_call_profiling,
|
2004-08-23 01:13:09 -04:00
|
|
|
primitive_word_call_count,
|
2004-08-24 23:46:55 -04:00
|
|
|
primitive_set_word_call_count,
|
2004-08-29 03:20:19 -04:00
|
|
|
primitive_allot_profiling,
|
|
|
|
primitive_word_allot_count,
|
|
|
|
primitive_set_word_allot_count,
|
2004-09-04 03:06:53 -04:00
|
|
|
primitive_dump,
|
|
|
|
primitive_cwd,
|
2004-09-06 02:32:04 -04:00
|
|
|
primitive_cd,
|
2004-09-06 22:39:12 -04:00
|
|
|
primitive_compiled_offset,
|
|
|
|
primitive_set_compiled_offset,
|
2004-09-19 17:39:28 -04:00
|
|
|
primitive_set_compiled_cell,
|
|
|
|
primitive_set_compiled_byte,
|
2004-09-06 22:39:12 -04:00
|
|
|
primitive_literal_top,
|
|
|
|
primitive_set_literal_top,
|
2004-09-18 22:29:29 -04:00
|
|
|
primitive_address,
|
2004-09-18 18:15:01 -04:00
|
|
|
primitive_dlopen,
|
|
|
|
primitive_dlsym,
|
|
|
|
primitive_dlsym_self,
|
2004-09-19 17:39:28 -04:00
|
|
|
primitive_dlclose,
|
|
|
|
primitive_alien,
|
2004-09-21 22:58:54 -04:00
|
|
|
primitive_local_alien,
|
2004-09-19 17:39:28 -04:00
|
|
|
primitive_alien_cell,
|
|
|
|
primitive_set_alien_cell,
|
|
|
|
primitive_alien_4,
|
|
|
|
primitive_set_alien_4,
|
2004-09-20 21:02:48 -04:00
|
|
|
primitive_alien_2,
|
|
|
|
primitive_set_alien_2,
|
2004-09-19 17:39:28 -04:00
|
|
|
primitive_alien_1,
|
2004-09-21 12:41:57 -04:00
|
|
|
primitive_set_alien_1,
|
|
|
|
primitive_heap_stats
|
2004-07-16 02:26:21 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
CELL primitive_to_xt(CELL primitive)
|
|
|
|
{
|
|
|
|
if(primitive < 0 || primitive >= PRIMITIVE_COUNT)
|
2004-08-29 01:04:42 -04:00
|
|
|
general_error(ERROR_BAD_PRIMITIVE,tag_fixnum(primitive));
|
2004-08-04 22:43:58 -04:00
|
|
|
|
2004-07-29 17:18:41 -04:00
|
|
|
return (CELL)primitives[primitive];
|
2004-07-16 02:26:21 -04:00
|
|
|
}
|