aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/ChangeLog33
-rw-r--r--src/boot/strap/utility.clisp50
-rw-r--r--src/boot/utility.boot30
-rw-r--r--src/interp/bc-matrix.boot6
-rw-r--r--src/interp/br-con.boot10
-rw-r--r--src/interp/br-data.boot2
-rw-r--r--src/interp/br-op1.boot14
-rw-r--r--src/interp/br-prof.boot2
-rw-r--r--src/interp/br-saturn.boot4
-rw-r--r--src/interp/br-search.boot6
-rw-r--r--src/interp/buildom.boot2
-rw-r--r--src/interp/c-doc.boot11
-rw-r--r--src/interp/c-util.boot16
-rw-r--r--src/interp/cattable.boot4
-rw-r--r--src/interp/clam.boot2
-rw-r--r--src/interp/define.boot4
-rw-r--r--src/interp/format.boot2
-rw-r--r--src/interp/functor.boot33
-rw-r--r--src/interp/g-timer.boot2
-rw-r--r--src/interp/g-util.boot11
-rw-r--r--src/interp/ht-util.boot2
-rw-r--r--src/interp/htsetvar.boot2
-rw-r--r--src/interp/i-intern.boot4
-rw-r--r--src/interp/i-map.boot19
-rw-r--r--src/interp/i-object.boot8
-rw-r--r--src/interp/i-syscmd.boot6
-rw-r--r--src/interp/lisplib.boot6
-rw-r--r--src/interp/profile.boot12
-rw-r--r--src/interp/sys-utility.boot13
-rw-r--r--src/interp/trace.boot14
-rw-r--r--src/interp/vmlisp.lisp17
31 files changed, 171 insertions, 176 deletions
diff --git a/src/ChangeLog b/src/ChangeLog
index 8c52fa09..e834c58e 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,5 +1,38 @@
2011-10-03 Gabriel Dos Reis <gdr@cs.tamu.edu>
+ * boot/utility.boot (symbolAssoc): Rename from assocSymbol. Export.
+ * interp/functor.boot: Remove getAbbreviation, mkAbbrev, addsuffix.
+ * interp/sys-utility.boot (symbolAssoc): Remove as redundant.
+ (scalarTarget): New.
+ * interp/bc-matrix.boot: Use symbolTarget instead of symbolLassoc.
+ * interp/br-con.boot: Use QLASSQ instead of symbolTarget.
+ * interp/br-data.boot: Likewise.
+ * interp/br-op1.boot: Likewise.
+ * interp/br-prof.boot: Likewise.
+ * interp/br-saturn.boot: Likewise.
+ * interp/br-search.boot: Likewise.
+ * interp/buildom.boot: Likewise.
+ * interp/c-doc.boot: Likewise.
+ * interp/c-util.boot: Likewise.
+ * interp/cattable.boot: Likewise.
+ * interp/clam.boot: Likewise.
+ * interp/define.boot: Likewise.
+ * interp/format.boot: Likewise.
+ * interp/g-timer.boot: Likewise.
+ * interp/g-util.boot: Likewise.
+ * interp/ht-util.boot: Likewise.
+ * interp/htsetvar.boot: Likewise.
+ * interp/i-intern.boot: Likewise.
+ * interp/i-map.boot: Likewise.
+ * interp/i-object.boot: Likewise.
+ * interp/i-syscmd.boot: Likewise.
+ * interp/lisplib.boot: Likewise.
+ * interp/profile.boot: Likewise.
+ * interp/trace.boot: Likewise.
+ * interp/vmlisp.lisp (assoc): Tidy.
+
+2011-10-03 Gabriel Dos Reis <gdr@cs.tamu.edu>
+
* interp/comp.lisp: Remove.
* interp/setvart.boot: Remove setting of 'compiler' options.
* interp/setvars.boot (setAsharpArgs): Remove.
diff --git a/src/boot/strap/utility.clisp b/src/boot/strap/utility.clisp
index c42cc8f2..d522b8c8 100644
--- a/src/boot/strap/utility.clisp
+++ b/src/boot/strap/utility.clisp
@@ -19,8 +19,9 @@
|scalarMember?| |listMember?| |reverse| |reverse!|
|lastNode| |append| |append!| |copyList| |substitute|
|substitute!| |setDifference| |setUnion| |setIntersection|
- |applySubst| |applySubst!| |applySubstNQ| |objectAssoc|
- |remove| |removeSymbol| |atomic?| |finishLine|)))
+ |symbolAssoc| |applySubst| |applySubst!| |applySubstNQ|
+ |objectAssoc| |remove| |removeSymbol| |atomic?|
+ |finishLine|)))
(DECLAIM (FTYPE (FUNCTION (|%Thing| |%Thing| |%Thing|) |%Thing|) |substitute|))
@@ -49,11 +50,17 @@
(DECLAIM
(FTYPE
- (FUNCTION (|%Thing| (|%List| (|%Pair| |%Thing| |%Thing|)))
+ (FUNCTION (|%Thing| (|%List| |%Thing|))
(|%Maybe| (|%Pair| |%Thing| |%Thing|)))
|objectAssoc|))
(DECLAIM
+ (FTYPE
+ (FUNCTION (|%Symbol| (|%List| |%Thing|))
+ (|%Maybe| (|%Pair| |%Symbol| |%Thing|)))
+ |symbolAssoc|))
+
+(DECLAIM
(FTYPE (FUNCTION ((|%List| |%Thing|) (|%List| |%Thing|)) (|%List| |%Thing|))
|setDifference|))
@@ -172,15 +179,25 @@
(DEFUN |append| (|x| |y|) (|append!| (|copyList| |x|) |y|))
-(DEFUN |assocSymbol| (|s| |al|)
+(DEFUN |symbolAssoc| (|s| |l|)
(PROG (|x|)
(RETURN
(LOOP
(COND
- ((AND (CONSP |al|)
- (PROGN (SETQ |x| (CAR |al|)) (SETQ |al| (CDR |al|)) T))
- (COND ((AND (CONSP |x|) (EQ |s| (CAR |x|))) (IDENTITY (RETURN |x|)))))
- (T (RETURN NIL)))))))
+ ((NOT
+ (AND (CONSP |l|) (PROGN (SETQ |x| (CAR |l|)) (SETQ |l| (CDR |l|)) T)))
+ (RETURN NIL))
+ ((AND (CONSP |x|) (EQ |s| (CAR |x|))) (RETURN |x|)))))))
+
+(DEFUN |objectAssoc| (|x| |l|)
+ (PROG (|p|)
+ (RETURN
+ (LOOP
+ (COND
+ ((NOT
+ (AND (CONSP |l|) (PROGN (SETQ |p| (CAR |l|)) (SETQ |l| (CDR |l|)) T)))
+ (RETURN NIL))
+ ((AND (CONSP |p|) (EQ (CAR |p|) |x|)) (RETURN |p|)))))))
(DEFUN |substitute!| (|y| |x| |s|)
(COND ((NULL |s|) NIL) ((EQ |x| |s|) |y|)
@@ -208,7 +225,7 @@
(SETQ |tl| (|applySubst| |sl| (CDR |t|)))
(COND ((AND (EQ |hd| (CAR |t|)) (EQ |tl| (CDR |t|))) |t|)
(T (CONS |hd| |tl|))))
- ((AND (SYMBOLP |t|) (SETQ |p| (|assocSymbol| |t| |sl|))) (CDR |p|))
+ ((AND (SYMBOLP |t|) (SETQ |p| (|symbolAssoc| |t| |sl|))) (CDR |p|))
(T |t|)))))
(DEFUN |applySubst!| (|sl| |t|)
@@ -218,7 +235,7 @@
((CONSP |t|) (SETQ |hd| (|applySubst!| |sl| (CAR |t|)))
(SETQ |tl| (|applySubst!| |sl| (CDR |t|))) (RPLACA |t| |hd|)
(RPLACD |t| |tl|))
- ((AND (SYMBOLP |t|) (SETQ |p| (|assocSymbol| |t| |sl|))) (CDR |p|))
+ ((AND (SYMBOLP |t|) (SETQ |p| (|symbolAssoc| |t| |sl|))) (CDR |p|))
(T |t|)))))
(DEFUN |applySubstNQ| (|sl| |t|)
@@ -231,7 +248,7 @@
(SETQ |tl| (|applySubstNQ| |sl| |tl|))
(COND ((AND (EQ |hd| (CAR |t|)) (EQ |tl| (CDR |t|))) |t|)
(T (CONS |hd| |tl|))))))
- ((AND (SYMBOLP |t|) (SETQ |p| (|assocSymbol| |t| |sl|))) (CDR |p|))
+ ((AND (SYMBOLP |t|) (SETQ |p| (|symbolAssoc| |t| |sl|))) (CDR |p|))
(T |t|)))))
(DEFUN |setDifference| (|x| |y|)
@@ -335,17 +352,6 @@
((OR (CHARACTERP |x|) (INTEGERP |x|)) (|removeScalar| |l| |x|))
(T (|removeValue| |l| |x|))))
-(DEFUN |objectAssoc| (|x| |l|)
- (PROG (|a| |p|)
- (RETURN
- (LOOP
- (COND
- ((NOT
- (AND (CONSP |l|) (PROGN (SETQ |p| (CAR |l|)) (SETQ |l| (CDR |l|)) T)))
- (RETURN NIL))
- ((AND (CONSP |p|) (PROGN (SETQ |a| (CAR |p|)) T) (EQ |a| |x|))
- (RETURN |p|)))))))
-
(DEFUN |charPosition| (|c| |s| |k|)
(PROG (|n|)
(RETURN
diff --git a/src/boot/utility.boot b/src/boot/utility.boot
index d60c7d5c..79d84700 100644
--- a/src/boot/utility.boot
+++ b/src/boot/utility.boot
@@ -47,7 +47,7 @@ module utility (objectMember?, symbolMember?, stringMember?,
charMember?, scalarMember?, listMember?, reverse, reverse!,
lastNode, append, append!, copyList, substitute, substitute!,
setDifference, setUnion, setIntersection,
- applySubst, applySubst!, applySubstNQ, objectAssoc,
+ symbolAssoc, applySubst, applySubst!, applySubstNQ, objectAssoc,
remove,removeSymbol,atomic?,finishLine) where
substitute: (%Thing,%Thing,%Thing) -> %Thing
substitute!: (%Thing,%Thing,%Thing) -> %Thing
@@ -57,8 +57,8 @@ module utility (objectMember?, symbolMember?, stringMember?,
lastNode: %List %Thing -> %Maybe %Node %Thing
removeSymbol: (%List %Thing, %Symbol) -> %List %Thing
remove: (%List %Thing, %Thing) -> %List %Thing
- objectAssoc: (%Thing, %List %Pair(%Thing,%Thing)) ->
- %Maybe %Pair(%Thing,%Thing)
+ objectAssoc: (%Thing, %List %Thing) -> %Maybe %Pair(%Thing,%Thing)
+ symbolAssoc: (%Symbol,%List %Thing) -> %Maybe %Pair(%Symbol,%Thing)
setDifference: (%List %Thing,%List %Thing) -> %List %Thing
setUnion: (%List %Thing,%List %Thing) -> %List %Thing
setIntersection: (%List %Thing,%List %Thing) -> %List %Thing
@@ -177,12 +177,15 @@ append(x,y) ==
--% a-list
-assocSymbol(s,al) ==
+symbolAssoc(s,l) ==
repeat
- al is [x,:al] =>
- cons? x and symbolEq?(s,first x) =>
- return x
- return nil
+ l isnt [x,:l] => return nil
+ x is [.,:.] and symbolEq?(s,first x) => return x
+
+objectAssoc(x,l) ==
+ repeat
+ l isnt [p,:l] => return nil
+ p is [.,:.] and sameObject?(first p,x) => return p
--% substitution
@@ -210,7 +213,7 @@ applySubst(sl,t) ==
tl := applySubst(sl,rest t)
sameObject?(hd,first t) and sameObject?(tl,rest t) => t
[hd,:tl]
- symbol? t and (p := assocSymbol(t,sl)) => rest p
+ symbol? t and (p := symbolAssoc(t,sl)) => rest p
t
applySubst!(sl,t) ==
@@ -219,7 +222,7 @@ applySubst!(sl,t) ==
tl := applySubst!(sl,rest t)
t.first := hd
t.rest := tl
- symbol? t and (p := assocSymbol(t,sl)) => rest p
+ symbol? t and (p := symbolAssoc(t,sl)) => rest p
t
++ Like applySubst, but skip quoted materials.
@@ -230,7 +233,7 @@ applySubstNQ(sl,t) ==
tl := applySubstNQ(sl,tl)
sameObject?(hd,first t) and sameObject?(tl,rest t) => t
[hd,:tl]
- symbol? t and (p := assocSymbol(t,sl)) => rest p
+ symbol? t and (p := symbolAssoc(t,sl)) => rest p
t
--% set operations
@@ -293,11 +296,6 @@ remove(l,x) ==
--% search
-objectAssoc(x,l) ==
- repeat
- l isnt [p,:l] => return nil
- p is [a,:.] and sameObject?(a,x) => return p
-
++ Return the index of the character `c' in the string `s', if present.
++ Otherwise, return nil.
charPosition(c,s,k) ==
diff --git a/src/interp/bc-matrix.boot b/src/interp/bc-matrix.boot
index 18b93120..1aacb08d 100644
--- a/src/interp/bc-matrix.boot
+++ b/src/interp/bc-matrix.boot
@@ -141,10 +141,10 @@ bcMatrixGen htPage ==
nrows := htpProperty(htPage,'nrows)
ncols := htpProperty(htPage,'ncols)
mat := htpProperty(htPage,'matrix)
- formula := symbolLassoc('formula,mat) =>
+ formula := symbolTarget('formula,mat) =>
formula := formula.0
- rowVar := (symbolLassoc('rowVar,mat)).0
- colVar := (symbolLAssoc('colVar,mat)).0
+ rowVar := (symbolTarget('rowVar,mat)).0
+ colVar := (symbolTarget('colVar,mat)).0
strconc('"matrix([[",formula,'" for ",colVar,'" in 1..",
STRINGIMAGE ncols,'"] for ",rowVar,'" in 1..",STRINGIMAGE nrows,'"])")
mat := htpProperty(htPage,'matrix) =>
diff --git a/src/interp/br-con.boot b/src/interp/br-con.boot
index 1719a767..46ab6120 100644
--- a/src/interp/br-con.boot
+++ b/src/interp/br-con.boot
@@ -49,7 +49,7 @@ namespace BOOT
-- [mathform2HtString x for x in rest a]
-- if cons? a then a := first a
-- da := DOWNCASE a
--- pageName := QLASSQ(da,'((type . CategoryType)(union . DomainUnion)(record . DomainRecord)(mapping . DomainMapping))) =>
+-- pageName := symbolTarget(da,'((type . CategoryType)(union . DomainUnion)(record . DomainRecord)(mapping . DomainMapping))) =>
-- downlink pageName --special jump out for primitive domains
-- line := conPageFastPath a => kPage line --lower case name of cons?
-- line := conPageFastPath UPCASE a => kPage line --upper case an abbr?
@@ -65,7 +65,7 @@ conPage(a,:b) ==
$conArgstrings: local := [form2HtString x for x in KDR a]
if cons? a then a := first a
da := DOWNCASE a
- pageName := QLASSQ(da,'((type . CategoryType)(union . DomainUnion)(record . DomainRecord)(mapping . DomainMapping)(enumeration . DomainEnumeration))) =>
+ pageName := symbolTarget(da,'((type . CategoryType)(union . DomainUnion)(record . DomainRecord)(mapping . DomainMapping)(enumeration . DomainEnumeration))) =>
downlink pageName --special jump out for primitive domains
line := conPageFastPath da => kPage(line,form) --lower case name of cons?
line := conPageFastPath UPCASE a => kPage(line,form) --upper case an abbr?
@@ -77,7 +77,7 @@ conPageFastPath x == --called by conPage and constructorSearch
charPosition(char "*",s,0) < #s => nil --quit if name has * in it
name := (string? x => makeSymbol x; x)
entry := tableValue($lowerCaseConTb,name) or return nil
- lineNumber := QLASSQ('dbLineNumber,CDDR entry) =>
+ lineNumber := symbolTarget('dbLineNumber,CDDR entry) =>
--'dbLineNumbers property is set by function dbAugmentConstructorDataTable
dbRead lineNumber --read record for constructor from libdb.text
conPageConEntry first entry
@@ -704,7 +704,7 @@ conOpPage1(conform,:options) ==
htpSetProperty(page,'domname,domname) --> !!note!! <--
htpSetProperty(page,'conform,conform)
htpSetProperty(page,'signature,signature)
- if selectedOperation := symbolLAssoc('selectedOperation,IFCDR options) then
+ if selectedOperation := symbolTarget('selectedOperation,IFCDR options) then
htpSetProperty(page,'selectedOperation,selectedOperation)
for [a,:b] in bindingsAlist repeat htpSetProperty(page,a,b)
koPage(page,'"operation")
@@ -984,7 +984,7 @@ dbShowConsDoc1(htPage,conform,indexOrNil) ==
--NOTE that we pass conform is as "origin"
getConstructorDocumentation conname ==
- symbolLassoc('constructor,getConstructorDocumentationFromDB conname)
+ symbolTarget('constructor,getConstructorDocumentationFromDB conname)
is [[nil,line,:.],:.] and line or '""
dbSelectCon(htPage,which,index) ==
diff --git a/src/interp/br-data.boot b/src/interp/br-data.boot
index 3b372629..204db22a 100644
--- a/src/interp/br-data.boot
+++ b/src/interp/br-data.boot
@@ -111,7 +111,7 @@ buildLibdbConEntry conname ==
DOWNCASE stringChar(symbolName kind,0)
argl := rest $conform
conComments :=
- symbolLassoc('constructor,$doc) is [[=nil,:r]] =>
+ symbolTarget('constructor,$doc) is [[=nil,:r]] =>
libdbTrim concatWithBlanks r
'""
argpart:= subString(form2HtString ['f,:argl],1)
diff --git a/src/interp/br-op1.boot b/src/interp/br-op1.boot
index 216e863d..ebd5b510 100644
--- a/src/interp/br-op1.boot
+++ b/src/interp/br-op1.boot
@@ -525,20 +525,20 @@ dbShowOpAllDomains(htPage,opAlist,which) ==
for [.,predicate,origin,:.] in items repeat
conname := first origin
getConstructorKindFromDB conname = "category" =>
- pred := simpOrDumb(predicate,QLASSQ(conname,catOriginAlist) or true)
+ pred := simpOrDumb(predicate,symbolTarget(conname,catOriginAlist) or true)
catOriginAlist := insertAlist(conname,pred,catOriginAlist)
- pred := simpOrDumb(predicate,QLASSQ(conname,domOriginAlist) or true)
+ pred := simpOrDumb(predicate,symbolTarget(conname,domOriginAlist) or true)
domOriginAlist := insertAlist(conname,pred,domOriginAlist)
--the following is similar to "domainsOf" but do not sort immediately
u := [COPY key for [key,:.] in entries _*HASCATEGORY_-HASH_*
- | QLASSQ(rest key,catOriginAlist)]
+ | symbolTarget(rest key,catOriginAlist)]
for pair in u repeat
[dom,:cat] := pair
- QLASSQ(cat,catOriginAlist) is 'etc => pair.rest := 'etc
+ symbolTarget(cat,catOriginAlist) is 'etc => pair.rest := 'etc
pair.rest := simpOrDumb(constructorHasCategoryFromDB pair,true)
--now add all of the domains
for [dom,:pred] in domOriginAlist repeat
- u := insertAlist(dom,simpOrDumb(pred,QLASSQ(dom,u) or true),u)
+ u := insertAlist(dom,simpOrDumb(pred,symbolTarget(dom,u) or true),u)
cAlist := listSort(function GLESSEQP,u)
for pair in cAlist repeat
pair.first := getConstructorForm first pair
@@ -610,10 +610,10 @@ dbShowOpParameters(htPage,opAlist,which,data) ==
htSayExpose(ops,exposeFlag)
n := #opform
do
- n = 2 and symbolLassoc('Nud,PROPLIST op) =>
+ n = 2 and symbolTarget('Nud,PROPLIST op) =>
dbShowOpParameterJump(ops,which,count,single?)
htSay('" {\em ",KAR args,'"}")
- n = 3 and symbolLassoc('Led,PROPLIST op) =>
+ n = 3 and symbolTarget('Led,PROPLIST op) =>
htSay('"{\em ",KAR args,'"} ")
dbShowOpParameterJump(ops,which,count,single?)
htSay('" {\em ",KAR KDR args,'"}")
diff --git a/src/interp/br-prof.boot b/src/interp/br-prof.boot
index c626ba23..56636ad2 100644
--- a/src/interp/br-prof.boot
+++ b/src/interp/br-prof.boot
@@ -84,7 +84,7 @@ dbShowInfoOp(htPage,op,sig,alist) ==
applySubst(pairList($FormalMapVariableList,IFCDR conform),faTypes)
conform := htpProperty(htPage,'conform)
conname := opOf conform
---argTypes := reverse ASSOCRIGHT symbolLassoc('arguments,alist)
+--argTypes := reverse ASSOCRIGHT symbolTarget('arguments,alist)
--sig := or/[sig for [sig,:.] in LASSOC(op,opAlist) | rest sig = argTypes]
ops := escapeSpecialChars STRINGIMAGE zeroOneConvert op
oppart := ['"{\em ", ops, '"}"]
diff --git a/src/interp/br-saturn.boot b/src/interp/br-saturn.boot
index 238855a0..6bea4b28 100644
--- a/src/interp/br-saturn.boot
+++ b/src/interp/br-saturn.boot
@@ -1206,9 +1206,9 @@ displayDomainOp(htPage,which,origin,op,sig,predicate,
ops := escapeSpecialChars STRINGIMAGE op
n := #sig
do
- n = 2 and symbolLassoc('Nud,PROPLIST op) =>
+ n = 2 and symbolTarget('Nud,PROPLIST op) =>
htSay(ops,'" {\em ",quickForm2HtString KAR args,'"}")
- n = 3 and symbolLassoc('Led,PROPLIST op) =>
+ n = 3 and symbolTarget('Led,PROPLIST op) =>
htSay('"{\em ",quickForm2HtString KAR args,'"} ",ops,'" {\em ",quickForm2HtString KAR KDR args,'"}")
if unexposed? and $includeUnexposed? then
htSayUnexposed()
diff --git a/src/interp/br-search.boot b/src/interp/br-search.boot
index 026ff895..fa44b8e1 100644
--- a/src/interp/br-search.boot
+++ b/src/interp/br-search.boot
@@ -362,7 +362,7 @@ spadType(x) == --called by \spadtype{x} from HyperDoc
looksLikeDomainForm x ==
entry := getCDTEntry(opOf x,true) or return false
- coSig := symbolLassoc('coSig,CDDR entry)
+ coSig := symbolTarget('coSig,CDDR entry)
k := #coSig
x isnt [.,:.] => k = 1
k ~= #x => false
@@ -754,7 +754,7 @@ dbSearchAbbrev([.,:conlist],kind,filter) ==
null conlist => emptySearchPage('"abbreviation",filter)
kind := intern kind
if kind ~= 'constructor then
- conlist := [x for x in conlist | symbolLassoc('kind,IFCDR IFCDR x) = kind]
+ conlist := [x for x in conlist | symbolTarget('kind,IFCDR IFCDR x) = kind]
conlist is [[nam,:.]] => conPage DOWNCASE nam
cAlist := [[con,:true] for con in conlist]
htPage := htInitPage('"",nil)
@@ -764,7 +764,7 @@ dbSearchAbbrev([.,:conlist],kind,filter) ==
page := htInitPage([#conlist,
'" Abbreviations Match {\em ",STRINGIMAGE filter,'"}"],nil)
for [nam,abbr,:r] in conlist repeat
- kind := symbolLAssoc('kind,r)
+ kind := symbolTarget('kind,r)
htSay('"\newline{\em ",s := STRINGIMAGE abbr)
htSayStandard '"\tab{10}"
htSay '"}"
diff --git a/src/interp/buildom.boot b/src/interp/buildom.boot
index 6af76e6a..59e0e68b 100644
--- a/src/interp/buildom.boot
+++ b/src/interp/buildom.boot
@@ -277,7 +277,7 @@ lookupInTable(op,sig,dollar,[domain,table]) ==
table is "derived" => lookupInAddChain(op,sig,domain,dollar)
success := nil -- lookup result
someMatch := false
- while not success for [sig1,:code] in QLASSQ(op,table) repeat
+ while not success for [sig1,:code] in symbolTarget(op,table) repeat
success :=
not compareSig(sig,sig1,canonicalForm dollar,domain) => false
code is ['Subsumed,a] =>
diff --git a/src/interp/c-doc.boot b/src/interp/c-doc.boot
index 100ee96d..fbf666f0 100644
--- a/src/interp/c-doc.boot
+++ b/src/interp/c-doc.boot
@@ -36,6 +36,9 @@ import c_-util
import daase
namespace BOOT
+$checkPrenAlist ==
+ [[char "(",:char ")"],[char "{",:char "}"],[char "[",:char "]"]]
+
batchExecute() ==
_/RF_-1 '(GENCON INPUT)
@@ -77,7 +80,7 @@ getDocForDomain(name,op,sig) ==
++ `op' and given signature `sigPart'. The operator `op' is assumed
++ to have been defined in the domain or catagory `abb'.
getOpDoc(abb,op,:sigPart) ==
- u := symbolLassoc(op,getConstructorDocumentationFromDB abb)
+ u := symbolTarget(op,getConstructorDocumentationFromDB abb)
$argList : local := $FormalMapVariableList
_$: local := '_$
sigPart is [sig] => or/[d for [s,:d] in u | sig = s]
@@ -1009,8 +1012,8 @@ checkBalance u ==
while u repeat
do
x := first u
- openClose := assoc(x,$checkPrenAlist) --is it an open bracket?
- => stack := [first openClose,:stack] --yes, push the open bracket
+ closer := scalarTarget(x,$checkPrenAlist) --is it an open bracket?
+ => stack := [closer,:stack] --yes, push the open bracket
open := rassoc(x,$checkPrenAlist) => --it is a close bracket!
stack is [top,:restStack] => --does corresponding open bracket match?
if open ~= top then --yes: just pop the stack
@@ -1153,7 +1156,7 @@ checkTransformFirsts(opname,u,margin) ==
checkDocError ['"Improper first word in comments: ",firstWord]
u
#(p := symbolName infixOp) = 1 and (open := p.0) and
- (close := LASSOC(open,$checkPrenAlist)) => --have an open bracket
+ (close := scalarTarget(open,$checkPrenAlist)) => --have an open bracket
l := getMatchingRightPren(u,k + 1,open,close)
if l > maxIndex u then l := k - 1
strconc('"\spad{",subString(u,0,l + 1),'"}",subString(u,l + 1))
diff --git a/src/interp/c-util.boot b/src/interp/c-util.boot
index 795556da..8145cd36 100644
--- a/src/interp/c-util.boot
+++ b/src/interp/c-util.boot
@@ -478,7 +478,7 @@ addContour(c,E is [cur,:tail]) ==
if p="conditionalmode" then
pv.first := "mode"
--check for conflicts with earlier mode
- if vv := symbolLassoc("mode",e) then
+ if vv := symbolTarget("mode",e) then
if v ~=vv then
stackWarning('"The conditional modes %1p and %2p conflict",
[v,vv])
@@ -603,7 +603,7 @@ prEnv E ==
for x in E for i in 1.. repeat
for y in x for j in 1.. repeat
SAY('"******CONTOUR ",j,'", LEVEL ",i,'":******")
- for z in y | null symbolLassoc("modemap",rest z) repeat
+ for z in y | null symbolTarget("modemap",rest z) repeat
TERPRI()
SAY("Properties Of: ",first z)
for u in rest z repeat
@@ -619,7 +619,7 @@ prModemaps E ==
for x in E for i in 1.. repeat
for y in x for j in 1.. repeat
for z in y | not member(first z,listOfOperatorsSeenSoFar) and
- (modemap := symbolLassoc("modemap",rest z)) repeat
+ (modemap := symbolTarget("modemap",rest z)) repeat
listOfOperatorsSeenSoFar:= [first z,:listOfOperatorsSeenSoFar]
TERPRI()
PRIN1 first z
@@ -710,7 +710,7 @@ diagnoseUnknownType(t,e) ==
isConstantId(name,e) ==
ident? name =>
pl:= getProplist(name,e) =>
- (symbolLassoc("value",pl) or symbolLassoc("mode",pl) => false; true)
+ (symbolTarget("value",pl) or symbolTarget("mode",pl) => false; true)
true
false
@@ -1010,8 +1010,8 @@ extendsCategoryForm(domain,form,form') ==
getmode(x,e) ==
prop:=getProplist(x,e)
- u := QLASSQ("value",prop) => u.mode
- QLASSQ("mode",prop)
+ u := symbolTarget("value",prop) => u.mode
+ symbolTarget("mode",prop)
getmodeOrMapping(x,e) ==
u:= getmode(x,e) => u
@@ -1095,7 +1095,7 @@ displayModemaps E ==
for x in E for i in 1.. repeat
for y in x for j in 1.. repeat
for z in y | not member(first z,listOfOperatorsSeenSoFar) and
- (modemaps := symbolLassoc("modemap",rest z)) repeat
+ (modemaps := symbolTarget("modemap",rest z)) repeat
listOfOperatorsSeenSoFar:= [first z,:listOfOperatorsSeenSoFar]
displayOpModemaps(first z,modemaps)
@@ -1497,7 +1497,7 @@ backendCompile2 code ==
code isnt [name,[type,args,:body],:junk] or junk ~= nil =>
systemError ['"parenthesis error in: ", code]
type = "SLAM" => backendCompileSLAM(name,args,body)
- QLASSQ(name,$clamList) => compClam(name,args,body,$clamList)
+ symbolTarget(name,$clamList) => compClam(name,args,body,$clamList)
type = "SPADSLAM" => backendCompileSPADSLAM(name,args,body)
type = "ILAM" => backendCompileILAM(name,args,body)
body := [name,[type,args,:body]]
diff --git a/src/interp/cattable.boot b/src/interp/cattable.boot
index 7e225cc6..a5abcce8 100644
--- a/src/interp/cattable.boot
+++ b/src/interp/cattable.boot
@@ -109,7 +109,7 @@ simpHasPred(pred,:options) == main where
op is 'hasArgs => ($hasArgs => $hasArgs = r; pred)
null r and opOf op = "has" => simp first pred
pred is '%true or pred is '(QUOTE T) => true
- op1 := symbolLassoc(op,'((and . AND)(or . OR)(not . NOT))) =>
+ op1 := symbolTarget(op,'((and . AND)(or . OR)(not . NOT))) =>
simp [op1,:r]
simp first pred --REMOVE THIS HACK !!!!
pred in '(T etc) => pred
@@ -134,7 +134,7 @@ simpHasSignature(pred,conform,op,sig) == --eval w/o loading
ident? conform => pred
[conname,:args] := conform
n := #sig
- u := symbolLassoc(op,getConstructorOperationsFromDB conname)
+ u := symbolTarget(op,getConstructorOperationsFromDB conname)
candidates := [x for (x := [sig1,:.]) in u | #sig1 = #sig] or return false
match := or/[x for (x := [sig1,:.]) in candidates
| sig = sublisFormal(args,sig1)] or return false
diff --git a/src/interp/clam.boot b/src/interp/clam.boot
index eabd822e..ef384409 100644
--- a/src/interp/clam.boot
+++ b/src/interp/clam.boot
@@ -78,7 +78,7 @@ $failed := '"failed"
compClam(op,argl,body,$clamList) ==
--similar to reportFunctionCompilation in SLAM BOOT
if $InteractiveMode then startTimingProcess 'compilation
- if (u := QLASSQ(op,$clamList)) isnt [kind,eqEtc,:options]
+ if (u := symbolTarget(op,$clamList)) isnt [kind,eqEtc,:options]
then keyedSystemError("S2GE0004",[op])
$clamList:= nil --clear to avoid looping
if u:= S_-(options,'(shift count)) then
diff --git a/src/interp/define.boot b/src/interp/define.boot
index f933a59e..3c73dfb0 100644
--- a/src/interp/define.boot
+++ b/src/interp/define.boot
@@ -827,7 +827,7 @@ compDefine1(form,m,e) ==
compDefineAddSignature([op,:argl],signature,e) ==
(sig:= hasFullSignature(argl,signature,e)) and
- null assoc(['$,:sig],symbolLassoc('modemap,getProplist(op,e))) =>
+ null assoc(['$,:sig],symbolTarget('modemap,getProplist(op,e))) =>
declForm:=
[":",[op,:[[":",x,m] for x in argl for m in sig.source]],signature.target]
[.,.,e]:= comp(declForm,$EmptyMode,e)
@@ -1198,7 +1198,7 @@ addModemap1(op,mc,sig,pred,fn,e) ==
if mc="Rep" then sig := substituteDollarIfRepHack sig
currentProplist:= getProplist(op,e) or nil
newModemapList:=
- mkNewModemapList(mc,sig,pred,fn,symbolLassoc('modemap,currentProplist),e,nil)
+ mkNewModemapList(mc,sig,pred,fn,symbolTarget('modemap,currentProplist),e,nil)
newProplist:= augProplist(currentProplist,'modemap,newModemapList)
newProplist':= augProplist(newProplist,"FLUID",true)
unErrorRef op
diff --git a/src/interp/format.boot b/src/interp/format.boot
index 4498f339..a619d7d5 100644
--- a/src/interp/format.boot
+++ b/src/interp/format.boot
@@ -725,7 +725,7 @@ pred2English x ==
concat(pred2English a,'": ",form2String abbreviate b)
x is [op,a,b] and op in '(isDomain domainEqual) =>
concat(pred2English a,'" = ",form2String abbreviate b)
- x is [op,:.] and (translation := symbolLassoc(op,'(
+ x is [op,:.] and (translation := symbolTarget(op,'(
(_< . " < ") (_<_= . " <= ")
(_> . " > ") (_>_= . " >= ") (_= . " = ") (_~_= . " _~_= ")))) =>
concat(pred2English a,translation,pred2English b)
diff --git a/src/interp/functor.boot b/src/interp/functor.boot
index 0a93ed7d..c291c554 100644
--- a/src/interp/functor.boot
+++ b/src/interp/functor.boot
@@ -846,36 +846,3 @@ getCaps x ==
clist:= [c for i in 0..maxIndex s | upperCase? (c:= s.i)]
null clist => '"__"
strconc/[first clist,:[L_-CASE u for u in rest clist]]
-
---% abbreviation code
-
-getAbbreviation(name,c) ==
- --returns abbreviation of name with c arguments
- x := getConstructorAbbreviationFromDB name
- X := objectAssoc(x,$abbreviationTable) =>
- N := objectAssoc(name,rest X) =>
- C := objectAssoc(c,rest N) => rest C --already there
- newAbbreviation:= mkAbbrev(X,x)
- N.rest := [[c,:newAbbreviation],:rest N]
- newAbbreviation
- newAbbreviation:= mkAbbrev(X,x)
- X.rest := [[name,[c,:newAbbreviation]],:rest X]
- newAbbreviation
- $abbreviationTable:= [[x,[name,[c,:x]]],:$abbreviationTable]
- x
-
-mkAbbrev(X,x) == addSuffix(alistSize rest X,x)
-
-alistSize c ==
- count(c,1) where
- count(x,level) ==
- level=2 => #x
- null x => 0
- count(CDAR x,level+1)+count(rest x,level)
-
-addSuffix(n,u) ==
- s := STRINGIMAGE u
- alphabetic? stringChar(s,maxIndex s) =>
- makeSymbol strconc(s,STRINGIMAGE n)
- INTERNL strconc(s,STRINGIMAGE ";",STRINGIMAGE n)
-
diff --git a/src/interp/g-timer.boot b/src/interp/g-timer.boot
index 69f538db..4e3ab09d 100644
--- a/src/interp/g-timer.boot
+++ b/src/interp/g-timer.boot
@@ -78,7 +78,7 @@ makeLongStatStringByProperty _
if otherStatTotal > 0 then
str := makeStatString(str,normalizeStatAndStringify otherStatTotal,'O,flag)
total := total + otherStatTotal
- cl := first symbolLassoc('other,listofnames)
+ cl := first symbolTarget('other,listofnames)
cl := first LASSOC(cl,listofclasses)
property(cl,classprop) := otherStatTotal + property(cl,classprop)
if flag ~= 'long then
diff --git a/src/interp/g-util.boot b/src/interp/g-util.boot
index f9bb8ef0..f49a61ec 100644
--- a/src/interp/g-util.boot
+++ b/src/interp/g-util.boot
@@ -266,15 +266,15 @@ get(x,prop,e) ==
get0(x,prop,e) ==
cons? x => get0(x.op,prop,e)
- u := QLASSQ(x,first first e) => QLASSQ(prop,u)
+ u := symbolTarget(x,first first e) => symbolTarget(prop,u)
(tail := rest first e) and (u := fastSearchCurrentEnv(x,tail)) =>
- QLASSQ(prop,u)
+ symbolTarget(prop,u)
nil
get1(x,prop,e) ==
cons? x => get1(x.op,prop,e)
prop = "modemap" and $insideCapsuleFunctionIfTrue =>
- symbolLassoc("modemap",getProplist(x,$CapsuleModemapFrame))
+ symbolTarget("modemap",getProplist(x,$CapsuleModemapFrame))
or get2(x,prop)
LASSOC(prop,getProplist(x,e)) or get2(x,prop)
@@ -762,10 +762,10 @@ augProplistOf(var,prop,val,e) ==
semchkProplist(x,proplist,prop,val) ==
prop="isLiteral" =>
- symbolLassoc("value",proplist) or symbolLassoc("mode",proplist) =>
+ symbolTarget("value",proplist) or symbolTarget("mode",proplist) =>
warnLiteral x
prop in '(mode value) =>
- symbolLassoc("isLiteral",proplist) => warnLiteral x
+ symbolTarget("isLiteral",proplist) => warnLiteral x
addBinding(var,proplist,e is [[curContour,:tailContour],:tailEnv]) ==
sameObject?(proplist,getProplist(var,e)) => e
@@ -875,7 +875,6 @@ $charQuote == char "'"
$charSemiColon == char ";"
$charComma == char ","
$charPeriod == char "."
-$checkPrenAlist := [[char "(",:char ")"],[char "{",:char "}"],[char "[",:char "]"]]
$charEscapeList:= [char "%",char "#",$charBack]
$charIdentifierEndings := [char "__", char "!", char "?"]
$charSplitList := [$charComma,$charPeriod,char "[", char "]",$charLbrace, $charRbrace, char "(", char ")", char "$", char "%"]
diff --git a/src/interp/ht-util.boot b/src/interp/ht-util.boot
index 46e1fcf1..1117be20 100644
--- a/src/interp/ht-util.boot
+++ b/src/interp/ht-util.boot
@@ -269,7 +269,7 @@ bcSadFaces() ==
htLispLinks(links,:option) ==
[links,options] := beforeAfter('options,links)
- indent := symbolLAssoc('indent,options) or 5
+ indent := symbolTarget('indent,options) or 5
iht '"\newline\indent{"
iht stringize indent
iht '"}\beginitems"
diff --git a/src/interp/htsetvar.boot b/src/interp/htsetvar.boot
index 058fcc8c..e91a7dcd 100644
--- a/src/interp/htsetvar.boot
+++ b/src/interp/htsetvar.boot
@@ -430,7 +430,7 @@ htCacheSet htPage ==
num := chkAllNonNegativeInteger
htpLabelInputString(htPage,htMakeLabel('"c",i))
$cacheAlist := ADDASSOC(makeSymbol name,num,$cacheAlist)
- if (n := symbolLAssoc('all,$cacheAlist)) then
+ if (n := symbolTarget('all,$cacheAlist)) then
$cacheCount := n
$cacheAlist := deleteAssoc('all,$cacheAlist)
htInitPage('"Cache Summary",nil)
diff --git a/src/interp/i-intern.boot b/src/interp/i-intern.boot
index e91f1d43..b8be53f7 100644
--- a/src/interp/i-intern.boot
+++ b/src/interp/i-intern.boot
@@ -449,9 +449,9 @@ remprop(x,prop,e) ==
e
fastSearchCurrentEnv(x,currentEnv) ==
- u:= QLASSQ(x,first currentEnv) => u
+ u:= symbolTarget(x,first currentEnv) => u
while (currentEnv:= rest currentEnv) repeat
- u:= QLASSQ(x,first currentEnv) => u
+ u:= symbolTarget(x,first currentEnv) => u
transformCollect [:itrl,body] ==
-- syntactic transformation for COLLECT form, called from mkAtree1
diff --git a/src/interp/i-map.boot b/src/interp/i-map.boot
index 8261ac76..dcdf4cf8 100644
--- a/src/interp/i-map.boot
+++ b/src/interp/i-map.boot
@@ -786,13 +786,12 @@ mapRecurDepth(opName,opList,body) ==
-- expanding the bodies of maps called in body
body isnt [.,:.] => 0
body is [op,:argl] =>
- argc:=
+ argc :=
argl isnt [.,:.] => 0
- argl => "MAX"/[mapRecurDepth(opName,opList,x) for x in argl]
- 0
- symbolMember?(op,opList) => argc
- op=opName => 1 + argc
- (obj := get(op,'value,$e)) and objVal obj is ["%Map",:mapDef] =>
+ "MAX"/[mapRecurDepth(opName,opList,x) for x in argl]
+ ident? op and symbolMember?(op,opList) => argc
+ ident? op and op = opName => 1 + argc
+ ident? op and (obj := get(op,'value,$e)) and objVal obj is ["%Map",:mapDef] =>
mapRecurDepth(opName,[op,:opList],getMapBody(op,mapDef))
+ argc
argc
@@ -895,15 +894,15 @@ nonRecursivePart(opName, funBody) ==
expandRecursiveBody(alreadyExpanded, body) ==
-- replaces calls to other maps with their bodies
body isnt [.,:.] =>
- (obj := get(body,'value,$e)) and objVal obj is ["%Map",:mapDef] and
+ ident? body and (obj := get(body,'value,$e)) and objVal obj is ["%Map",:mapDef] and
((numMapArgs mapDef) = 0) => getMapBody(body,mapDef)
body
body is [op,:argl] =>
- not symbolMember?(op,alreadyExpanded) =>
+ ident? op and not symbolMember?(op,alreadyExpanded) =>
(obj := get(op,'value,$e)) and objVal obj is ["%Map",:mapDef] =>
- newBody:= getMapBody(op,mapDef)
+ newBody := getMapBody(op,mapDef)
for arg in argl for var in $FormalMapVariableList repeat
- newBody:=MSUBST(arg,var,newBody)
+ newBody := substitute(arg,var,newBody)
expandRecursiveBody([op,:alreadyExpanded],newBody)
[op,:[expandRecursiveBody(alreadyExpanded,arg) for arg in argl]]
[op,:[expandRecursiveBody(alreadyExpanded,arg) for arg in argl]]
diff --git a/src/interp/i-object.boot b/src/interp/i-object.boot
index 972d6ed4..2e739d1c 100644
--- a/src/interp/i-object.boot
+++ b/src/interp/i-object.boot
@@ -375,7 +375,7 @@ putAtree(x,prop,val) ==
if vector? op then putAtree(op,prop,val)
x
not vector? x => x -- just ignore it
- n := QLASSQ(prop,'((mode . 1) (value . 2) (modeSet . 3)))
+ n := symbolTarget(prop,'((mode . 1) (value . 2) (modeSet . 3)))
=> vectorRef(x,n) := val
vectorRef(x,4) := insertShortAlist(prop,val,x.4)
x
@@ -387,9 +387,9 @@ getAtree(x,prop) ==
vector? op => getAtree(op,prop)
nil
not vector? x => nil -- just ignore it
- n := QLASSQ(prop,'((mode . 1) (value . 2) (modeSet . 3)))
+ n := symbolTarget(prop,'((mode . 1) (value . 2) (modeSet . 3)))
=> vectorRef(x,n)
- QLASSQ(prop,vectorRef(x,4))
+ symbolTarget(prop,vectorRef(x,4))
putTarget(x, targ) ==
-- want to put nil modes perhaps to clear old target
@@ -462,7 +462,7 @@ getFlagArgsPos t ==
transferPropsToNode(x,t) ==
propList := getProplist(x,$env)
- QLASSQ('Led,propList) or QLASSQ('Nud,propList) => nil
+ symbolTarget('Led,propList) or symbolTarget('Nud,propList) => nil
node :=
vector? t => t
first t
diff --git a/src/interp/i-syscmd.boot b/src/interp/i-syscmd.boot
index 1c48b7c6..311db253 100644
--- a/src/interp/i-syscmd.boot
+++ b/src/interp/i-syscmd.boot
@@ -353,7 +353,7 @@ clearCmdParts(l is [opt,:vl]) ==
vl := ASSOCLEFT CAAR $InteractiveFrame
vl := removeDuplicates(append(vl, pmacs))
$e : local := $InteractiveFrame
- for x in vl repeat
+ for x in vl | ident? x repeat
clearDependencies(x,true)
if option is 'properties and symbolMember?(x,pmacs) then
clearParserMacro(x)
@@ -2409,7 +2409,7 @@ diffAlist(new,old) ==
acc := [[name,:[[prop] for [prop,:.] in proplist]],:acc]
--record properties absent on new list (say, from a )cl all)
for (oldPair := [name,:r]) in old repeat
- r and null QLASSQ(name,new) =>
+ r and null symbolTarget(name,new) =>
acc := [oldPair,:acc]
-- name has an entry both in new and old world
-- (1) if the new world has no proplist for that variable
@@ -2490,7 +2490,7 @@ undoSingleStep(changes,env) ==
-- pp '"----Undoing 1 step--------"
-- pp changes
for (change := [name,:changeList]) in changes repeat
- if symbolLassoc('localModemap,changeList) then
+ if symbolTarget('localModemap,changeList) then
changeList := undoLocalModemapHack changeList
pairlist := objectAssoc(name,env) =>
proplist := rest pairlist =>
diff --git a/src/interp/lisplib.boot b/src/interp/lisplib.boot
index 27b67a68..e1a16471 100644
--- a/src/interp/lisplib.boot
+++ b/src/interp/lisplib.boot
@@ -294,7 +294,7 @@ loadIfNecessary u ==
dbLoaded? constructorDB u => u
loadLib u => u
not $InteractiveMode and (null (y:= getProplist(u,$CategoryFrame))
- or (null symbolLassoc('isFunctor,y)) and (null symbolLAssoc('isCategory,y))) =>
+ or (null symbolTarget('isFunctor,y)) and (null symbolTarget('isCategory,y))) =>
y:= getConstructorKindFromDB u =>
y = "category" =>
updateCategoryFrameForCategory u
@@ -637,7 +637,7 @@ transformOperationAlist operationAlist ==
signatureItem:=
if u:= assoc([op,sig],$functionLocations) then n := [n,:rest u]
[sig,n,condition,kind]
- itemList:= [signatureItem,:QLASSQ(op,newAlist)]
+ itemList:= [signatureItem,:symbolTarget(op,newAlist)]
newAlist:= insertAlist(op,itemList,newAlist)
newAlist
@@ -673,7 +673,7 @@ getSlotNumberFromOperationAlist(domainForm,op,sig) ==
operationAlist:=
getConstructorOperationsFromDB constructorName or
keyedSystemError("S2IL0026",[constructorName])
- entryList:= QLASSQ(op,operationAlist) or return nil
+ entryList:= symbolTarget(op,operationAlist) or return nil
tail:= or/[r for [sig1,:r] in entryList | sigsMatch(sig,sig1,domainForm)] =>
first tail
nil
diff --git a/src/interp/profile.boot b/src/interp/profile.boot
index 78afa963..41796931 100644
--- a/src/interp/profile.boot
+++ b/src/interp/profile.boot
@@ -1,6 +1,6 @@
-- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd.
-- All rights reserved.
--- Copyright (C) 2007-2010, Gabriel Dos Reis.
+-- Copyright (C) 2007-2011, Gabriel Dos Reis.
-- All rights reserved.
--
-- Redistribution and use in source and binary forms, with or without
@@ -73,19 +73,19 @@ profileRecord(label,name,info) == --name: info is var: type or op: sig
$profileAlist
profileDisplay() ==
- profileDisplayOp('constructor,symbolLassoc('constructor,$profileAlist) )
+ profileDisplayOp('constructor,symbolTarget('constructor,$profileAlist) )
for [op,:alist1] in $profileAlist | op ~= 'constructor repeat
profileDisplayOp(op,alist1)
profileDisplayOp(op,alist1) ==
sayBrightly op
- if symbolLassoc('arguments,alist1) then
+ if symbolTarget('arguments,alist1) then
sayBrightly '" arguments"
- for [x,:t] in MSORT symbolLAssoc('arguments,alist1) repeat
+ for [x,:t] in MSORT symbolTarget('arguments,alist1) repeat
sayBrightly concat('" ",x,": ",prefix2String t)
- if symbolLassoc('locals,alist1) then
+ if symbolTarget('locals,alist1) then
sayBrightly '" locals"
- for [x,:t] in MSORT symbolLassoc('locals,alist1) repeat
+ for [x,:t] in MSORT symbolTarget('locals,alist1) repeat
sayBrightly concat('" ",x,": ",prefix2String t)
for [con,:alist2] in alist1 | not (con in '(locals arguments)) repeat
sayBrightly concat('" ",prefix2String con)
diff --git a/src/interp/sys-utility.boot b/src/interp/sys-utility.boot
index b8ae514d..f9f7cbf8 100644
--- a/src/interp/sys-utility.boot
+++ b/src/interp/sys-utility.boot
@@ -45,6 +45,9 @@ module sys_-utility where
upwardCut: (%Thing, %List %Thing) -> %List %Thing
symbolPosition: (%Symbol,%List %Symbol) -> %Maybe %Short
valuePosition: (%Thing,%List %Thing) -> %Maybe %Short
+ symbolTarget: (%Symbol,%List %Thing) -> %Maybe %Thing
+ scalarAssoc: (%Thing,%List %Thing) -> %Maybe %Pair(%Thing,%Thing)
+ scalarTarget: (%Thing,%List %Thing) -> %Maybe %Thing
--%
$COMBLOCKLIST := nil
@@ -148,7 +151,6 @@ ADDASSOC(x,y,l) ==
x = first first l => [[x,:y],:rest l]
[first l,:ADDASSOC(x,y,rest l)]
-
++ Remove any assocation pair `(u . x)' from list `v'.
DELLASOS: (%Thing,%Alist(%Thing,%Thing)) -> %Alist(%Thing,%Thing)
DELLASOS(u,v) ==
@@ -358,9 +360,6 @@ valuePosition(s,l) ==
--% assoc
-symbolAssoc(s,l) ==
- or/[symbolEq?(s,first x) and leave x for x in l | cons? x] or nil
-
scalarAssoc(c,l) ==
or/[scalarEq?(c,first x) and leave x for x in l | cons? x] or nil
@@ -369,10 +368,14 @@ stringAssoc(s,l) ==
--% lassoc
-symbolLassoc(s,l) ==
+symbolTarget(s,l) ==
p := symbolAssoc(s,l) => rest p
nil
+scalarTarget(s,l) ==
+ p := scalarAssoc(s,l) => rest p
+ nil
+
--%
remove!(l,x) ==
l = nil => nil
diff --git a/src/interp/trace.boot b/src/interp/trace.boot
index 976e788e..c1e71e8b 100644
--- a/src/interp/trace.boot
+++ b/src/interp/trace.boot
@@ -138,8 +138,8 @@ trace1 l ==
ADDASSOC(x,$options,$optionAlist)
optionList:= getTraceOptions $options
argument:=
- domainList := symbolLassoc("of",optionList) =>
- symbolLAssoc("ops",optionList) =>
+ domainList := symbolTarget("of",optionList) =>
+ symbolTarget("ops",optionList) =>
throwKeyedMsg("S2IT0004",nil)
opList:=
traceList => [["ops",:traceList]]
@@ -378,7 +378,7 @@ getPreviousMapSubNames(traceNames) ==
subs
lassocSub(x,subs) ==
- y := QLASSQ(x,subs) => y
+ y := symbolTarget(x,subs) => y
x
rassocSub(x,subs) ==
@@ -586,7 +586,7 @@ mapLetPrint(x,val,currentFunction) ==
letPrint(x,val,currentFunction) ==
if $letAssoc and
- ((y:= LASSOC(currentFunction,$letAssoc)) or (y:= symbolLassoc("all",$letAssoc))) then
+ ((y:= LASSOC(currentFunction,$letAssoc)) or (y:= symbolTarget("all",$letAssoc))) then
if (y="all" or symbolMember?(x,y)) and
not (IS__GENVAR(x) or isSharpVarWithNum(x) or GENSYMP x) then
sayBrightlyNT [:bright x,": "]
@@ -604,7 +604,7 @@ letPrint(x,val,currentFunction) ==
letPrint2(x,printform,currentFunction) ==
$BreakMode:local := nil
if $letAssoc and
- ((y:= LASSOC(currentFunction,$letAssoc)) or (y:= symbolLAssoc("all",$letAssoc))) then
+ ((y:= symbolTarget(currentFunction,$letAssoc)) or (y:= symbolTarget("all",$letAssoc))) then
if (y="all" or symbolMember?(x,y)) and
not (IS__GENVAR(x) or isSharpVarWithNum(x) or GENSYMP x) then
$BreakMode:='letPrint2
@@ -624,7 +624,7 @@ letPrint2(x,printform,currentFunction) ==
letPrint3(x,xval,printfn,currentFunction) ==
$BreakMode:local := nil
if $letAssoc and
- ((y:= LASSOC(currentFunction,$letAssoc)) or (y:= symbolLassoc("all",$letAssoc))) then
+ ((y:= LASSOC(currentFunction,$letAssoc)) or (y:= symbolTarget("all",$letAssoc))) then
if (y="all" or symbolMember?(x,y)) and
not (IS__GENVAR(x) or isSharpVarWithNum(x) or GENSYMP x) then
$BreakMode:='letPrint2
@@ -792,7 +792,7 @@ breaklet(fn,vars) ==
fn = "Undef" => nil
fnEntry:= LASSOC(fn,$letAssoc)
vars:=
- pair := symbolLassoc("BREAK",fnEntry) => setUnion(vars,rest pair)
+ pair := symbolTarget("BREAK",fnEntry) => setUnion(vars,rest pair)
vars
$letAssoc:=
null fnEntry => [[fn,:[["BREAK",:vars]]],:$letAssoc]
diff --git a/src/interp/vmlisp.lisp b/src/interp/vmlisp.lisp
index bbf199f6..e922e1de 100644
--- a/src/interp/vmlisp.lisp
+++ b/src/interp/vmlisp.lisp
@@ -671,26 +671,13 @@
; 14.3 Searching
-(defun QLASSQ (p a-list) (cdr (|objectAssoc| p a-list)))
-
(DEFUN |assoc| (X Y)
"Return the pair associated with key X in association list Y."
; ignores non-nil list terminators
; ignores non-pair a-list entries
- (cond ((symbolp X)
- (PROG NIL
- A (COND ((ATOM Y) (RETURN NIL))
- ((NOT (consp (CAR Y))) )
- ((EQ (CAAR Y) X) (RETURN (CAR Y))) )
- (SETQ Y (CDR Y))
- (GO A)))
+ (cond ((symbolp X) (|symbolAssoc| X Y))
((or (numberp x) (characterp x))
- (PROG NIL
- A (COND ((ATOM Y) (RETURN NIL))
- ((NOT (consp (CAR Y))) )
- ((EQL (CAAR Y) X) (RETURN (CAR Y))) )
- (SETQ Y (CDR Y))
- (GO A)))
+ (|scalarAssoc| X Y))
(t
(PROG NIL
A (COND ((ATOM Y) (RETURN NIL))