summaryrefslogtreecommitdiffstats
path: root/lib.c
diff options
context:
space:
mode:
authorKaz Kyheku <kaz@kylheku.com>2020-02-24 23:03:08 -0800
committerKaz Kylheku <kaz@kylheku.com>2020-02-24 23:03:08 -0800
commit0e3c047c3fa3ef7d3e7168314bf6fdb0ba15443d (patch)
treeef7aa64fa706ae84f823cb725b63c4b91b4be4b5 /lib.c
parent3830cf321258321719865709081a709c97fd4e0a (diff)
downloadtxr-0e3c047c3fa3ef7d3e7168314bf6fdb0ba15443d.tar.gz
txr-0e3c047c3fa3ef7d3e7168314bf6fdb0ba15443d.tar.bz2
txr-0e3c047c3fa3ef7d3e7168314bf6fdb0ba15443d.zip
New function: assq and rassq.
TXR Lisp is henceforth a dialect in which (cdr (assq key a-list)) works exactly as shown, without substitution of assql or assoc. * eval.c (eval_init): Register assq and rassq intrinsics. * lib.c (assq, rassq): New functions. * lib.h (assq, rassq): Declared. * txr.1: Documented. * tests/012/ashwin.tl: New file. * tests/012/ashwin.expected: New file.
Diffstat (limited to 'lib.c')
-rw-r--r--lib.c28
1 files changed, 28 insertions, 0 deletions
diff --git a/lib.c b/lib.c
index 011da356..dc9f28d3 100644
--- a/lib.c
+++ b/lib.c
@@ -8178,6 +8178,20 @@ val assql(val key, val list)
return nil;
}
+val assq(val key, val list)
+{
+ list = nullify(list);
+
+ while (list) {
+ val elem = car(list);
+ if (eq(car(elem), key))
+ return elem;
+ list = cdr(list);
+ }
+
+ return nil;
+}
+
val rassoc(val key, val list)
{
list = nullify(list);
@@ -8206,6 +8220,20 @@ val rassql(val key, val list)
return nil;
}
+val rassq(val key, val list)
+{
+ list = nullify(list);
+
+ while (list) {
+ val elem = car(list);
+ if (eq(cdr(elem), key))
+ return elem;
+ list = cdr(list);
+ }
+
+ return nil;
+}
+
val acons(val car, val cdr, val list)
{
return cons(cons(car, cdr), list);