diff options
Diffstat (limited to 'src/interp')
-rw-r--r-- | src/interp/Makefile.in | 9 | ||||
-rw-r--r-- | src/interp/define.boot | 14 | ||||
-rw-r--r-- | src/interp/functor.boot | 28 | ||||
-rw-r--r-- | src/interp/g-util.boot | 4 | ||||
-rw-r--r-- | src/interp/hashcode.boot | 115 | ||||
-rw-r--r-- | src/interp/interop.boot | 669 | ||||
-rw-r--r-- | src/interp/nrunfast.boot | 45 | ||||
-rw-r--r-- | src/interp/trace.boot | 15 |
8 files changed, 73 insertions, 826 deletions
diff --git a/src/interp/Makefile.in b/src/interp/Makefile.in index fab50106..1731f897 100644 --- a/src/interp/Makefile.in +++ b/src/interp/Makefile.in @@ -65,7 +65,7 @@ OBJS= boot-pkg.$(FASLEXT) types.$(FASLEXT) \ astr.$(FASLEXT) bits.$(FASLEXT) \ ht-util.$(FASLEXT) bc-util.$(FASLEXT) \ br-search.$(FASLEXT) alql.$(FASLEXT) \ - buildom.$(FASLEXT) hashcode.$(FASLEXT) \ + buildom.$(FASLEXT) \ simpbool.$(FASLEXT) g-timer.$(FASLEXT) \ cattable.$(FASLEXT) posit.$(FASLEXT) \ cformat.$(FASLEXT) clam.$(FASLEXT) \ @@ -109,7 +109,7 @@ OBJS= boot-pkg.$(FASLEXT) types.$(FASLEXT) \ # Last minite patches. # FIXMEL: should be folded into the main object list. -INOBJS= setvart.$(FASLEXT) interop.$(FASLEXT) patches.$(FASLEXT) +INOBJS= setvart.$(FASLEXT) patches.$(FASLEXT) # Main compiler files. OCOBJS= \ @@ -299,12 +299,11 @@ setvart.$(FASLEXT): macros.$(FASLEXT) compiler.$(FASLEXT): msgdb.$(FASLEXT) pathname.$(FASLEXT) define.$(FASLEXT) nrunfast.$(FASLEXT): c-util.$(FASLEXT) nruncomp.$(FASLEXT): profile.$(FASLEXT) simpbool.$(FASLEXT) functor.$(FASLEXT) -nrungo.$(FASLEXT): c-util.$(FASLEXT) clam.$(FASLEXT) interop.$(FASLEXT) define.$(FASLEXT): g-error.$(FASLEXT) nruncomp.$(FASLEXT) database.$(FASLEXT) database.$(FASLEXT): clam.$(FASLEXT) nlib.$(FASLEXT) daase.$(FASLEXT) \ cattable.$(FASLEXT) compat.$(FASLEXT) g-cndata.$(FASLEXT) \ c-util.$(FASLEXT) -functor.$(FASLEXT): category.$(FASLEXT) interop.$(FASLEXT) lisplib.$(FASLEXT) +functor.$(FASLEXT): category.$(FASLEXT) lisplib.$(FASLEXT) nrunfast.$(FASLEXT) category.$(FASLEXT): c-util.$(FASLEXT) g-cndata.$(FASLEXT) cattable.$(FASLEXT): simpbool.$(FASLEXT) c-util.$(FASLEXT) compat.$(FASLEXT): pathname.$(FASLEXT) @@ -312,7 +311,6 @@ simpbool.$(FASLEXT): macros.$(FASLEXT) newfort.$(FASLEXT): macros.$(FASLEXT) lisplib.$(FASLEXT): nlib.$(FASLEXT) c-util.$(FASLEXT) debug.$(FASLEXT) \ daase.$(FASLEXT) -interop.$(FASLEXT): interop.boot c-util.$(FASLEXT) hashcode.$(FASLEXT) c-doc.$(FASLEXT): c-util.$(FASLEXT) daase.$(FASLEXT) server.$(FASLEXT): macros.$(FASLEXT) @@ -382,7 +380,6 @@ msgdb.$(FASLEXT): g-util.$(FASLEXT) g-error.$(FASLEXT): diagnostics.$(FASLEXT) g-util.$(FASLEXT) c-util.$(FASLEXT): g-opt.$(FASLEXT) pathname.$(FASLEXT): nlib.$(FASLEXT) -hashcode.$(FASLEXT): g-util.$(FASLEXT) g-util.$(FASLEXT): ggreater.$(FASLEXT) macros.$(FASLEXT) sys-utility.$(FASLEXT) g-cndata.$(FASLEXT): sys-macros.$(FASLEXT) c-util.$(FASLEXT) msg.$(FASLEXT): sys-macros.$(FASLEXT) astr.$(FASLEXT) diff --git a/src/interp/define.boot b/src/interp/define.boot index 048efb2f..f4675b08 100644 --- a/src/interp/define.boot +++ b/src/interp/define.boot @@ -466,6 +466,20 @@ makeCompactSigCode sig == [fn for x in sig] where --======================================================================= -- Generate Slot 4 Constructor Vectors --======================================================================= +depthAssocList u == + u := removeSymbol(u,'DomainSubstitutionMacro) --hack by RDJ 8/90 + removeDuplicates ("append"/[depthAssoc(y) for y in u]) + +depthAssoc x == + y := tableValue($depthAssocCache,x) => y + x is ['Join,:u] or (u := getCatAncestors x) => + v := depthAssocList u + tableValue($depthAssocCache,x) := [[x,:n],:v] + where n() == 1 + "MAX"/[rest y for y in v] + tableValue($depthAssocCache,x) := [[x,:0]] + +getCatAncestors x == [CAAR y for y in parentsOf opOf x] + NRTmakeCategoryAlist() == $depthAssocCache: local := hashTable 'EQ $catAncestorAlist: local := nil diff --git a/src/interp/functor.boot b/src/interp/functor.boot index f8a2ff11..20ed8c36 100644 --- a/src/interp/functor.boot +++ b/src/interp/functor.boot @@ -33,7 +33,7 @@ import lisplib -import interop +import nrunfast import category namespace BOOT @@ -60,11 +60,6 @@ CategoryPrint(D,$e) == PRETTYPRINT u --% Domain printing -keyItem a == - isDomain a => CDAR domainRef(a,4) - a - --The item that domain checks on - --Global strategy here is to maintain a list of substitutions -- ( in $Sublis), of vectors and the names that they have, -- which may be either local names ('View1') or global names ('Where1') @@ -78,7 +73,7 @@ DomainPrint(D,brief) == $WhereCounter: local := 1 env:= $e or $EmptyEnvironment --in case we are called from top level categoryObject? D => CategoryPrint(D,env) - $Sublis:= [[keyItem D,:'original]] + $Sublis:= [[D,:'original]] SAY '"-----------------------------------------------------------------------" DomainPrint1(D,nil,env) while ($WhereList) repeat @@ -91,7 +86,6 @@ DomainPrint(D,brief) == SAY '"-----------------------------------------------------------------------" DomainPrint1(D,brief,$e) == - vector? D and not isDomain D => PacPrint D if vector? D then D := D.4 --if we were passed a vector, go to the domain Sublis:= @@ -110,12 +104,12 @@ DomainPrint1(D,brief,$e) == uu.5 := vv for j in 0..maxIndex vv repeat if vector? vv.j then - l := ASSQ(keyItem vv.j,Sublis) + l := ASSQ(vv.j,Sublis) if l then name:= rest l else name := DPname() - Sublis := [[keyItem vv.j,:name],:Sublis] + Sublis := [[vv.j,:name],:Sublis] $Sublis := [first Sublis,:$Sublis] $WhereList := [[name,:vv.j],:$WhereList] vv.j := name @@ -125,13 +119,13 @@ DomainPrint1(D,brief,$e) == uu.i := DomainPrintSubst(uu.i,Sublis) if vector? uu.i then name := DPname() - Sublis := [[keyItem uu.i,:name],:Sublis] + Sublis := [[uu.i,:name],:Sublis] $Sublis := [first Sublis,:$Sublis] $WhereList := [[name,:uu.i],:$WhereList] uu.i := name if uu.i is [.,:v] and vector? v then name := DPname() - Sublis := [[keyItem v,:name],:Sublis] + Sublis := [[v,:name],:Sublis] $Sublis := [first Sublis,:$Sublis] $WhereList := [[name,:v],:$WhereList] uu.i := [first uu.i,:name] @@ -147,22 +141,22 @@ PacPrint v == vv := copyVector v for j in 0..maxIndex vv repeat if vector? vv.j then - l := ASSQ(keyItem vv.j,Sublis) + l := ASSQ(vv.j,Sublis) if l then name := rest l else name := DPname() - Sublis := [[keyItem vv.j,:name],:Sublis] + Sublis := [[vv.j,:name],:Sublis] $Sublis := [first Sublis,:$Sublis] $WhereList := [[name,:vv.j],:$WhereList] vv.j := name if cons? vv.j and vector?(u:=rest vv.j) then - l := ASSQ(keyItem u,Sublis) + l := ASSQ(u,Sublis) if l then name := rest l else name := DPname() - Sublis := [[keyItem u,:name],:Sublis] + Sublis := [[u,:name],:Sublis] $Sublis := [first Sublis,:$Sublis] $WhereList := [[name,:u],:$WhereList] vv.j.rest := name @@ -176,7 +170,7 @@ DomainPrintSubst(item,Sublis) == [c1,:c2] l := ASSQ(item,Sublis) l => rest l - l := ASSQ(keyItem item,Sublis) + l := ASSQ(item,Sublis) l => rest l item diff --git a/src/interp/g-util.boot b/src/interp/g-util.boot index 2efeff70..321f8b9d 100644 --- a/src/interp/g-util.boot +++ b/src/interp/g-util.boot @@ -797,10 +797,6 @@ intern x == makeSymbol x x -isDomain a == - cons? a and vector? first a and - member(first a.0, $domainTypeTokens) - -- variables used by browser $htHash := MAKE_-HASH_-TABLE() diff --git a/src/interp/hashcode.boot b/src/interp/hashcode.boot deleted file mode 100644 index c88c326f..00000000 --- a/src/interp/hashcode.boot +++ /dev/null @@ -1,115 +0,0 @@ --- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd. --- All rights reserved. --- Copyright (C) 2007-2008, Gabriel Dos Reis. --- All rights reserved. --- --- Redistribution and use in source and binary forms, with or without --- modification, are permitted provided that the following conditions are --- met: --- --- - Redistributions of source code must retain the above copyright --- notice, this list of conditions and the following disclaimer. --- --- - Redistributions in binary form must reproduce the above copyright --- notice, this list of conditions and the following disclaimer in --- the documentation and/or other materials provided with the --- distribution. --- --- - Neither the name of The Numerical ALgorithms Group Ltd. nor the --- names of its contributors may be used to endorse or promote products --- derived from this software without specific prior written permission. --- --- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS --- IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED --- TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A --- PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER --- OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, --- EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, --- PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR --- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF --- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING --- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS --- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - - -import g_-util -namespace BOOT - -$DomainsWithoutLisplibs == - '(CAPSULE Union Record SubDomain Mapping Enumeration Mode) - - --- Type hasher for old compiler style type names which produces a hash code --- compatible with the asharp compiler. Takes a hard error if the type --- is parameterized, but has no constructor modemap. -getDomainHash dom == SPADCALL(rest dom, (first dom).4) - -hashType(type, percentHash) == - symbol? type => - type = '$ => percentHash - type = "%" => percentHash - hashString symbolName type - string? type => hashCombine(hashString type, - hashString('"Enumeration")) - type is ['QUOTE, val] => hashType(val, percentHash) - type is [dom] => hashString symbolName dom - type is ['_:, ., type2] => hashType(type2, percentHash) - isDomain type => getDomainHash type - [op, :args] := type - hash := hashString symbolName op - op is 'Mapping => - hash := hashString '"->" - [retType, :mapArgs] := args - for arg in mapArgs repeat - hash := hashCombine(hashType(arg, percentHash), hash) - retCode := hashType(retType, percentHash) - scalarEq?(retCode, $VoidHash) => hash - hashCombine(retCode, hash) - op is 'Enumeration => - for arg in args repeat - hash := hashCombine(hashString(symbolName arg), hash) - hash - symbolMember?(op,$DomainsWithoutLisplibs) => - for arg in args repeat - hash := hashCombine(hashType(arg, percentHash), hash) - hash - - cmm := getConstructorModemap(op).mmSource - cosig := rest getDualSignatureFromDB op - for arg in args for c in cosig for ct in cmm repeat - if c then - hash := hashCombine(hashType(arg, percentHash), hash) - else - hash := hashCombine(7, hash) --- !!! If/when asharp hashes values using their type, use instead --- ctt := applySubst(pairList($FormalMapVariableList,args),ct) --- hash := hashCombine(hashType(ctt, percentHash), hash) - - - hash - -$hashModulus := 1073741789 -- largest 30-bit prime - --- Produce a 30-bit hash code. This function must produce the same codes --- as the asharp string hasher in src/strops.c -hashString str == - h := 0 - for i in 0..#str-1 repeat - j := codePoint char str.i - h := LOGXOR(h, ASH(h, 8)) - h := h + j + 200041 - h := LOGAND(h, 1073741823) -- 0x3FFFFFFF - REM(h, $hashModulus) - --- Combine two hash codes to make a new one. Must be the same as in --- the hashCombine function in aslib/runtime.as in asharp. -hashCombine(hash1, hash2) == - MOD(ASH(LOGAND(hash2, 16777215), 6) + hash1, $hashModulus) - - -$VoidHash := hashString '"Void" - - --- following two lines correct bad coSig properties due to SubsetCategory ---putConstructorProperty('LocalAlgebra,'coSig,'(NIL T T T)) ---putConstructorProperty('Localize,'coSig,'(NIL T T T)) diff --git a/src/interp/interop.boot b/src/interp/interop.boot deleted file mode 100644 index c9c0f67d..00000000 --- a/src/interp/interop.boot +++ /dev/null @@ -1,669 +0,0 @@ --- Copyright (c) 1991-2002, The Numerical Algorithms Group Ltd. --- All rights reserved. --- Copyright (C) 2007-2011, Gabriel Dos Reis. --- All rights reserved. --- --- Redistribution and use in source and binary forms, with or without --- modification, are permitted provided that the following conditions are --- met: --- --- - Redistributions of source code must retain the above copyright --- notice, this list of conditions and the following disclaimer. --- --- - Redistributions in binary form must reproduce the above copyright --- notice, this list of conditions and the following disclaimer in --- the documentation and/or other materials provided with the --- distribution. --- --- - Neither the name of The Numerical Algorithms Group Ltd. nor the --- names of its contributors may be used to endorse or promote products --- derived from this software without specific prior written permission. --- --- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS --- IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED --- TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A --- PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER --- OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, --- EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, --- PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR --- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF --- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING --- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS --- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - - -import c_-util -import hashcode -namespace BOOT - --- note domainObjects are now (dispatchVector hashCode . domainVector) --- lazy oldAxiomDomainObjects are (dispatchVector hashCode (Call form) . backptr), --- pre oldAxiomCategory is (dispatchVector . (cat form)) --- oldAxiomCategory objects are (dispatchVector . ( (cat form) hash defaultpack parentlist)) - -hashCode? x == integer? x - -$domainTypeTokens == ['lazyOldAxiomDomain, 'oldAxiomDomain, 'oldAxiomPreCategory, - 'oldAxiomCategory, 0] - --- The name game. --- The compiler produces names that are of the form: --- a) cons(0, <string>) --- b) cons(1, type-name, arg-names...) --- c) cons(2, arg-names...) --- d) cons(3, value) --- NB: (c) is for tuple-ish constructors, --- and (d) is for dependent types. - -DNameStringID == 0 -DNameApplyID == 1 -DNameTupleID == 2 -DNameOtherID == 3 - -DNameToSExpr1 dname == - null dname => error "unexpected domain name" - first dname = DNameStringID => - makeSymbol(CompStrToString rest dname) - name0 := DNameToSExpr1 second dname - args := rest rest dname - name0 is '_-_> => - froms := first args - froms := [DNameToSExpr x for x in rest froms] - ret := second args -- a tuple - ret := DNameToSExpr second ret -- contents - ['Mapping,:[ret,:froms]] - name0 is 'Union or name0 is 'Record => - sxs := [DNameToSExpr x for x in rest first args] - [name0,:sxs] - name0 is 'Enumeration => - [name0,:[DNameFixEnum x for x in rest first args]] - [name0,:[DNameToSExpr x for x in args]] - -DNameToSExpr dname == - first dname = DNameOtherID => - rest dname - sx := DNameToSExpr1 dname - cons? sx => sx - [sx] - -DNameFixEnum arg == CompStrToString rest arg - -SExprToDName(sexpr, cosigVal) == - -- is it a non-type valued object? - not cosigVal => [DNameOtherID, :sexpr] - if first sexpr is '_: then sexpr := third sexpr - first sexpr is 'Mapping => - args := [ SExprToDName(sx,true) for sx in rest sexpr] - [DNameApplyID, - [DNameStringID,: StringToCompStr '"->"], - [DNameTupleID, : rest args], - [DNameTupleID, first args]] - name0 := [DNameStringID, : StringToCompStr symbolName first sexpr] - first sexpr is 'Union or first sexpr is 'Record => - [DNameApplyID, name0, - [DNameTupleID,: [ SExprToDName(sx,true) for sx in rest sexpr]]] - newCosig := rest getDualSignatureFromDB first sexpr - [DNameApplyID, name0, - :[SExprToDName(x,f) for x in rest sexpr for f in newCosig]] - --- local garbage because Compiler strings are null terminated -StringToCompStr(str) == - strconc(str, charString abstractChar 0) - -CompStrToString(str) == - subString(str, 0, #str - 1) --- local garbage ends - -runOldAxiomFunctor(:allArgs) == - [:args,env] := allArgs - getConstructorKindFromDB env is "category" => - [$oldAxiomPreCategoryDispatch,: [env, :args]] - dom:=apply(env, args) - makeOldAxiomDispatchDomain dom - -makeLazyOldAxiomDispatchDomain domform == - attribute? domform => - [$attributeDispatch, domform, hashString(symbolName domform)] - getConstructorKindFromDB opOf domform is "category" => - [$oldAxiomPreCategoryDispatch,: domform] - dd := [$lazyOldAxiomDomainDispatch, hashTypeForm(domform,0), domform] - append!(dd,dd) -- installs back pointer to head of domain. - dd - -makeOldAxiomDispatchDomain dom == - cons? dom => dom - [$oldAxiomDomainDispatch,hashTypeForm(dom.0,0),:dom] - -closeOldAxiomFunctor(name) == - [function runOldAxiomFunctor,:symbolFunction name] - -lazyOldAxiomDomainLookupExport(domenv, self, op, sig, box, skipdefaults, env) == - dom := instantiate domenv - SPADCALL(rest dom, self, op, sig, box, skipdefaults, first dom.3) - -lazyOldAxiomDomainHashCode(domenv, env) == first domenv - -lazyOldAxiomDomainDevaluate(domenv, env) == - dom := instantiate domenv - SPADCALL(rest dom, first dom.1) - -lazyOldAxiomAddChild(domenv, kid, env) == - [$lazyOldAxiomDomainDispatch,:domenv] - -$lazyOldAxiomDomainDispatch := - VECTOR('lazyOldAxiomDomain, - [function lazyOldAxiomDomainDevaluate], - [nil], - [function lazyOldAxiomDomainLookupExport], - [function lazyOldAxiomDomainHashCode], - [function lazyOldAxiomAddChild]) - --- old Axiom pre category objects are just (dispatch . catform) --- where catform is ('categoryname,: evaluated args) --- old Axiom category objects are (dispatch . [catform, hashcode, defaulting package, parent vector, dom]) -oldAxiomPreCategoryBuild(catform, dom, env) == - pack := oldAxiomCategoryDefaultPackage(catform, dom) - [$oldAxiomCategoryDispatch, - :[catform, hashTypeForm(catform,0), pack, oldAxiomPreCategoryParents(catform,dom), dom]] -oldAxiomPreCategoryHashCode(catform, env) == hashTypeForm(catform,0) -oldAxiomCategoryDefaultPackage(catform, dom) == - hasDefaultPackage opOf catform - -oldAxiomPreCategoryDevaluate([op,:args], env) == - SExprToDName([op,:devaluateList args], true) - -$oldAxiomPreCategoryDispatch := - VECTOR('oldAxiomPreCategory, - [function oldAxiomPreCategoryDevaluate], - [nil], - [nil], - [function oldAxiomPreCategoryHashCode], - [function oldAxiomPreCategoryBuild], - [nil]) - -oldAxiomCategoryDevaluate([[op,:args],:.], env) == - SExprToDName([op,:devaluateList args], true) - -oldAxiomPreCategoryParents(catform,dom) == - vars := ["$",:rest getConstructorFormFromDB opOf catform] - vals := [dom,:rest catform] - -- parents := getConstructorParentsFromDB opOf catform - parents := parentsOf opOf catform - PROGV(vars, vals, - vector - [eval quoteCatOp cat for [cat,:pred] in parents | eval pred]) - -quoteCatOp cat == - cat isnt [.,:.] => MKQ cat - ['LIST, MKQ first cat,: rest cat] - - -oldAxiomCategoryLookupExport(catenv, self, op, sig, box, env) == - [catform,hash, pack,:.] := catenv - opIsHasCat op => if scalarEq?(sig, hash) then [self] else nil - null(pack) => nil - if not vector? pack then - pack:=apply(pack, [self, :rest catform]) - catenv.rest.rest.first := pack - fun := basicLookup(op, sig, pack, self) => [fun] - nil - -oldAxiomCategoryParentCount([.,.,.,parents,.], env) == # parents -oldAxiomCategoryNthParent([.,.,.,parvec,dom], n, env) == - catform := parvec.(n-1) - VECTORP KAR catform => catform - newcat := oldAxiomPreCategoryBuild(catform,dom,nil) - parvec.(n-1) := newcat - newcat - -oldAxiomCategoryBuild([catform,:.], dom, env) == - oldAxiomPreCategoryBuild(catform,dom, env) -oldAxiomCategoryHashCode([.,hash,:.], env) == hash - -$oldAxiomCategoryDispatch := - VECTOR('oldAxiomCategory, - [function oldAxiomCategoryDevaluate], - [nil], - [function oldAxiomCategoryLookupExport], - [function oldAxiomCategoryHashCode], - [function oldAxiomCategoryBuild], -- builder ?? - [function oldAxiomCategoryParentCount], - [function oldAxiomCategoryNthParent]) -- 1 indexed - -attributeDevaluate(attrObj, env) == - [name, hash] := attrObj - StringToCompStr symbolName name - -attributeLookupExport(attrObj, self, op, sig, box, env) == - [name, hash] := attrObj - opIsHasCat op => if scalarEq?(hash, sig) then [self] else nil - -attributeHashCode(attrObj, env) == - [name, hash] := attrObj - hash - -attributeCategoryBuild(attrObj, dom, env) == - [name, hash] := attrObj - [$attributeDispatch, name, hash] - -attributeCategoryParentCount(attrObj, env) == 0 - -attributeNthParent(attrObj, env) == nil - -$attributeDispatch := - VECTOR('attribute, - [function attributeDevaluate], - [nil], - [function attributeLookupExport], - [function attributeHashCode], - [function attributeCategoryBuild], -- builder ?? - [function attributeCategoryParentCount], - [function attributeNthParent]) -- 1 indexed - - ---======================================================================= --- Generate Category Level Alist ---======================================================================= -orderCatAnc x == - reverse! ASSOCLEFT SORTBY(function rest,rest depthAssoc x) - -depthAssocList u == - u := removeSymbol(u,'DomainSubstitutionMacro) --hack by RDJ 8/90 - removeDuplicates ("append"/[depthAssoc(y) for y in u]) - -depthAssoc x == - y := tableValue($depthAssocCache,x) => y - x is ['Join,:u] or (u := getCatAncestors x) => - v := depthAssocList u - tableValue($depthAssocCache,x) := [[x,:n],:v] - where n() == 1 + "MAX"/[rest y for y in v] - tableValue($depthAssocCache,x) := [[x,:0]] - -getCatAncestors x == [CAAR y for y in parentsOf opOf x] - -listOfEntries form == - form isnt [.,:.] => form - form is [op,:l] => - op is 'Join => "append"/[listOfEntries x for x in l] - op is 'CATEGORY => listOfCategoryEntries rest l - op is 'PROGN => listOfCategoryEntries l - op is 'ATTRIBUTE and first l is [f,:.] and constructor? f => [first l] - op in '(ATTRIBUTE SIGNATURE) => nil - [form] - categoryFormatError() - -listOfCategoryEntries l == - null l => nil - l is [[op,:u],:v] => - firstItemList:= - op is 'ATTRIBUTE and first u is [f,:.] and constructor? f => - [first u] - op in '(ATTRIBUTE SIGNATURE) => nil - op is 'IF and u is [pred,conseq,alternate] => - listOfCategoryEntriesIf(pred,conseq,alternate) - categoryFormatError() - [:firstItemList,:listOfCategoryEntries v] - l is ['PROGN,:l] => listOfCategoryEntries l - l is '(NIL) => nil - sayBrightly '"unexpected category format encountered:" - pp l - -listOfCategoryEntriesIf(pred,conseq,alternate) == - alternate in '(%noBranch NIL) => - conseq is ['IF,p,c,a] => listOfCategoryEntriesIf(makePrefixForm([pred,p],'AND),c,a) - [fn for x in listOfEntries conseq] where fn() == - x is ['IF,a,b] => ['IF,makePrefixForm([pred,a],'AND),b] - ['IF,pred,x] - notPred := makePrefixForm(pred,'NOT) - conseq is ['IF,p,c,a] => - listOfCategoryEntriesIf(makePrefixForm([notPred,p],'AND),c,a) - [gn for x in listOfEntries conseq] where gn() == - x is ['IF,a,b] => ['IF,makePrefixForm([notPred,a],'AND),b] - ['IF,notPred,x] - -orderedDefaults(conform,domform) == - $depthAssocCache : local := hashTable 'EQ - conList := [x for x in orderCatAnc (op := opOf conform) | hasDefaultPackage op] - acc := nil - ancestors := ancestorsOf(conform,domform) - for x in conList repeat - for y in ancestors | x = CAAR y repeat acc := [y,:acc] - reverse! acc - -instantiate domenv == - -- following is a patch for a bug in runtime.as - -- has a lazy dispatch vector with an instantiated domenv - VECTORP rest domenv => [$oldAxiomDomainDispatch ,: domenv] - callForm := second domenv - oldDom := CDDR domenv - [functor,:args] := callForm --- if null(fn := property(functor,'instantiate)) then --- ofn := symbolFunction functor --- loadFunctor functor --- fn := symbolFunction functor --- symbolFunction(functor) := ofn --- proprty(functor, 'instantiate) := fn --- domvec := apply(fn, args) - domvec := apply(functor, args) - oldDom.first := $oldAxiomDomainDispatch - oldDom.rest := [second oldDom,: domvec] - oldDom - -hashTypeForm([fn,: args], percentHash) == - hashType([fn,:devaluateList args], percentHash) - -$hashOp1 == hashString '"1" -$hashOp0 == hashString '"0" -$hashOpApply == hashString '"apply" -$hashOpSet == hashString '"set!" -$hashSeg == hashString '".." -$hashPercent == hashString '"%" - -oldAxiomDomainLookupExport _ - (domenv, self, op, sig, box, skipdefaults, env) == - domainVec := rest domenv - if hashCode? op then - scalarEq?(op, $hashOp1) => op := 'One - scalarEq?(op, $hashOp0) => op := 'Zero - scalarEq?(op, $hashOpApply) => op := 'elt - scalarEq?(op, $hashOpSet) => op := 'setelt - scalarEq?(op, $hashSeg) => op := 'SEGMENT - constant := nil - if hashCode? sig and self and scalarEq?(sig, getDomainHash self) then - sig := '($) - constant := true - val := - skipdefaults => - oldCompLookupNoDefaults(op, sig, domainVec, self) - oldCompLookup(op, sig, domainVec, self) - null val => val - if constant then val := SPADCALL val - box.first := val - box - -oldAxiomDomainHashCode(domenv, env) == first domenv - -oldAxiomDomainHasCategory(domenv, cat, env) == - HasAttribute(domvec := rest domenv, cat) or - HasCategory(domvec, devaluate cat) - -oldAxiomDomainDevaluate(domenv, env) == - SExprToDName(rest domenv.0, 'T) - -oldAxiomAddChild(domenv, child, env) == [$oldAxiomDomainDispatch,:domenv] - -$oldAxiomDomainDispatch := - VECTOR('oldAxiomDomain, - [function oldAxiomDomainDevaluate], - [nil], - [function oldAxiomDomainLookupExport], - [function oldAxiomDomainHashCode], - [function oldAxiomAddChild]) - -basicLookupCheckDefaults(op,sig,domain,dollar) == - box := [nil] - not vector?(dispatch := first dollar) => error "bad domain format" - lookupFun := dispatch.3 - dispatch.0 = 0 => -- new compiler domain object - hashPercent := - vector? dollar => hashType(dollar.0,0) - hashType(dollar,0) - - hashSig := - hashCode? sig => sig - hashType( ['Mapping,:sig], hashPercent) - - if symbol? op then op := hashString symbolName op - first SPADCALL(rest dollar, dollar, op, hashSig, box, not $lookupDefaults, lookupFun) - first SPADCALL(rest dollar, dollar, op, sig, box, not $lookupDefaults, lookupFun) - -$hasCatOpHash == hashString '"%%" -opIsHasCat op == - hashCode? op => scalarEq?(op, $hasCatOpHash) - op = "%%" - --- has cat questions lookup up twice if false --- replace with following ? --- not(opIsHasCat op) and --- (u := lookupInDomainVector(op,sig,domvec,domvec)) => u - -oldCompLookup(op, sig, domvec, dollar) == - $lookupDefaults: local := false - u := lookupInDomainVector(op,sig,domvec,dollar) => u - $lookupDefaults := true - lookupInDomainVector(op,sig,domvec,dollar) - -oldCompLookupNoDefaults(op, sig, domvec, dollar) == - $lookupDefaults: local := false - lookupInDomainVector(op,sig,domvec,dollar) - -hashNewLookupInTable(op,sig,dollar,[domain,opvec],flag) == - opIsHasCat op => - HasCategory(domain, sig) - if hashCode? op and scalarEq?(op, $hashOp1) then op := 'One - if hashCode? op and scalarEq?(op, $hashOp0) then op := 'Zero - hashPercent := - vector? dollar => hashType(dollar.0,0) - hashType(dollar,0) - if hashCode? sig and scalarEq?(sig, hashPercent) then - sig := hashType('(Mapping $), hashPercent) - dollar = nil => systemError() - $lookupDefaults => - hashNewLookupInCategories(op,sig,domain,dollar) --lookup first in my cats - or newLookupInAddChain(op,sig,domain,dollar) - --fast path when called from newGoGet - success := false - if $monitorNewWorld then - sayLooking(concat('"---->",form2String devaluate domain, - '"----> searching op table for:","%l"," "),op,sig,dollar) - someMatch := false - numvec := getDomainByteVector domain - predvec := domainPredicates domain - max := maxIndex opvec - k := getOpCode(op,opvec,max) or return - flag => newLookupInAddChain(op,sig,domain,dollar) - nil - idxmax := maxIndex numvec - start := vectorRef(opvec,k) - finish := - max > k => vectorRef(opvec,k + 2) - idxmax - if finish > idxmax then systemError '"limit too large" - numArgs := if hashCode? sig then -1 else (#sig)-1 - success := nil - $isDefaultingPackage: local := - -- use special defaulting handler when dollar non-trivial - dollar ~= domain and defaultPackageForm? devaluate domain - while finish > start repeat - PROGN - i := start - numTableArgs := arrayRef(numvec,i) - predIndex := arrayRef(numvec,i := i + 1) - (predIndex ~= 0) and null testBitVector(predvec,predIndex) => nil - exportSig := - [newExpandTypeSlot(numvec.(i + j + 1), - dollar,domain) for j in 0..numTableArgs] - sig ~= hashType(['Mapping,: exportSig],hashPercent) => nil --signifies no match - loc := arrayRef(numvec,i + numTableArgs + 2) - loc = 1 => (someMatch := true) - loc = 0 => - start := start + numTableArgs + 4 - i := start + 2 - someMatch := true --mark so that if subsumption fails, look for original - subsumptionSig := - [newExpandTypeSlot(arrayRef(numvec,i + j), - dollar,domain) for j in 0..numTableArgs] - if $monitorNewWorld then - sayBrightly [formatOpSignature(op,sig),'"--?-->", - formatOpSignature(op,subsumptionSig)] - nil - slot := vectorRef(domain,loc) - cons? slot => - slot.op = 'newGoGet => someMatch:=true - --treat as if operation were not there - --if sameObject?(QCAR slot,'newGoGet) then - -- UNWIND_-PROTECT --break infinite recursion - -- ((SETELT(domain,loc,'skip); slot := replaceGoGetSlot rest slot), - -- if domain.loc = 'skip then domain.loc := slot) - return (success := slot) - slot is 'skip => --recursive call from above 'replaceGoGetSlot - return (success := newLookupInAddChain(op,sig,domain,dollar)) - systemError '"unexpected format" - start := start + numTableArgs + 4 - (success ~= 'failed) and success => - if $monitorNewWorld then - sayLooking1('"<----",uu) where uu() == - cons? success => [first success,:devaluate rest success] - success - success - subsumptionSig and (u:= basicLookup(op,subsumptionSig,domain,dollar)) => u - flag or someMatch => newLookupInAddChain(op,sig,domain,dollar) - nil - -hashNewLookupInCategories(op,sig,dom,dollar) == - slot4 := domainData dom - catVec := second slot4 - # catVec = 0 => nil --early exit if no categories - integer? KDR catVec.0 => - newLookupInCategories1(op,sig,dom,dollar) --old style - $lookupDefaults : local := false - if $monitorNewWorld then sayBrightly concat('"----->", - form2String devaluate dom,'"-----> searching default packages for ",op) - predvec := domainPredicates dom - packageVec := first slot4 ---the next three lines can go away with new category world - varList := ['$,:$FormalMapVariableList] - valueList := [dom,:[vectorRef(dom,5+i) for i in 1..(# rest dom.0)]] - valueList := [MKQ val for val in valueList] - nsig := MSUBST(dom.0,dollar.0,sig) - for i in 0..maxIndex packageVec | - (entry := packageVec.i) and entry ~= true repeat - package := - vector? entry => - if $monitorNewWorld then - sayLooking1('"already instantiated cat package",entry) - entry - ident? entry => - cat := catVec.i - packageForm := nil - if not property(entry,'LOADED) then loadLib entry - infovec := property(entry,'infovec) - success := - --vector? infovec => ----new world - true => ----new world - opvec := infovec.1 - max := maxIndex opvec - code := getOpCode(op,opvec,max) - null code => nil - byteVector := CDDDR infovec.3 - endPos := - code+2 > max => # byteVector - vectorRef(opvec,code+2) - --not nrunNumArgCheck(#sig.source,byteVector,opvec.code,endPos) => nil - --numOfArgs := byteVector.(opvec.code) - --numOfArgs ~= #sig.source => nil - packageForm := [entry,'$,:rest cat] - package := evalSlotDomain(packageForm,dom) - packageVec.i := package - package - ----old world - table := tableValue($Slot1DataBase,entry) or systemError nil - (u := LASSQ(op,table)) - and (v := or/[rest x for x in u]) => - packageForm := [entry,'$,:rest cat] - package := evalSlotDomain(packageForm,dom) - packageVec.i := package - package - nil - null success => - if $monitorNewWorld then - sayBrightlyNT '" not in: " - pp (packageForm and devaluate package or entry) - nil - if $monitorNewWorld then - sayLooking1('"candidate default package instantiated: ",success) - success - entry - null package => nil - if $monitorNewWorld then - sayLooking1('"Looking at instantiated package ",package) - res := basicLookup(op,sig,package,dollar) => - if $monitorNewWorld then - sayBrightly '"candidate default package succeeds" - return res - if $monitorNewWorld then - sayBrightly '"candidate fails -- continuing to search categories" - nil - -HasAttribute(domain,attrib) == - hashPercent := - vector? domain => hashType(domain.0,0) - hashType(domain,0) - isDomain domain => - integer?((first domain).0) => - -- following call to hashType was missing 2nd arg. - -- getDomainHash domain added on 4/01/94 by RSS - basicLookup("%%",hashType(attrib, hashPercent),domain,domain) - HasAttribute(CDDR domain, attrib) - integer? domainRef(domain,3) => newHasAttribute(domain,attrib) - (u := LASSOC(attrib,domain.2)) and lookupPred(first u,domain,domain) - -newHasAttribute(domain,attrib) == - hashPercent := - vector? domain => hashType(domain.0,0) - hashType(domain,0) - predIndex := - hashCode? attrib => - -- following call to hashType was missing 2nd arg. - -- hashPercent added by PAB 15/4/94 - or/[x for x in domain.2 | attrib = hashType(first x, hashPercent)] - LASSOC(attrib,domain.2) - predIndex => - predIndex = 0 => true - predvec := domainPredicates domain - testBitVector(predvec,predIndex) - false - -newHasCategory(domain,catform) == - catform = $Type or catform = $Category => true - catform is ["Join",:cats] => - and/[newHasCategory(domain,cat) for cat in cats] - slot4 := domain.4 - auxvec := first slot4 - catvec := second slot4 - $isDefaultingPackage: local := defaultPackageForm? devaluate domain - #catvec > 0 and integer? KDR catvec.0 => --old style - predIndex := lazyMatchAssocV1(catform,catvec,domain) - null predIndex => false - predIndex = 0 => true - predvec := domainPredicates domain - testBitVector(predvec,predIndex) - lazyMatchAssocV(catform,auxvec,catvec,domain) --new style - -getCatForm(catvec, index, domain) == - integer?(form := vectorRef(catvec,index)) => domain.form - form - -HasSignature(domain,[op,sig]) == - compiledLookup(op,sig,domain) - -HasCategory(domain,catform') == - catform' is ['SIGNATURE,:f] => HasSignature(domain,f) - catform' is ['ATTRIBUTE,f] => HasAttribute(domain,f) - isDomain domain => - integer?((first domain).0) => - catform' := devaluate catform' - basicLookup("%%",catform',domain,domain) - HasCategory(CDDR domain, catform') - catform:= devaluate catform' - integer? domainRef(domain,3) => newHasCategory(domain,catform) - domain0 := canonicalForm domain -- handles old style domains, Record, Union etc. - slot4 := domainData domain - catlist := slot4.1 - member(catform,catlist) or - opOf(catform) in '(Object Type) or --temporary hack - or/[compareSigEqual(catform,cat,domain0,domain) for cat in catlist] - -domainEqual(a,b) == - vector? a and vector? b and a.0 = b.0 - diff --git a/src/interp/nrunfast.boot b/src/interp/nrunfast.boot index 1a881336..eba02971 100644 --- a/src/interp/nrunfast.boot +++ b/src/interp/nrunfast.boot @@ -602,6 +602,51 @@ resolveNiladicConstructors form == --======================================================= -- HasCategory/Attribute --======================================================= +domainEqual(a,b) == + vector? a and vector? b and a.0 = b.0 + +HasAttribute(domain,attrib) == + integer? domainRef(domain,3) => newHasAttribute(domain,attrib) + (u := LASSOC(attrib,domain.2)) and lookupPred(first u,domain,domain) + +newHasAttribute(domain,attrib) == + predIndex := LASSOC(attrib,domain.2) => + predIndex = 0 => true + predvec := domainPredicates domain + testBitVector(predvec,predIndex) + false + +newHasCategory(domain,catform) == + catform = $Type or catform = $Category => true + catform is ["Join",:cats] => + and/[newHasCategory(domain,cat) for cat in cats] + slot4 := domain.4 + auxvec := first slot4 + catvec := second slot4 + $isDefaultingPackage: local := defaultPackageForm? devaluate domain + #catvec > 0 and integer? KDR catvec.0 => --old style + predIndex := lazyMatchAssocV1(catform,catvec,domain) + null predIndex => false + predIndex = 0 => true + predvec := domainPredicates domain + testBitVector(predvec,predIndex) + lazyMatchAssocV(catform,auxvec,catvec,domain) --new style + +HasSignature(domain,[op,sig]) == + compiledLookup(op,sig,domain) + +HasCategory(domain,catform') == + catform' is ['SIGNATURE,:f] => HasSignature(domain,f) + catform' is ['ATTRIBUTE,f] => HasAttribute(domain,f) + catform:= devaluate catform' + integer? domainRef(domain,3) => newHasCategory(domain,catform) + domain0 := canonicalForm domain -- handles old style domains, Record, Union etc. + slot4 := domainData domain + catlist := slot4.1 + member(catform,catlist) or + opOf(catform) in '(Object Type) or --temporary hack + or/[compareSigEqual(catform,cat,domain0,domain) for cat in catlist] + -- PLEASE NOTE: This function has the rather charming side-effect that -- e.g. it works if domform is an Aldor Category. This is being used -- by extendscategoryForm in c-util to allow Aldor domains to be used diff --git a/src/interp/trace.boot b/src/interp/trace.boot index 1d503bcf..ab1890b5 100644 --- a/src/interp/trace.boot +++ b/src/interp/trace.boot @@ -762,24 +762,9 @@ traceReply() == sayBrightly flowSegmentedMsg(displayList,$LINELENGTH,6) addTraceItem d == - isDomain d => $domains:= [devaluate d,:$domains] isDomainOrPackage d => $packages:= [devaluate d,:$packages] constructor? d => $constructors:=[d,:$constructors] -_?t() == - null _/TRACENAMES => sayMSG bright '"nothing is traced" - for x in _/TRACENAMES | x isnt [.,:.] and not IS__GENVAR x repeat - if llm:= get(x,'localModemap,$InteractiveFrame) then - x:= ([CADAR llm]) - sayMSG ['"Function",:bright rassocSub(x,$mapSubNameAlist),'"traced"] - for x in _/TRACENAMES | x is [d,:l] and isDomainOrPackage d repeat - suffix:= - isDomain d => '"domain" - '"package" - sayBrightly ['" Functions traced in ",suffix,'"%b",devaluate d,'"%d",":"] - for x in orderBySlotNumber l repeat reportSpadTrace(" ",take(4,x)) - TERPRI() - tracelet(fn,vars) == if GENSYMP fn and stupidIsSpadFunction eval fn then fn := eval fn |