diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2017-02-11 17:41:48 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2017-02-11 17:41:48 -0800 |
commit | ef33ae0c563543449d2284e13d6c9ba28654e64d (patch) | |
tree | eaa35be8bf1bbc90afea1d56e6f7407aa54a8c4e /lib.c | |
parent | e9ebac341d45521b4558a4d198129484ef094a8e (diff) | |
download | txr-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.c | 28 |
1 files changed, 28 insertions, 0 deletions
@@ -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); |