summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--lib.c13
2 files changed, 17 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 5fca6fb8..59c2e55a 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
2012-03-16 Kaz Kylheku <kaz@kylheku.com>
+ * lib.c (do_chain): More useful behavior. The first
+ function, if any, is treated as variadic. Subsequent
+ functions are monadic.
+ (chain, chainv): Turn do_chain into variadic.
+
+2012-03-16 Kaz Kylheku <kaz@kylheku.com>
+
* eval.c (eval_init): New intrinsic functions
chain, andf, orf, iff.
diff --git a/lib.c b/lib.c
index 9d3c1ccb..7462f685 100644
--- a/lib.c
+++ b/lib.c
@@ -2815,8 +2815,15 @@ val curry_1234_34(val fun4, val arg1, val arg2)
return func_f2(cons(fun4, cons(arg1, arg2)), do_curry_1234_34);
}
-static val do_chain(val fun1_list, val arg)
+static val do_chain(val fun1_list, val args)
{
+ val arg = nil;
+
+ if (fun1_list) {
+ arg = apply(car(fun1_list), args, nil);
+ fun1_list = cdr(fun1_list);
+ }
+
for (; fun1_list; fun1_list = cdr(fun1_list))
arg = funcall1(car(fun1_list), arg);
@@ -2839,12 +2846,12 @@ val chain(val first_fun, ...)
va_end (vl);
}
- return func_f1(out, do_chain);
+ return func_f0v(out, do_chain);
}
val chainv(val funlist)
{
- return func_f1(funlist, do_chain);
+ return func_f0v(funlist, do_chain);
}
static val do_and(val fun1_list, val args)