diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/ChangeLog | 9 | ||||
-rw-r--r-- | src/interp/c-util.boot | 10 | ||||
-rw-r--r-- | src/interp/define.boot | 18 |
3 files changed, 25 insertions, 12 deletions
diff --git a/src/ChangeLog b/src/ChangeLog index c6af32cc..96edf51f 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,12 @@ +2011-11-11 Gabriel Dos Reis <gdr@cs.tamu.edu> + + * interp/c-util.boot (dbByteList): New accessor macro. + * interp/define.boot ($byteVec): Remove. + (getInfovecCode): Do not bind it. + (makeGoGetSlot): Take DB as first parameter. Adjust caller. + Update dbByteList. + (NRTmakeCategoryAlist): Adjust. + 2011-11-10 Gabriel Dos Reis <gdr@cs.tamu.edu> * interp/compiler.boot (applyMapping): Emit special call for diff --git a/src/interp/c-util.boot b/src/interp/c-util.boot index 3480c03b..a5369444 100644 --- a/src/interp/c-util.boot +++ b/src/interp/c-util.boot @@ -135,12 +135,13 @@ macro domainData d == --% Constructor Compilation Data. --% Operational Semantics: --% structure CompilationData == ---% Record(formalSubst: Substitution,implicits: List Identifier) +--% Record(formalSubst: Substitution,implicits: List Identifier, +--% byteList: List SingleInteger) --% ++ Make a fresh compilation data structure. makeCompilationData() == - [nil,nil] + [nil,nil,nil] ++ Subsitution that replaces parameters with formals. macro dbFormalSubst db == @@ -156,6 +157,11 @@ dbParameters db == macro dbImplicitData db == second dbCompilerData db +++ Return the list of encoding bytes for a function during elaboration. +++ Transcient data. +macro dbByteList db == + third dbCompilerData db + ++ Return the existential substitution of `db'. dbQuerySubst db == x := dbImplicitData db => first x diff --git a/src/interp/define.boot b/src/interp/define.boot index 3212979b..d3c56105 100644 --- a/src/interp/define.boot +++ b/src/interp/define.boot @@ -75,7 +75,6 @@ $NRTattributeAlist := [] $NRTdeltaListComp := [] $signature := nil $byteAddress := nil -$byteVec := nil $sigAlist := [] $predAlist := [] $argumentConditionList := [] @@ -344,7 +343,6 @@ chaseInferences(pred,$e) == --======================================================================= ++ Called by compDefineFunctor1 to create infovec at compile time getInfovecCode(db,e) == - $byteVec: local := nil $byteAddress: local := 0 ['LIST, MKQ makeDomainTemplate db, @@ -365,18 +363,18 @@ makeDomainTemplate db == item = nil => nil domainRef(vec,index) := item isnt [.,:.] => item - cons? first item => makeGoGetSlot(item,index) + cons? first item => makeGoGetSlot(db,item,index) item - $byteVec := "append"/reverse! $byteVec + dbByteList(db) := "append"/reverse! dbByteList db vec -makeGoGetSlot(item,index) == +makeGoGetSlot(db,item,index) == --NOTES: creates byte vec strings for LATCH slots ---these parts of the $byteVec are created first; see also makeCompactDirect +--these parts of the dbByteList are created first; see also makeCompactDirect [sig,whereToGo,op,:flag] := item n := #sig - 1 newcode := [n,whereToGo,:makeCompactSigCode sig,index] - $byteVec := [newcode,:$byteVec] + dbByteList(db) := [newcode,:dbByteList db] curAddress := $byteAddress $byteAddress := $byteAddress + n + 4 [curAddress,:op] @@ -391,7 +389,7 @@ makeCompactDirect(db,u) == [nam,[addForm,:opList]] := u --pp opList d := [[op,y] for [op,:items] in opList | y := makeCompactDirect1(db,op,items)] - $byteVec := [:$byteVec,:"append"/reverse! $byteVecAcc] + dbByteList(db) := [:dbByteList db,:"append"/reverse! $byteVecAcc] vector("append"/d) makeCompactDirect1(db,op,items) == @@ -487,11 +485,11 @@ NRTmakeCategoryAlist(db,e) == predList := ASSOCRIGHT slot1 --is list of predicate indices maxPredList := "MAX"/predList catformvec := ASSOCLEFT slot1 - maxElement := "MAX"/$byteVec + maxElement := "MAX"/dbByteList db ['CONS, ['makeByteWordVec2,MAX(maxPredList,1),MKQ predList], ['CONS, MKQ vector slot0, ['CONS, MKQ vector [encodeCatform x for x in catformvec], - ['makeByteWordVec2,maxElement,MKQ $byteVec]]]] + ['makeByteWordVec2,maxElement,MKQ dbByteList db]]]] --NOTE: this is new form: old form satisfies vector? CDDR form encodeCatform x == |