summaryrefslogtreecommitdiffstats
path: root/lib.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2017-02-11 17:41:48 -0800
committerKaz Kylheku <kaz@kylheku.com>2017-02-11 17:41:48 -0800
commitef33ae0c563543449d2284e13d6c9ba28654e64d (patch)
treeeaa35be8bf1bbc90afea1d56e6f7407aa54a8c4e /lib.c
parente9ebac341d45521b4558a4d198129484ef094a8e (diff)
downloadtxr-ef33ae0c563543449d2284e13d6c9ba28654e64d.tar.gz
txr-ef33ae0c563543449d2284e13d6c9ba28654e64d.tar.bz2
txr-ef33ae0c563543449d2284e13d6c9ba28654e64d.zip
Add rassoc and rassql functions.
* eval.c (eval_init): Register rassoc and rassql intrinsics. * lib.c (rassoc, rassql): New functions. * lib.h (rassoc, rassql): Declared. * txr.1: Documented rassoc and rassql, with small fixes to assql and assoc.
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 8720218d..98e80315 100644
--- a/lib.c
+++ b/lib.c
@@ -7277,6 +7277,34 @@ val assql(val key, val list)
return nil;
}
+val rassoc(val key, val list)
+{
+ list = nullify(list);
+
+ while (list) {
+ val elem = car(list);
+ if (equal(cdr(elem), key))
+ return elem;
+ list = cdr(list);
+ }
+
+ return nil;
+}
+
+val rassql(val key, val list)
+{
+ list = nullify(list);
+
+ while (list) {
+ val elem = car(list);
+ if (eql(cdr(elem), key))
+ return elem;
+ list = cdr(list);
+ }
+
+ return nil;
+}
+
val acons(val car, val cdr, val list)
{
return cons(cons(car, cdr), list);