diff options
-rw-r--r-- | src/ChangeLog | 11 | ||||
-rw-r--r-- | src/interp/bits.lisp | 9 | ||||
-rw-r--r-- | src/interp/g-opt.boot | 29 | ||||
-rw-r--r-- | src/interp/lisp-backend.boot | 4 |
4 files changed, 28 insertions, 25 deletions
diff --git a/src/ChangeLog b/src/ChangeLog index c0e20a55..297b9991 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,14 @@ +2011-06-22 Gabriel Dos Reis <gdr@cs.tamu.edu> + + * interp/g-opt.boot (optCond): Remove unreachable code. + (opt2bit): Tidy. + (opt2bool): Likewise. + * interp/bits.lisp (TRUTH-TO-BIT): Remove. + (BIT-TO-TRUTH): Likewise. + (BVEC-MAKE-FULL): Likewise. + (BVEC-ELT): Likewise. + (BVEC-SETELT): Likewise. + 2011-06-21 Gabriel Dos Reis <gdr@cs.tamu.edu> * interp/Makefile.in (OBJS): Remove foam_l.$(FASLEXT), $(ASCOMP). diff --git a/src/interp/bits.lisp b/src/interp/bits.lisp index 5b20b3e7..8a97cb10 100644 --- a/src/interp/bits.lisp +++ b/src/interp/bits.lisp @@ -47,15 +47,6 @@ ;;; SMW Nov 88: Created -(defmacro truth-to-bit (x) `(cond (,x 1) ('else 0))) -(defmacro bit-to-truth (b) `(eql ,b 1)) - -(defun bvec-make-full (n x) - (make-array (list n) :element-type 'bit :initial-element x)) - -(defmacro bvec-elt (bv i) `(sbit ,bv ,i)) -(defmacro bvec-setelt (bv i x) `(setf (sbit ,bv ,i) ,x)) - (defun bvec-greater (bv1 bv2) (let ((pos (mismatch bv1 bv2))) (cond ((or (null pos) (>= pos (length bv1))) nil) diff --git a/src/interp/g-opt.boot b/src/interp/g-opt.boot index f1dd8d2e..8a6c0d91 100644 --- a/src/interp/g-opt.boot +++ b/src/interp/g-opt.boot @@ -287,6 +287,9 @@ optCons (x is ["CONS",a,b]) == x optCond (x is ['%when,:l]) == + l is [['%true,c],:.] => c + l is [['%false,.],:.] => optCond ['%when,:rest l] + l is [['%otherwise,c]] => c if l is [a,[aa,b]] and aa is '%otherwise and b is ['%when,:c] then x.rest.rest := c if l is [[p1,:c1],[p2,:c2],:.] then @@ -680,10 +683,20 @@ optOr(x is ['%or,a,b]) == a is '%true => '%true x +-- Boolean <-> bit conversion. +opt2bit ['%2bit,a] == + optCond ['%when,[a,'%icst1],['%otherwise,'%icst0]] + +opt2bool ['%2bool,a] == + a is '%icst0 => '%false + a is '%icst1 => '%true + optIeq ['%ieq,a,'%icst1] + optIeq(x is ['%ieq,a,b]) == integer? a and integer? b => - a = b => '%true + scalarEq?(a,b) => '%true '%false + sameObject?(a,b) => '%true x optIlt(x is ['%ilt,a,b]) == @@ -752,23 +765,11 @@ optIquo(x is ['%iquo,a,b]) == integer? a and integer? b => a quo b x --- Boolean <-> bit conversion. -opt2bit(x is ['%2bit,a]) == - a is '%true => 1 - a is '%false => 0 - x - -opt2bool(x is ['%2bool,a]) == - integer? a => - a = 1 => '%true - '%false - x - --% --% optimizer hash table --% -for x in '( (%call optCall) _ +for x in '((%call optCall) _ (SEQ optSEQ)_ (LET optLET)_ (%bind optBind)_ diff --git a/src/interp/lisp-backend.boot b/src/interp/lisp-backend.boot index 3b254c78..a6fe5da7 100644 --- a/src/interp/lisp-backend.boot +++ b/src/interp/lisp-backend.boot @@ -446,8 +446,6 @@ for x in [ ['%true, :'T], -- unary Boolean operations ['%not, :'NOT], - ['%2bit, :'TRUTH_-TO_-BIT], - ['%2bool, :'BIT_-TO_-TRUTH], -- binary Boolean operations ['%and, :'AND], ['%or, :'OR], @@ -470,6 +468,8 @@ for x in [ ['%blt, :'byteLessThan], -- integer constants + ['%icst0, :0], + ['%icst1, :1], ['%icstmin, :'_$ShortMinimum], ['%icstmax, :'_$ShortMaximum], -- unary integer operations. |