summaryrefslogtreecommitdiffstats
path: root/lib.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2015-07-22 20:41:54 -0700
committerKaz Kylheku <kaz@kylheku.com>2015-07-22 20:41:54 -0700
commitd6760da67732419d8043d1fdc43e8081f96ef1f1 (patch)
tree021b792bbba89c65d5fbfeaa9132f6325988d11b /lib.c
parent0dd87c5b673f94f06263ace234e689e953bf3393 (diff)
downloadtxr-d6760da67732419d8043d1fdc43e8081f96ef1f1.tar.gz
txr-d6760da67732419d8043d1fdc43e8081f96ef1f1.tar.bz2
txr-d6760da67732419d8043d1fdc43e8081f96ef1f1.zip
Adding nthcdr as accessor.
* eval.c (eval_init): Register nthcdr function. * lib.c (nthcdr): New function. * lib.h (nthcdr): Declared. * share/txr/stdlib/place.tl (nthcdr): New defplace. * txr.1: Documented.
Diffstat (limited to 'lib.c')
-rw-r--r--lib.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/lib.c b/lib.c
index 4d0c901b..6a662fbc 100644
--- a/lib.c
+++ b/lib.c
@@ -498,6 +498,19 @@ val last(val list)
return nullocp(p) ? list : deref(p);
}
+val nthcdr(val pos, val list)
+{
+ cnum n = c_num(pos);
+
+ if (n < 0)
+ uw_throwf(error_s, lit("nthcdr: negative index ~s given"), pos, nao);
+
+ while (n-- > 0)
+ list = cdr(list);
+
+ return list;
+}
+
loc ltail(loc cons)
{
while (cdr(deref(cons)))