summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2018-12-13 06:28:50 -0800
committerKaz Kylheku <kaz@kylheku.com>2018-12-13 06:28:50 -0800
commitc547316cbfa514fd793a147c6f2e5aa5d5e0e283 (patch)
treeebcb101d2265a8e4bf411403c67f86fc61ffe703
parent526a9c89d0c74788adbc1492e613d174f03fb268 (diff)
downloadtxr-c547316cbfa514fd793a147c6f2e5aa5d5e0e283.tar.gz
txr-c547316cbfa514fd793a147c6f2e5aa5d5e0e283.tar.bz2
txr-c547316cbfa514fd793a147c6f2e5aa5d5e0e283.zip
nzerop: new function.
* arith.c (nzerop): New function. * eval.c (eval_init): Register nzerop intrinsic. * lib.h (nzerop): Declared. * txr.1: Documented.
-rw-r--r--arith.c22
-rw-r--r--eval.c1
-rw-r--r--lib.h1
-rw-r--r--txr.125
4 files changed, 48 insertions, 1 deletions
diff --git a/arith.c b/arith.c
index 084d8cf5..67fa75c2 100644
--- a/arith.c
+++ b/arith.c
@@ -1557,6 +1557,28 @@ val zerop(val num)
}
}
+val nzerop(val num)
+{
+ val self = lit("nzerop");
+
+ if (num == zero)
+ return nil;
+
+ switch (type(num)) {
+ case NUM:
+ case BGNUM:
+ return t;
+ case FLNUM:
+ return tnil(c_flo(num, self) != 0.0);
+ case CHR:
+ return tnil(num != chr(0));
+ case RNG:
+ return tnil(nzerop(from(num)) || nzerop(to(num)));
+ default:
+ not_number(self, num);
+ }
+}
+
val plusp(val num)
{
val self = lit("plusp");
diff --git a/eval.c b/eval.c
index b26dc5b1..9cfeba03 100644
--- a/eval.c
+++ b/eval.c
@@ -6445,6 +6445,7 @@ void eval_init(void)
reg_fun(intern(lit("numberp"), user_package), func_n1(numberp));
reg_fun(intern(lit("zerop"), user_package), func_n1(zerop));
+ reg_fun(intern(lit("nzerop"), user_package), func_n1(nzerop));
reg_fun(intern(lit("plusp"), user_package), func_n1(plusp));
reg_fun(intern(lit("minusp"), user_package), func_n1(minusp));
reg_fun(intern(lit("evenp"), user_package), func_n1(evenp));
diff --git a/lib.h b/lib.h
index d74304db..6570d904 100644
--- a/lib.h
+++ b/lib.h
@@ -685,6 +685,7 @@ val wrap_star(val start, val end, val num);
val wrap(val start, val end, val num);
val divi(val anum, val bnum);
val zerop(val num);
+val nzerop(val num);
val plusp(val num);
val minusp(val num);
val evenp(val num);
diff --git a/txr.1 b/txr.1
index 19b0580d..4d1249df 100644
--- a/txr.1
+++ b/txr.1
@@ -35770,9 +35770,10 @@ a
or
.codn float .
-.coNP Function @ zerop
+.coNP Functions @ zerop and @ nzerop
.synb
.mets (zerop << number )
+.mets (nzerop << number )
.syne
.desc
The
@@ -35797,6 +35798,28 @@ and
.code nil
for all other characters.
+If
+.meta number
+is a range, then
+.code zerop
+returns
+.code t
+if both of the range endpoints individually satisfy
+.codn zerop .
+
+The
+.code nzerop
+function is the logical inverse of
+.codn zerop :
+it returns
+.code t
+for those arguments for which
+.code zerop
+returns
+.code nil
+and
+.IR "vice versa" .
+
.coNP Functions @ plusp and @ minusp
.synb
.mets (plusp << number )