diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2011-12-10 10:22:07 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2011-12-10 10:22:07 -0800 |
commit | e3a60abafb1e7740f3c278396f703f4e47ebcf29 (patch) | |
tree | b22d3b2b59af09bdb98e89d42a95511209886fea /lib.c | |
parent | b2a9e9235656317a5608c2ef837ed0d7a4fd43ae (diff) | |
download | txr-e3a60abafb1e7740f3c278396f703f4e47ebcf29.tar.gz txr-e3a60abafb1e7740f3c278396f703f4e47ebcf29.tar.bz2 txr-e3a60abafb1e7740f3c278396f703f4e47ebcf29.zip |
* lib.c (plusv): Recognize cases to eliminate a wasteful plus call
with an initial element of zero.
Diffstat (limited to 'lib.c')
-rw-r--r-- | lib.c | 6 |
1 files changed, 5 insertions, 1 deletions
@@ -834,7 +834,11 @@ val bignump(val num) val plusv(val nlist) { - return reduce_left(func_n2(plus), nlist, num(0), nil); + if (!nlist) + return num(0); + else if (!cdr(nlist)) + return car(nlist); + return reduce_left(func_n2(plus), cdr(nlist), car(nlist), nil); } val minusv(val minuend, val nlist) |