diff options
Diffstat (limited to 'src/interp')
-rw-r--r-- | src/interp/clam.boot | 6 | ||||
-rw-r--r-- | src/interp/database.boot | 7 | ||||
-rw-r--r-- | src/interp/define.boot | 21 | ||||
-rw-r--r-- | src/interp/lisplib.boot | 2 | ||||
-rw-r--r-- | src/interp/nruncomp.boot | 4 |
5 files changed, 10 insertions, 30 deletions
diff --git a/src/interp/clam.boot b/src/interp/clam.boot index cdfb6e73..14a3d04b 100644 --- a/src/interp/clam.boot +++ b/src/interp/clam.boot @@ -513,12 +513,6 @@ numberOfEmptySlots cache== if CAAR x='$failed then count:= count+1 count -addToSlam([name,:argnames],shell) == - $mutableDomain => return nil - null argnames => addToConstructorCache(name,nil,shell) - args:= ['LIST,:[mkDevaluate a for a in argnames]] - addToConstructorCache(name,args,shell) - addToConstructorCache(op,args,value) == ['haddProp,'$ConstructorCache,MKQ op,args,['CONS,1,value]] diff --git a/src/interp/database.boot b/src/interp/database.boot index 3ba37506..06030e16 100644 --- a/src/interp/database.boot +++ b/src/interp/database.boot @@ -829,10 +829,3 @@ loadDBIfnecessary db == property(ctor,'LOADED) => db loadLib ctor or return nil constructorDB ctor - -++ Returns true if instantiations of the constructor -++ defined by `db' should not be cached. -dbMutable? db == - dbInstanceCache loadDBIfnecessary db = nil - - diff --git a/src/interp/define.boot b/src/interp/define.boot index 379d751f..048efb2f 100644 --- a/src/interp/define.boot +++ b/src/interp/define.boot @@ -51,13 +51,6 @@ module define where $newCompCompare := false -++ List of mutable domains. -$mutableDomains := nil - -++ True if the current constructor being compiled instantiates -++ mutable domains or packages. Default is `false'. -$mutableDomain := false - ++ when non nil, holds the declaration number of a function in a capsule. $suffix := nil @@ -991,6 +984,7 @@ compDefineCategory2(form,signature,specialCases,body,m,e, --Set in DomainSubstitutionFunction, used further down -- 1.1 augment e to add declaration $: <form> [$op,:argl] := $definition + dbInstanceCache(constructorDB $op) := true e:= addBinding("$",[['mode,:$definition]],e) -- 2. obtain signature @@ -1305,7 +1299,6 @@ compDefineFunctor(df,m,e,prefix,fal) == $domainShell: local := nil -- holds the category of the object being compiled $profileCompiler: local := true $profileAlist: local := nil - $mutableDomain: local := false $LISPLIB = nil => compDefineFunctor1(df,m,e,prefix,fal) compDefineLisplib(df,m,e,prefix,fal,'compDefineFunctor1) @@ -1333,10 +1326,8 @@ compDefineFunctor1(df is ['DEF,form,signature,nils,body], dbConstructorForm(constructorDB $op) := form $formalArgList:= [:argl,:$formalArgList] $pairlis: local := pairList(argl,$FormalMapVariableList) - $mutableDomain: local := - -- all defaulting packages should have caching turned off - isCategoryPackageName $op or symbolMember?($op,$mutableDomains) - --true if domain has mutable state + -- all defaulting packages should have caching turned off + dbInstanceCache(constructorDB $op) := not isCategoryPackageName $op signature':= [signature.target,:[getArgumentModeOrMoan(a,form,$e) for a in argl]] $functorForm := $form := [$op,:argl] @@ -1398,7 +1389,9 @@ compDefineFunctor1(df is ['DEF,form,signature,nils,body], [nil, ['Mapping, :signature'], originale] body':= T.expr - lamOrSlam:= if $mutableDomain then 'LAM else 'SPADSLAM + lamOrSlam := + dbInstanceCache constructorDB $op = nil => 'LAM + 'SPADSLAM fun:= compile applySubst($pairlis, [op',[lamOrSlam,argl,body']]) --The above statement stops substitutions gettting in one another's way operationAlist := applySubst($pairlis,$lisplibOperationAlist) @@ -2050,7 +2043,7 @@ compileConstructor1 (form:=[fn,[key,vl,:bodyl]]) == $clamList: local := nil lambdaOrSlam := getConstructorKindFromDB fn = "category" => 'SPADSLAM - $mutableDomain => 'LAMBDA + dbInstanceCache constructorDB fn = nil => 'LAMBDA $clamList:= [[fn,"$ConstructorCache",'domainEqualList,'count],:$clamList] 'LAMBDA diff --git a/src/interp/lisplib.boot b/src/interp/lisplib.boot index d448fd22..25b00464 100644 --- a/src/interp/lisplib.boot +++ b/src/interp/lisplib.boot @@ -573,7 +573,7 @@ finalizeLisplib(ctor,libName) == writeConstructorForm(ctor,form,$libFile) writeKind(ctor,kind,$libFile) writeConstructorModemap(ctor,removeZeroOne mm,$libFile) - if not $mutableDomains then + if dbInstanceCache constructorDB ctor then writeInstanceCache(ctor,$libFile) $lisplibCategory := $lisplibCategory or mm.mmTarget -- set to target of mm for package/domain constructors; diff --git a/src/interp/nruncomp.boot b/src/interp/nruncomp.boot index 8f0fff7d..6171d4eb 100644 --- a/src/interp/nruncomp.boot +++ b/src/interp/nruncomp.boot @@ -660,9 +660,9 @@ NRToptimizeHas u == u NRTaddToSlam([name,:argnames],shell) == - $mutableDomain => return nil + dbInstanceCache constructorDB name = nil => return nil null argnames => addToConstructorCache(name,nil,shell) - args:= ['%list,:ASSOCRIGHT $devaluateList] + args := ['%list,:ASSOCRIGHT $devaluateList] addToConstructorCache(name,args,shell) changeDirectoryInSlot1() == --called by buildFunctor |