aboutsummaryrefslogtreecommitdiff
path: root/src/interp
diff options
context:
space:
mode:
Diffstat (limited to 'src/interp')
-rw-r--r--src/interp/g-opt.boot32
-rw-r--r--src/interp/nruncomp.boot4
-rw-r--r--src/interp/wi2.boot8
3 files changed, 10 insertions, 34 deletions
diff --git a/src/interp/g-opt.boot b/src/interp/g-opt.boot
index b7b90ed9..4806b103 100644
--- a/src/interp/g-opt.boot
+++ b/src/interp/g-opt.boot
@@ -243,25 +243,10 @@ optCall (x is ['%call,:u]) ==
x.rest := [:a,name]
x
fn is [q,R,n] and q in '(getShellEntry ELT QREFELT CONST) =>
- not $bootStrapMode and (w := optCallSpecially(q,x,n,R)) => resetTo(x,w)
q = 'CONST => ['spadConstant,R,n]
emitIndirectCall(fn,a,x)
systemErrorHere ['optCall,x]
-optCallSpecially(q,x,n,R) ==
- optimizableDomain? R => optSpecialCall(x,R,n)
- (y:= get(R,"value",$e)) and optimizableDomain? y.expr =>
- optSpecialCall(x,y.expr,n)
- nil
-
-optCallEval u ==
- u is ["List",:.] => List Integer()
- u is ["Vector",:.] => Vector Integer()
- u is ["PrimitiveArray",:.] => PrimitiveArray Integer()
- u is ["FactoredForm",:.] => FactoredForm Integer()
- u is ["Matrix",:.] => Matrix Integer()
- eval u
-
optCons (x is ["CONS",a,b]) ==
a="NIL" =>
b='NIL => (x.first := 'QUOTE; x.rest := ['NIL,:'NIL]; x)
@@ -273,23 +258,6 @@ optCons (x is ["CONS",a,b]) ==
x
x
-optSpecialCall(x,y,n) ==
- yval := optCallEval y
- CAAAR x="CONST" =>
- KAR yval.n = function Undef =>
- keyedSystemError("S2GE0016",['"optSpecialCall",
- '"invalid constant"])
- MKQ yval.n
- fn := getFunctionReplacement compileTimeBindingOf first yval.n =>
- x.rest := CDAR x
- x.first := fn
- if fn is ["XLAM",:.] then x := simplifyVMForm x
- x is ["EQUAL",:args] => resetTo(x,DEF_-EQUAL args)
- --DEF-EQUAL is really an optimiser
- x
- [fn,:a]:= first x
- emitIndirectCall(fn,a,x)
-
compileTimeBindingOf u ==
null(name:= BPINAME u) => keyedSystemError("S2OO0001",[u])
name="Undef" => MOAN "optimiser found unknown function"
diff --git a/src/interp/nruncomp.boot b/src/interp/nruncomp.boot
index 68169169..ddcbb16e 100644
--- a/src/interp/nruncomp.boot
+++ b/src/interp/nruncomp.boot
@@ -171,8 +171,8 @@ optDeltaEntry(op,sig,dc,eltOrConst) ==
atom dc and (dcval := get(dc,'value,$e)) => dcval.expr
dc
sig := MSUBST(ndc,dc,sig)
- -- Don't bothe if the domain of computation is not an instantiation,
- -- or is candidate for inlining.
+ -- Don't bother if the domain of computation is not an instantiation
+ -- nor a candidate for inlining.
atom ndc or not optimizableDomain? ndc => nil
fun := lookupDefiningFunction(op,sig,ndc)
-- following code is to handle selectors like first, rest
diff --git a/src/interp/wi2.boot b/src/interp/wi2.boot
index 51d2fe33..f519b830 100644
--- a/src/interp/wi2.boot
+++ b/src/interp/wi2.boot
@@ -599,6 +599,14 @@ compMapCond''(cexpr,dc) ==
--======================================================================
-- From nruncomp.boot
--======================================================================
+optCallEval u ==
+ u is ["List",:.] => List Integer()
+ u is ["Vector",:.] => Vector Integer()
+ u is ["PrimitiveArray",:.] => PrimitiveArray Integer()
+ u is ["FactoredForm",:.] => FactoredForm Integer()
+ u is ["Matrix",:.] => Matrix Integer()
+ eval u
+
optDeltaEntry(op,sig,dc,eltOrConst) ==
return nil --------> kill it
$killOptimizeIfTrue = true => nil