summaryrefslogtreecommitdiffstats
path: root/lib.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2014-10-16 19:01:26 -0700
committerKaz Kylheku <kaz@kylheku.com>2014-10-16 19:01:26 -0700
commit499f04dc4f9f864071d6ff7e75c9cbec60e2fd12 (patch)
treea088c450568622b02c46dbce6cec053861c04569 /lib.c
parentb2dfc50f1c98417166d647538d7d5ecd6178dd4c (diff)
downloadtxr-499f04dc4f9f864071d6ff7e75c9cbec60e2fd12.tar.gz
txr-499f04dc4f9f864071d6ff7e75c9cbec60e2fd12.tar.bz2
txr-499f04dc4f9f864071d6ff7e75c9cbec60e2fd12.zip
* arith.c (gcd): Fix semantics. If either operand is
zero, return the other operand. (lcm): New function. * eval.c (eval_init): Retarget registration of gcd to variable argument gcdv function. Register lcm. * lib.c (gcdv, lcmv): New functions. * lib.h (gcdv, lcm, lcmv): Declared. * txr.1: Re-document gcd with coverage of lcm. * txr.vim: Regenerated.
Diffstat (limited to 'lib.c')
-rw-r--r--lib.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/lib.c b/lib.c
index d25e47e3..4b929c97 100644
--- a/lib.c
+++ b/lib.c
@@ -2150,6 +2150,24 @@ val exptv(val nlist)
return reduce_right(func_n2(expt), nlist, one, nil);
}
+val gcdv(val nlist)
+{
+ if (!nlist)
+ return zero;
+ if (!cdr(nlist))
+ return abso(car(nlist));
+ return reduce_left(func_n2(gcd), nlist, colon_k, nil);
+}
+
+val lcmv(val nlist)
+{
+ if (!nlist)
+ return one;
+ if (!cdr(nlist))
+ return abso(car(nlist));
+ return reduce_left(func_n2(lcm), nlist, colon_k, nil);
+}
+
val string_own(wchar_t *str)
{
val obj = make_obj();