diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2018-12-13 06:28:50 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2018-12-13 06:28:50 -0800 |
commit | c547316cbfa514fd793a147c6f2e5aa5d5e0e283 (patch) | |
tree | ebcb101d2265a8e4bf411403c67f86fc61ffe703 | |
parent | 526a9c89d0c74788adbc1492e613d174f03fb268 (diff) | |
download | txr-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.c | 22 | ||||
-rw-r--r-- | eval.c | 1 | ||||
-rw-r--r-- | lib.h | 1 | ||||
-rw-r--r-- | txr.1 | 25 |
4 files changed, 48 insertions, 1 deletions
@@ -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"); @@ -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)); @@ -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); @@ -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 ) |