implement native version of some primitive functions such as car,crd...
This commit is contained in:
parent
b9985dd682
commit
a2f022df4e
|
@ -1,10 +1,3 @@
|
|||
; Although looking like a magic, it just works.
|
||||
(define (car x)
|
||||
(car x))
|
||||
|
||||
(define (cdr x)
|
||||
(cdr x))
|
||||
|
||||
(define (zero? n)
|
||||
(= n 0))
|
||||
|
||||
|
@ -138,9 +131,6 @@
|
|||
(every pred (cdr list))
|
||||
#f)))
|
||||
|
||||
(define (null? obj)
|
||||
(null? obj))
|
||||
|
||||
(define (any pred list)
|
||||
(if (null? list)
|
||||
#f
|
||||
|
|
44
src/pair.c
44
src/pair.c
|
@ -125,6 +125,46 @@ pic_pair_pair_p(pic_state *pic)
|
|||
return pic_bool_value(pic_pair_p(v));
|
||||
}
|
||||
|
||||
static pic_value
|
||||
pic_pair_car(pic_state *pic)
|
||||
{
|
||||
pic_value v;
|
||||
|
||||
pic_get_args(pic, "o", &v);
|
||||
|
||||
return pic_car(pic, v);
|
||||
}
|
||||
|
||||
static pic_value
|
||||
pic_pair_cdr(pic_state *pic)
|
||||
{
|
||||
pic_value v;
|
||||
|
||||
pic_get_args(pic, "o", &v);
|
||||
|
||||
return pic_cdr(pic, v);
|
||||
}
|
||||
|
||||
static pic_value
|
||||
pic_pair_null_p(pic_state *pic)
|
||||
{
|
||||
pic_value v;
|
||||
|
||||
pic_get_args(pic, "o", &v);
|
||||
|
||||
return pic_bool_value(pic_nil_p(v));
|
||||
}
|
||||
|
||||
static pic_value
|
||||
pic_pair_cons(pic_state *pic)
|
||||
{
|
||||
pic_value v,w;
|
||||
|
||||
pic_get_args(pic, "oo", &v, &w);
|
||||
|
||||
return pic_cons(pic, v, w);
|
||||
}
|
||||
|
||||
static pic_value
|
||||
pic_pair_set_car(pic_state *pic)
|
||||
{
|
||||
|
@ -157,6 +197,10 @@ void
|
|||
pic_init_pair(pic_state *pic)
|
||||
{
|
||||
pic_defun(pic, "pair?", pic_pair_pair_p);
|
||||
pic_defun(pic, "car", pic_pair_car);
|
||||
pic_defun(pic, "cdr", pic_pair_cdr);
|
||||
pic_defun(pic, "null?", pic_pair_null_p);
|
||||
pic_defun(pic, "cons", pic_pair_cons);
|
||||
pic_defun(pic, "set-car!", pic_pair_set_car);
|
||||
pic_defun(pic, "set-cdr!", pic_pair_set_cdr);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue