aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/interp/c-util.boot25
-rw-r--r--src/interp/compiler.boot12
-rw-r--r--src/interp/define.boot37
3 files changed, 25 insertions, 49 deletions
diff --git a/src/interp/c-util.boot b/src/interp/c-util.boot
index 58706ec0..9e56bb12 100644
--- a/src/interp/c-util.boot
+++ b/src/interp/c-util.boot
@@ -1207,31 +1207,6 @@ old2NewModemaps x ==
x is [dcSig,[pred,:.],:.] => [dcSig,pred]
x
-traceUp() ==
- $x isnt [.,:.] => sayBrightly "$x is an atom"
- for y in rest $x repeat
- u:= comp(y,$EmptyMode,$f) =>
- sayBrightly [y,'" ==> mode",'"%b",u.mode,'"%d"]
- sayBrightly [y,'" does not compile"]
-
-traceDown() ==
- mmList:= getFormModemaps($x,$f) =>
- for mm in mmList repeat if u:= qModemap mm then return u
- sayBrightly "no modemaps for $x"
-
-qModemap mm ==
- sayBrightly ['"%b","modemap",'"%d",:formatModemap mm]
- [[dc,target,:sl],[pred,:.]]:= mm
- and/[qArg(a,m) for a in rest $x for m in sl] => target
- sayBrightly ['"%b","fails",'"%d",'"%l"]
-
-qArg(a,m) ==
- yesOrNo:=
- u:= comp(a,m,$f) => "yes"
- "no"
- sayBrightly [a," --> ",m,'"%b",yesOrNo,'"%d"]
- yesOrNo="yes"
-
displayProplist(x,alist) ==
sayBrightly ["properties of",'"%b",x,'"%d",":"]
fn alist where
diff --git a/src/interp/compiler.boot b/src/interp/compiler.boot
index 0ff039f3..2a3f413e 100644
--- a/src/interp/compiler.boot
+++ b/src/interp/compiler.boot
@@ -71,7 +71,7 @@ primitiveType: (%Maybe %Database,%Form,%Mode) -> %Mode
modeEqual: (%Form,%Form) -> %Boolean
hasUniqueCaseView: (%Form,%Mode,%Env) -> %Boolean
convertOrCroak: (%Triple,%Mode) -> %Maybe %Triple
-getFormModemaps: (%Form,%Env) -> %List %Modemap
+getFormModemaps: (%Maybe %Database,%Form,%Env) -> %List %Modemap
reshapeArgumentList: (%Form,%Sig) -> %Form
applyMapping: (%Form,%Mode,%Env,%List %Mode) -> %Maybe %Triple
@@ -525,14 +525,14 @@ compForm1(db,form is [op,:argl],m,e) ==
-- since addDomain refuses to add modemaps from Mapping
(domain is ['Mapping,:.]) and
(ans := compForm2(db,[op',:argl],m,e:= augModemapsFromDomain1(db,domain,domain,e),
- [x for x in getFormModemaps([op',:argl],e) | x.mmDC = domain])) => ans
+ [x for x in getFormModemaps(db,[op',:argl],e) | x.mmDC = domain])) => ans
ans := compForm2(db,[op',:argl],m,e:= addDomain(db,domain,e),
- [x for x in getFormModemaps([op',:argl],e) | x.mmDC = domain]) => ans
+ [x for x in getFormModemaps(db,[op',:argl],e) | x.mmDC = domain]) => ans
(op'="construct") and coerceable(domain,m,e) =>
(T:= comp([op',:argl],domain,e) or return nil; coerce(T,m))
nil
- T := compForm2(db,form,m,e,getFormModemaps(form,e)) => T
+ T := compForm2(db,form,m,e,getFormModemaps(db,form,e)) => T
--FIXME: remove next line when the parser is fixed.
form = $Zero or form = $One => nil
compToApply(op,argl,m,e)
@@ -634,9 +634,9 @@ compFormWithModemap(db,form,m,e,modemap) ==
++ of paramter types as arguments supplied to the form. A special
++ case is made for a modemap whose sole parameter type is a Tuple.
++ In that case, it matches any number of supplied arguments.
-getFormModemaps(form is [op,:argl],e) ==
+getFormModemaps(db,form is [op,:argl],e) ==
op is ["elt",domain,op1] and isDomainForm(domain,e) =>
- [x for x in getFormModemaps([op1,:argl],e) | x.mmDC = domain]
+ [x for x in getFormModemaps(db,[op1,:argl],e) | x.mmDC = domain]
op is [.,:.] => nil
modemapList := get(op,"modemap",e)
-- Within default implementations, modemaps cannot mention the
diff --git a/src/interp/define.boot b/src/interp/define.boot
index 63a5f31c..299d0304 100644
--- a/src/interp/define.boot
+++ b/src/interp/define.boot
@@ -717,7 +717,7 @@ clearCapsuleFunctionTable() ==
++ Note: for category packages, this list is nil.
$exports := nil
-noteExport(form,pred) ==
+noteExport(db,form,pred) ==
-- don't recheck category package exports; we just check
-- them when defining the category. Plus, we might actually
-- get indirect duplicates, which is OK.
@@ -2592,75 +2592,76 @@ DomainSubstitutionFunction(parameters,body) ==
++ Compile exported signature `opsig' under predicate `pred' in
++ environment `env'. The parameters `sigs' is a reference to a list
++ of signatures elaborated so far.
-compSignature(opsig,pred,env,sigs) ==
+compSignature(db,opsig,pred,env,sigs) ==
[op,:sig] := opsig
cons? op =>
for y in op repeat
- compSignature([y,:sig],pred,env,sigs)
+ compSignature(db,[y,:sig],pred,env,sigs)
op in '(per rep) =>
stackSemanticError(['"cannot export signature for", :bright op],nil)
nil
- noteExport(opsig,pred)
+ noteExport(db,opsig,pred)
deref(sigs) := [MKQ [opsig,pred],:deref sigs]
++ Subroutine of comCategory.
++ Elaborate a category-level item `x' under the predicates `predl'.
++ The parameters `sigs' and `atts' are references to list of
++ signatures and attributes elaborated so far.
-compCategoryItem(x,predl,env,sigs,atts) ==
+compCategoryItem(db,x,predl,env,sigs,atts) ==
x is nil => nil
--1. if x is a conditional expression, recurse; otherwise, form the predicate
x is ['%when,[p,e]] =>
predl':= [p,:predl]
e is ["PROGN",:l] =>
- for y in l repeat compCategoryItem(y,predl',env,sigs,atts)
- compCategoryItem(e,predl',env,sigs,atts)
+ for y in l repeat compCategoryItem(db,y,predl',env,sigs,atts)
+ compCategoryItem(db,e,predl',env,sigs,atts)
x is ["IF",a,b,c] =>
- a is ["not",p] => compCategoryItem(["IF",p,c,b],predl,env,sigs,atts)
+ a is ["not",p] => compCategoryItem(db,["IF",p,c,b],predl,env,sigs,atts)
a is ["and",p,q] =>
- compCategoryItem(["IF",p,["IF",q,b,c],copyTree c],predl,env,sigs,atts)
+ compCategoryItem(db,["IF",p,["IF",q,b,c],copyTree c],predl,env,sigs,atts)
a is ["or",p,q] =>
- compCategoryItem(["IF",p,b,["IF",q,copyTree b,c]],predl,env,sigs,atts)
+ compCategoryItem(db,["IF",p,b,["IF",q,copyTree b,c]],predl,env,sigs,atts)
predl':= [a,:predl]
if b~="%noBranch" then
b is ["PROGN",:l] =>
- for y in l repeat compCategoryItem(y,predl',env,sigs,atts)
- compCategoryItem(b,predl',env,sigs,atts)
+ for y in l repeat compCategoryItem(db,y,predl',env,sigs,atts)
+ compCategoryItem(db,b,predl',env,sigs,atts)
c="%noBranch" => nil
predl':= [["not",a],:predl]
c is ["PROGN",:l] =>
for y in l repeat
- compCategoryItem(y,predl',env,sigs,atts)
- compCategoryItem(c,predl',env,sigs,atts)
+ compCategoryItem(db,y,predl',env,sigs,atts)
+ compCategoryItem(db,c,predl',env,sigs,atts)
pred := (predl => MKPF(predl,"AND"); true)
--2. if attribute, push it and return
x is ["ATTRIBUTE",y] =>
-- Attribute 'nil' carries no semantics.
y = "nil" => nil
- noteExport(y,pred)
+ noteExport(db,y,pred)
deref(atts) := [MKQ [y,pred],:deref atts]
--3. it may be a list, with PROGN as the first, and some information as the rest
x is ["PROGN",:l] =>
for u in l repeat
- compCategoryItem(u,predl,env,sigs,atts)
+ compCategoryItem(db,u,predl,env,sigs,atts)
-- 4. otherwise, x gives a signature for a
-- single operator name or a list of names; if a list of names,
-- recurse
- x is ["SIGNATURE",:opsig] => compSignature(opsig,pred,env,sigs)
+ x is ["SIGNATURE",:opsig] => compSignature(db,opsig,pred,env,sigs)
systemErrorHere ["compCategoryItem",x]
compCategory: (%Form,%Mode,%Env) -> %Maybe %Triple
compCategory(x,m,e) ==
clearExportsTable()
+ db := currentDB e
m := resolve(m,$Category)
m = $Category and x is ['CATEGORY,kind,:l] =>
sigs := ref nil
atts := ref nil
for x in l repeat
- compCategoryItem(x,nil,e,sigs,atts)
+ compCategoryItem(db,x,nil,e,sigs,atts)
rep := mkExplicitCategoryFunction(kind,deref sigs,deref atts)
--if inside compDefineCategory, provide for category argument substitution
[rep,m,e]