diff options
author | Kaz Kyheku <kaz@kylheku.com> | 2020-02-24 23:03:08 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2020-02-24 23:03:08 -0800 |
commit | 0e3c047c3fa3ef7d3e7168314bf6fdb0ba15443d (patch) | |
tree | ef7aa64fa706ae84f823cb725b63c4b91b4be4b5 /lib.c | |
parent | 3830cf321258321719865709081a709c97fd4e0a (diff) | |
download | txr-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.c | 28 |
1 files changed, 28 insertions, 0 deletions
@@ -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); |