From 3f5e42cc9a9db6ddbbb90d130826ad6dd3b7d770 Mon Sep 17 00:00:00 2001 From: dos-reis Date: Wed, 16 Nov 2011 13:20:39 +0000 Subject: * interp/category.boot (mkCategory): Tidy. (SigListUnion): Likewise. The last argument is not a vector buffer. (JoinInner): Use a vector buffer for scratch space to compute the initial principal ancestor. Simplify copy logic. * interp/g-util.boot (mkBuffer): New. (bufferData): New. (buffeLength): Likewise. (resizeBuffer): Likewise. (bufferToVector): Likwise. * lisp/core.lisp.in (mkVector): New. Export. --- src/interp/category.boot | 72 +++++++++++++++++++----------------------------- src/interp/g-util.boot | 32 +++++++++++++++++++++ 2 files changed, 60 insertions(+), 44 deletions(-) (limited to 'src/interp') diff --git a/src/interp/category.boot b/src/interp/category.boot index f6c2932d..8115f544 100644 --- a/src/interp/category.boot +++ b/src/interp/category.boot @@ -62,15 +62,15 @@ isCategoryForm(x,e) == ++ (as indicated by `domainOrPackage'), with signature list ++ designated by `sigList', attribute list designated by `attList', ++ used domains list designated by `domList', and a princical ancestor -++ category object designated by `PrincipalAncestor'. +++ category object designated by `principal'. mkCategory: (%ConstructorKind,%List %Sig,%List %Form,%List %Instantiation, %Maybe %Shell) -> %Shell -mkCategory(domainOrPackage,sigList,attList,domList,PrincipalAncestor) == +mkCategory(domainOrPackage,sigList,attList,domList,principal) == NSigList := nil -- Unless extending a principal ancestor (from the end), start -- from the first free, unencumbered slot. count := - PrincipalAncestor = nil => $NRTbase - #PrincipalAncestor + principal = nil => $NRTbase + #principal sigList:= [if s is [sig,pred] then @@ -102,8 +102,8 @@ mkCategory(domainOrPackage,sigList,attList,domList,PrincipalAncestor) == [v] OldLocals:= nil -- Remove possible duplicate local domain caches. - if PrincipalAncestor then - for u in (OldLocals := categoryLocals PrincipalAncestor) repeat + if principal then + for u in (OldLocals := categoryLocals principal) repeat NewLocals := remove(NewLocals,first u) -- New local domains caches are hosted in slots at the end onward for u in NewLocals repeat @@ -115,12 +115,12 @@ mkCategory(domainOrPackage,sigList,attList,domList,PrincipalAncestor) == categoryExports(v) := sigList categoryAttributes(v) := attList categoryRef(v,3) := $Category - if PrincipalAncestor ~= nil then - for x in 6..#PrincipalAncestor-1 repeat - categoryRef(v,x) := PrincipalAncestor.x + if principal ~= nil then + for x in 6..#principal-1 repeat + categoryRef(v,x) := categoryRef(principal,x) categoryAssociatedTypes(v) := - [categoryPrincipals PrincipalAncestor, - categoryAncestors PrincipalAncestor, + [categoryPrincipals principal, + categoryAncestors principal, OldLocals] else categoryAssociatedTypes(v) := [nil,nil,OldLocals] @@ -185,7 +185,7 @@ SigListUnion(extra,original,principal) == -- We must pick up the previous implementation, if any --+ if ximplem is [[q,.,index]] and integer? index and (q="ELT" or q="CONST") - then principal . index:= e + then bufferRef(principal,index) := e original:= [e,:original] original @@ -392,18 +392,16 @@ filterConditionalCategories(l,e) == JoinInner(l,$e) == [CondList,uncondList] := filterConditionalCategories(l,$e) [principal,:l] := [:l,:uncondList] + principal := mkBuffer principal l' := [:CondList,:[[u,true] for u in l]] -- This is a list of all the categories that this extends -- conditionally or unconditionally - sigl := categoryExports principal - attl := categoryAttributes principal - globalDomains := categoryParameters principal - FundamentalAncestors := categoryAncestors principal - if principal.0 then - FundamentalAncestors := [[principal.0],:FundamentalAncestors] - -- we can not decide to extend the vector in multiple ways - -- this flag helps us detect this case - copied := false + sigl := categoryExports bufferData principal + attl := categoryAttributes bufferData principal + globalDomains := categoryParameters bufferData principal + FundamentalAncestors := categoryAncestors bufferData principal + if name := canonicalForm bufferData principal then + FundamentalAncestors := [[name],:FundamentalAncestors] -- this skips buggy code which discards needed categories for [b,condition] in FindFundAncs(l',$e) | bname := b.0 repeat CondAncestorP(bname,FundamentalAncestors,condition,$e) => nil @@ -431,28 +429,14 @@ JoinInner(l,$e) == if not listMember?(newentry,FundamentalAncestors) then FundamentalAncestors := [newentry,:FundamentalAncestors] else ancindex := nil - if not copied then - principal := copyVector principal - copied := true if ancindex then - principal.ancindex := bname + bufferRef(principal,ancindex) := bname reallynew := false if reallynew then - n := # principal + n := bufferLength principal FundamentalAncestors := [[b.0,condition,n],:FundamentalAncestors] - principal := LENGTHENVEC(principal,n+1) --- We need to copy the vector otherwise the FundamentalAncestors --- list will get stepped on while compiling "If R has ... " code --- Camm Maguire July 26, 2003 --- copied := true - copied := false - originalvector := false - principal.n := b.0 - if not copied then - principal := copyVector principal - -- It is important to copy the vector now, - -- in case SigListUnion alters it while - -- performing Operator Subsumption + resizeBuffer(principal,n + 1) + bufferRef(principal,n) := b.0 for b in l repeat sigl := SigListUnion([DropImplementations u for u in categoryExports b], sigl,principal) @@ -480,12 +464,12 @@ JoinInner(l,$e) == [sig,mkpf([oldpred,newpred],"and"),:implem] FundamentalAncestors := [x for x in FundamentalAncestors | rest x] --strip out the pointer to Principal Ancestor - c := categoryPrincipals principal - pName := principal.0 + c := categoryPrincipals bufferData principal + pName := canonicalForm bufferData principal if pName and not listMember?(pName,c) then c := [pName,:c] - categoryAssociatedTypes(principal) := - [c,FundamentalAncestors,categoryLocals principal] - mkCategory("domain",sigl,attl,globalDomains,principal) + categoryAssociatedTypes(bufferData principal) := + [c,FundamentalAncestors,categoryLocals bufferData principal] + mkCategory("domain",sigl,attl,globalDomains,bufferToVector principal) Join(:l) == e := diff --git a/src/interp/g-util.boot b/src/interp/g-util.boot index 178ec1ab..f4adb422 100644 --- a/src/interp/g-util.boot +++ b/src/interp/g-util.boot @@ -149,6 +149,38 @@ isSharpVarWithNum x == ok := digit? d => c := 10*c + DIG2FIX d if ok then c else nil + +mkBuffer v == + [copyVector v,:#v] + +macro bufferData buf == + first buf + +macro bufferLength buf == + rest buf + +macro bufferRef(buf,i) == + vectorRef(bufferData buf,i) + +resizeBuffer(buf,n) == + #bufferData buf >= n => + bufferLength(buf) := n + buf + v := mkVector(2 * n) + for i in 0..(bufferLength buf - 1) repeat + vectorRef(v,i) := vectorRef(bufferData buf,i) + bufferData(buf) := v + bufferLength(buf) := n + buf + +bufferToVector buf == + n := bufferLength buf + v := mkVector n + for i in 0..(n-1) repeat + vectorRef(v,i) := vectorRef(bufferData buf,i) + v + + --% Sub-domains information handlers ++ If `dom' is a subdomain, return its immediate super-domain. -- cgit v1.2.3