summaryrefslogtreecommitdiffstats
path: root/share
diff options
context:
space:
mode:
Diffstat (limited to 'share')
-rw-r--r--share/txr/stdlib/compiler.tl8
1 files changed, 6 insertions, 2 deletions
diff --git a/share/txr/stdlib/compiler.tl b/share/txr/stdlib/compiler.tl
index 5553f293..60411e39 100644
--- a/share/txr/stdlib/compiler.tl
+++ b/share/txr/stdlib/compiler.tl
@@ -206,6 +206,9 @@
(or [*dedup* obj] (set [*dedup* obj] obj)))
(t obj)))
+(defun null-reg (reg)
+ (equal reg '(t 0)))
+
(defmeth compiler get-dreg (me obj)
(let ((dobj (dedup obj)))
(condlet
@@ -748,8 +751,9 @@
(frag me.(compile bind.loc fenv form)))
(when seq
fenv.(rename-var tmp sym))
- (pend frag.code
- (maybe-mov bind.loc frag.oreg))
+ (pend frag.code)
+ (unless (null-reg frag.oreg)
+ (pend (maybe-mov bind.loc frag.oreg)))
(set ffuns (uni ffuns frag.ffuns)
fvars (uni fvars
(if seq