diff options
Diffstat (limited to 'src/interp/ht-util.boot.pamphlet')
-rw-r--r-- | src/interp/ht-util.boot.pamphlet | 753 |
1 files changed, 0 insertions, 753 deletions
diff --git a/src/interp/ht-util.boot.pamphlet b/src/interp/ht-util.boot.pamphlet deleted file mode 100644 index f875959f..00000000 --- a/src/interp/ht-util.boot.pamphlet +++ /dev/null @@ -1,753 +0,0 @@ -\documentclass{article} -\usepackage{axiom} -\begin{document} -\title{\$SPAD/src/interp ht-util.boot} -\author{The Axiom Team} -\maketitle -\begin{abstract} -\end{abstract} -\eject -\tableofcontents -\eject -\section{License} -<<license>>= --- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd. --- All rights reserved. --- --- Redistribution and use in source and binary forms, with or without --- modification, are permitted provided that the following conditions are --- met: --- --- - Redistributions of source code must retain the above copyright --- notice, this list of conditions and the following disclaimer. --- --- - Redistributions in binary form must reproduce the above copyright --- notice, this list of conditions and the following disclaimer in --- the documentation and/or other materials provided with the --- distribution. --- --- - Neither the name of The Numerical ALgorithms Group Ltd. nor the --- names of its contributors may be used to endorse or promote products --- derived from this software without specific prior written permission. --- --- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS --- IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED --- TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A --- PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER --- OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, --- EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, --- PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR --- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF --- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING --- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS --- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -@ -<<*>>= -<<license>> - --- HyperTeX Utilities for generating basic Command pages ---)package "BOOT" - -$bcParseOnly := true - --- List of issued hypertex lines -$htLineList := nil - --- pointer to the page we are currently defining -$curPage := nil - --- List of currently active window named -$activePageList := nil - -htpDestroyPage(pageName) == - pageName in $activePageList => - SET(pageName, nil) - $activePageList := NREMOVE($activePageList, pageName) - -htpName htPage == --- GENSYM whose value is the page - ELT(htPage, 0) - -htpSetName(htPage, val) == - SETELT(htPage, 0, val) - -htpDomainConditions htPage == --- List of Domain conditions - ELT(htPage, 1) - -htpSetDomainConditions(htPage, val) == - SETELT(htPage, 1, val) - -htpDomainVariableAlist htPage == --- alist of pattern variables and conditions - ELT(htPage, 2) - -htpSetDomainVariableAlist(htPage, val) == - SETELT(htPage, 2, val) - -htpDomainPvarSubstList htPage == --- alist of user pattern variables to system vars - ELT(htPage, 3) - -htpSetDomainPvarSubstList(htPage, val) == - SETELT(htPage, 3, val) - -htpRadioButtonAlist htPage == --- alist of radio button group names and labels - ELT(htPage, 4) - -htpButtonValue(htPage, groupName) == - for buttonName in LASSOC(groupName, htpRadioButtonAlist htPage) repeat - (stripSpaces htpLabelInputString(htPage, buttonName)) = '"t" => - return buttonName - -htpSetRadioButtonAlist(htPage, val) == - SETELT(htPage, 4, val) - -htpInputAreaAlist htPage == --- Alist of input-area labels, and default values - ELT(htPage, 5) - -htpSetInputAreaAlist(htPage, val) == - SETELT(htPage, 5, val) - -htpAddInputAreaProp(htPage, label, prop) == - SETELT(htPage, 5, [[label, nil, nil, nil, :prop], :ELT(htPage, 5)]) - -htpPropertyList htPage == --- Association list of user-defined properties - ELT(htPage, 6) - -htpProperty(htPage, propName) == - LASSOC(propName, ELT(htPage, 6)) - -htpSetProperty(htPage, propName, val) == - pair := ASSOC(propName, ELT(htPage, 6)) - pair => RPLACD(pair, val) - SETELT(htPage, 6, [[propName, :val], :ELT(htPage, 6)]) - -htpLabelInputString(htPage, label) == --- value user typed as input string on page - props := LASSOC(label, htpInputAreaAlist htPage) - props and STRINGP (s := ELT(props,0)) => - s = '"" => s - trimString s - nil - -htpLabelFilteredInputString(htPage, label) == --- value user typed as input string on page - props := LASSOC(label, htpInputAreaAlist htPage) - props => - #props > 5 and ELT(props, 6) => - FUNCALL(SYMBOL_-FUNCTION ELT(props, 6), ELT(props, 0)) - replacePercentByDollar ELT(props, 0) - nil - -replacePercentByDollar s == fn(s,0,MAXINDEX s) where - fn(s,i,n) == - i > n => '"" - (m := charPosition(char "%",s,i)) > n => SUBSTRING(s,i,nil) - STRCONC(SUBSTRING(s,i,m - i),'"$",fn(s,m + 1,n)) - -htpSetLabelInputString(htPage, label, val) == -------------------> OBSELETE --- value user typed as input string on page - props := LASSOC(label, htpInputAreaAlist htPage) - props => SETELT(props, 0, STRINGIMAGE val) - nil - -htpLabelSpadValue(htPage, label) == --- Scratchpad value of parsed and evaled inputString, as (type . value) - props := LASSOC(label, htpInputAreaAlist htPage) - props => ELT(props, 1) - nil - -htpSetLabelSpadValue(htPage, label, val) == --- value user typed as input string on page - props := LASSOC(label, htpInputAreaAlist htPage) - props => SETELT(props, 1, val) - nil - -htpLabelErrorMsg(htPage, label) == --- error message associated with input area - props := LASSOC(label, htpInputAreaAlist htPage) - props => ELT(props, 2) - nil - -htpSetLabelErrorMsg(htPage, label, val) == --- error message associated with input area - props := LASSOC(label, htpInputAreaAlist htPage) - props => SETELT(props, 2, val) - nil - -htpLabelType(htPage, label) == --- either 'string or 'button - props := LASSOC(label, htpInputAreaAlist htPage) - props => ELT(props, 3) - nil - -htpLabelDefault(htPage, label) == --- default value for the input area - msg := htpLabelInputString(htPage, label) => - msg = '"t" => 1 - msg = '"nil" => 0 - msg - props := LASSOC(label, htpInputAreaAlist htPage) - props => - ELT(props, 4) - nil - - -htpLabelSpadType(htPage, label) == --- pattern variable for target domain for input area - props := LASSOC(label, htpInputAreaAlist htPage) - props => ELT(props, 5) - nil - -htpLabelFilter(htPage, label) == --- string to string mapping applied to input area strings before parsing - props := LASSOC(label, htpInputAreaAlist htPage) - props => ELT(props, 6) - nil - -htpPageDescription htPage == --- a list of all the commands issued to create the basic-command page - ELT(htPage, 7) - -htpSetPageDescription(htPage, pageDescription) == - SETELT(htPage, 7, pageDescription) - -htpAddToPageDescription(htPage, pageDescrip) == --------------> OBSELETE <----------- - SETELT(htPage, 7, nconc(nreverse COPY_-LIST pageDescrip, ELT(htPage, 7))) - -iht line == --- issue a single hyperteTeX line, or a group of lines - $newPage => nil - PAIRP line => - $htLineList := NCONC(nreverse mapStringize COPY_-LIST line, $htLineList) - $htLineList := [basicStringize line, :$htLineList] - -bcHt line == ---line = '"\##1" => harharhar() - iht line - PAIRP line => - if $newPage then htpAddToPageDescription($curPage, [['text, :line]]) - if $newPage then htpAddToPageDescription($curPage, [['text, line]]) - -bcIssueHt line == - PAIRP line => htMakePage1 line - iht line - -mapStringize l == - ATOM l => l - RPLACA(l, basicStringize CAR l) - RPLACD(l, mapStringize CDR l) - l - -basicStringize s == - STRINGP s => - s = '"\$" => '"\%" - s = '"{\em $}" => '"{\em \%}" - s - s = '_$ => '"\%" - PRINC_-TO_-STRING s - -stringize s == - STRINGP s => s - PRINC_-TO_-STRING s - -htInitPage(title, propList) == -----------------------------> OBSELETE---cannot return $curPage --- start defining a hyperTeX page - htInitPageNoScroll(propList, title) - htSayStandard '"\beginscroll " - $curPage - - ---htInitPageNoHeading(propList) == ------------------------> replaced by htInitPageNoScroll --- start defining a hyperTeX page --- $curPage := htpMakeEmptyPage(propList) --- if $saturn then $saturnPage := htpMakeEmptyPage(propList) --- $newPage := true --- $htLineList := nil --- $curPage - -htAddHeading(title) == -------------------------> OBSELETE - htNewPage title - $curPage - -htShowPage() == --- show the page which has been computed - htSayStandard '"\endscroll" - htShowPageNoScroll() - -htShowPageNoScroll() == -------------------------> OBSELETE --- show the page which has been computed - htSayStandard '"\autobuttons" - htpSetPageDescription($curPage, nreverse htpPageDescription $curPage) - $newPage := false - $htLineList := nil - htMakePage htpPageDescription $curPage - line := APPLY(function CONCAT, nreverse $htLineList) - issueHT line - endHTPage() - -htMakePage itemList == -------------------------> OBSELETE --- make a page given the description in itemList - if $newPage then htpAddToPageDescription($curPage, itemList) - htMakePage1 itemList - -htMakePage1 itemList == --- make a page given the description in itemList - for [itemType, :items] in itemList repeat - itemType = 'text => iht items - itemType = 'lispLinks => htLispLinks items - itemType = 'lispmemoLinks => htLispMemoLinks items - itemType = 'bcLinks => htBcLinks items ---> - itemType = 'bcLinksNS => htBcLinks(items,true) - itemType = 'bcLispLinks => htBcLispLinks items ---> - itemType = 'radioButtons => htRadioButtons items - itemType = 'bcRadioButtons => htBcRadioButtons items - itemType = 'inputStrings => htInputStrings items - itemType = 'domainConditions => htProcessDomainConditions items - itemType = 'bcStrings => htProcessBcStrings items - itemType = 'toggleButtons => htProcessToggleButtons items - itemType = 'bcButtons => htProcessBcButtons items - itemType = 'doneButton => htProcessDoneButton items - itemType = 'doitButton => htProcessDoitButton items - systemError ['"unknown itemType", itemType] - -htMakeErrorPage htPage == -------------------> OBSELETE - $newPage := false - $htLineList := nil - $curPage := htPage - htMakePage htpPageDescription htPage - line := APPLY(function CONCAT, nreverse $htLineList) - issueHT line - endHTPage() - -htQuote s == --- wrap quotes around a piece of hyperTeX - iht '"_"" - iht s - iht '"_"" - -htProcessToggleButtons buttons == - iht '"\newline\indent{5}\beginitems " - for [message, info, defaultValue, buttonName] in buttons repeat - if NULL LASSOC(buttonName, htpInputAreaAlist $curPage) then - setUpDefault(buttonName, ['button, defaultValue]) - iht ['"\item{\em\inputbox[", htpLabelDefault($curPage, buttonName), '"]{", - buttonName, '"}{\htbmfile{pick}}{\htbmfile{unpick}}\space{}"] - bcIssueHt message - iht '"\space{}}" - bcIssueHt info - iht '"\enditems\indent{0} " - -htProcessBcButtons buttons == - for [defaultValue, buttonName] in buttons repeat - if NULL LASSOC(buttonName, htpInputAreaAlist $curPage) then - setUpDefault(buttonName, ['button, defaultValue]) - k := htpLabelDefault($curPage,buttonName) - k = 0 => iht ['"\off{",buttonName,'"}"] - k = 1 => iht ['"\on{", buttonName,'"}"] - iht ['"\inputbox[", htpLabelDefault($curPage, buttonName), '"]{", - buttonName, '"}{\htbmfile{pick}}{\htbmfile{unpick}}"] - -htProcessBcStrings strings == ----------------------> OBSELETE <------------------------ - for [numChars, default, stringName, spadType, :filter] in strings repeat - mess2 := '"" - if NULL LASSOC(stringName, htpInputAreaAlist $curPage) then - setUpDefault(stringName, ['string, default, spadType, filter]) - if htpLabelErrorMsg($curPage, stringName) then - iht ['"\centerline{{\em ", htpLabelErrorMsg($curPage, stringName), '"}}"] - mess2 := CONCAT(mess2, bcSadFaces()) - htpSetLabelErrorMsg($curPage, stringName, nil) - iht ['"\inputstring{", stringName, '"}{", - numChars, '"}{", htpLabelDefault($curPage,stringName), '"} ", mess2] - -bcSadFaces() == - '"\space{1}{\em\htbitmap{error}\htbitmap{error}\htbitmap{error}}" - -htLispLinks(links,:option) == - [links,options] := beforeAfter('options,links) - indent := LASSOC('indent,options) or 5 - iht '"\newline\indent{" - iht stringize indent - iht '"}\beginitems" - for [message, info, func, :value] in links repeat - iht '"\item[" - call := (IFCAR option => '"\lispmemolink"; '"\lispdownlink") - htMakeButton(call,message, mkCurryFun(func, value)) - iht ['"]\space{}"] - bcIssueHt info - iht '"\enditems\indent{0} " - -htLispMemoLinks(links) == htLispLinks(links,true) - -htBcLinks(links,:options) == --------------------------> OBSELETE - skipStateInfo? := IFCAR options - [links,options] := beforeAfter('options,links) - for [message, info, func, :value] in links repeat - htMakeButton('"\lispdownlink",message, - mkCurryFun(func, value),skipStateInfo?) - bcIssueHt info - -htBcLispLinks links == --------------------------> OBSELETE - [links,options] := beforeAfter('options,links) - for [message, info, func, :value] in links repeat - htMakeButton('"\lisplink",message, mkCurryFun(func, value)) - bcIssueHt info - -beforeAfter(x,u) == [[y for [y,:r] in tails u while x ^= y],r] - -mkCurryFun(fun, val) == - name := GENTEMP() - code := - ['DEFUN, name, '(arg), ['APPLY, MKQ fun, ['CONS, 'arg, MKQ val]]] - EVAL code - name - -htRadioButtons [groupName, :buttons] == - htpSetRadioButtonAlist($curPage, [[groupName, :buttonNames buttons], - : htpRadioButtonAlist $curPage]) - boxesName := GENTEMP() - iht ['"\newline\indent{5}\radioboxes{", boxesName, - '"}{\htbmfile{pick}}{\htbmfile{unpick}}\beginitems "] - defaultValue := '"1" - for [message, info, buttonName] in buttons repeat - if NULL LASSOC(buttonName, htpInputAreaAlist $curPage) then - setUpDefault(buttonName, ['button, defaultValue]) - defaultValue := '"0" - iht ['"\item{\em\radiobox[", htpLabelDefault($curPage, buttonName), '"]{", - buttonName, '"}{",boxesName, '"}\space{}"] - bcIssueHt message - iht '"\space{}}" - bcIssueHt info - iht '"\enditems\indent{0} " - -htBcRadioButtons [groupName, :buttons] == - htpSetRadioButtonAlist($curPage, [[groupName, :buttonNames buttons], - : htpRadioButtonAlist $curPage]) - boxesName := GENTEMP() - iht ['"\radioboxes{", boxesName, - '"}{\htbmfile{pick}}{\htbmfile{unpick}} "] - defaultValue := '"1" - for [message, info, buttonName] in buttons repeat - if NULL LASSOC(buttonName, htpInputAreaAlist $curPage) then - setUpDefault(buttonName, ['button, defaultValue]) - defaultValue := '"0" - iht ['"{\em\radiobox[", htpLabelDefault($curPage, buttonName), '"]{", - buttonName, '"}{",boxesName, '"}"] - bcIssueHt message - iht '"\space{}}" - bcIssueHt info - -setUpDefault(name, props) == ----------------> OBSELETE <---------------- - htpAddInputAreaProp($curPage, name, props) - -buttonNames buttons == - [buttonName for [.,., buttonName] in buttons] - -htInputStrings strings == - iht '"\newline\indent{5}\beginitems " - for [mess1, mess2, numChars, default, stringName, spadType, :filter] - in strings repeat - if NULL LASSOC(stringName, htpInputAreaAlist $curPage) then - setUpDefault(stringName, ['string, default, spadType, filter]) - if htpLabelErrorMsg($curPage, stringName) then - iht ['"\centerline{{\em ", htpLabelErrorMsg($curPage, stringName), '"}}"] - - mess2 := CONCAT(mess2, bcSadFaces()) - htpSetLabelErrorMsg($curPage, stringName, nil) - iht '"\item " - bcIssueHt mess1 - iht ['"\inputstring{", stringName, '"}{", - numChars, '"}{", htpLabelDefault($curPage,stringName), '"} "] - bcIssueHt mess2 - iht '"\enditems\indent{0}\newline " - -htProcessDomainConditions condList == - htpSetDomainConditions($curPage, renamePatternVariables condList) - htpSetDomainVariableAlist($curPage, computeDomainVariableAlist()) - -renamePatternVariables condList == - htpSetDomainPvarSubstList($curPage, - renamePatternVariables1(condList, nil, $PatternVariableList)) - substFromAlist(condList, htpDomainPvarSubstList $curPage) - -renamePatternVariables1(condList, substList, patVars) == - null condList => substList - [cond, :restConds] := condList - cond is ['isDomain, pv, pattern] or cond is ['ofCategory, pv, pattern] - or cond is ['Satisfies, pv, cond] => - if pv = $EmptyMode then nsubst := substList - else nsubst := [[pv, :car patVars], :substList] - renamePatternVariables1(restConds, nsubst, rest patVars) - substList - -substFromAlist(l, substAlist) == - for [pvar, :replace] in substAlist repeat - l := SUBST(replace, pvar, l) - l - -computeDomainVariableAlist() == - [[pvar, :pvarCondList pvar] for [., :pvar] in - htpDomainPvarSubstList $curPage] - -pvarCondList pvar == - nreverse pvarCondList1([pvar], nil, htpDomainConditions $curPage) - -pvarCondList1(pvarList, activeConds, condList) == - null condList => activeConds - [cond, : restConds] := condList - cond is [., pv, pattern] and pv in pvarList => - pvarCondList1(nconc(pvarList, pvarsOfPattern pattern), - [cond, :activeConds], restConds) - pvarCondList1(pvarList, activeConds, restConds) - -pvarsOfPattern pattern == - NULL LISTP pattern => nil - [pvar for pvar in rest pattern | pvar in $PatternVariableList] - -htMakeTemplates(templateList, numLabels) == - templateList := [templateParts template for template in templateList] - [[substLabel(i, template) for template in templateList] - for i in 1..numLabels] where substLabel(i, template) == - PAIRP template => - INTERN CONCAT(first template, PRINC_-TO_-STRING i, rest template) - template - -templateParts template == - NULL STRINGP template => template - i := SEARCH('"%l", template) - null i => template - [SUBSEQ(template, 0, i), : SUBSEQ(template, i+2)] - -htMakeDoneButton(message, func) == - bcHt '"\newline\vspace{1}\centerline{" - if message = '"Continue" then - bchtMakeButton('"\lispdownlink", "\ContinueBitmap", func) - else - bchtMakeButton('"\lispdownlink",CONCAT('"\box{", message, '"}"), func) - bcHt '"} " - -htProcessDoneButton [label , func] == - iht '"\newline\vspace{1}\centerline{" - - if label = '"Continue" then - htMakeButton('"\lispdownlink", "\ContinueBitmap", func) - else if label = '"Push to enter names" then - htMakeButton('"\lispdownlink",'"\ControlBitmap{ClickToSet}", func) - else - htMakeButton('"\lispdownlink", CONCAT('"\box{", label, '"}"), func) - - iht '"} " - -htMakeButton(htCommand, message, func,:options) == -----------> OBSELETE <---------------------------------- - skipStateInfo? := IFCAR options - iht [htCommand, '"{"] - bcIssueHt message - skipStateInfo? => - iht ['"}{(|htDoneButton| '|", func, '"| ",htpName $curPage, '")}"] - iht ['"}{(|htDoneButton| '|", func, '"| (PROGN "] - for [id, ., ., ., type, :.] in htpInputAreaAlist $curPage repeat - iht ['"(|htpSetLabelInputString| ", htpName $curPage, '"'|", id, '"| "] - if type = 'string then - iht ['"_"\stringvalue{", id, '"}_""] - else - iht ['"_"\boxvalue{", id, '"}_""] - iht '") " - iht [htpName $curPage, '"))}"] - -bchtMakeButton(htCommand, message, func) == - bcHt [htCommand, '"{", message, - '"}{(|htDoneButton| '|", func, '"| (PROGN "] - for [id, ., ., ., type, :.] in htpInputAreaAlist $curPage repeat - bcHt ['"(|htpSetLabelInputString| ", htpName $curPage, '"'|", id, '"| "] - if type = 'string then - bcHt ['"_"\stringvalue{", id, '"}_""] - else - bcHt ['"_"\boxvalue{", id, '"}_""] - bcHt '") " - bcHt [htpName $curPage, '"))} "] - -htProcessDoitButton [label, command, func] == - fun := mkCurryFun(func, [command]) - iht '"\newline\vspace{1}\centerline{" - htMakeButton('"\lispcommand", CONCAT('"\box{", label, '"}"), fun) - iht '"} " - iht '"\vspace{2}{Select \ \UpButton{} \ to go back one page.}" - iht '"\newline{Select \ \ExitButton{QuitPage} \ to remove this window.}" - -htMakeDoitButton(label, command) == - -- use bitmap button if just plain old "Do It" - if label = '"Do It" then - bcHt '"\newline\vspace{1}\centerline{\lispcommand{\DoItBitmap}{(|doDoitButton| " - else - bcHt ['"\newline\vspace{1}\centerline{\lispcommand{\box{", label, - '"}}{(|doDoitButton| "] - bcHt htpName $curPage - bcHt ['" _"", htEscapeString command, '"_""] - bcHt '")}}" - - bcHt '"\vspace{2}{Select \ \UpButton{} \ to go back one page.}" - bcHt '"\newline{Select \ \ExitButton{QuitPage} \ to remove this window.}" - -doDoitButton(htPage, command) == - executeInterpreterCommand command - -executeInterpreterCommand command == - PRINC command - TERPRI() - ncSetCurrentLine(command) - CATCH('SPAD__READER, parseAndInterpret command) - PRINC MKPROMPT() - FINISH_-OUTPUT() - -htDoneButton(func, htPage) == - typeCheckInputAreas htPage => - htMakeErrorPage htPage - NULL FBOUNDP func => - systemError ['"unknown function", func] - FUNCALL(SYMBOL_-FUNCTION func, htPage) - -typeCheckInputAreas htPage == - -- This needs to be severly beefed up - inputAlist := nil - errorCondition := false - for entry in htpInputAreaAlist htPage - | entry is [stringName, ., ., ., 'string, ., spadType, filter] repeat - condList := - LASSOC(LASSOC(spadType,htpDomainPvarSubstList htPage), - htpDomainVariableAlist htPage) - string := htpLabelFilteredInputString(htPage, stringName) - $bcParseOnly => - null ncParseFromString string => - htpSetLabelErrorMsg(htPage, '"Syntax Error", '"Syntax Error") - nil - val := checkCondition(htpLabelInputString(htPage, stringName), - string, condList) - STRINGP val => - errorCondition := true - htpSetLabelErrorMsg(htPage, stringName, val) - htpSetLabelSpadValue(htPage, stringName, val) - errorCondition - -checkCondition(s1, string, condList) == - condList is [['Satisfies, pvar, pred]] => - val := FUNCALL(pred, string) - STRINGP val => val - ['(String), :wrap s1] - condList isnt [['isDomain, pvar, pattern]] => - systemError '"currently invalid domain condition" - pattern is '(String) => ['(String), :wrap s1] - val := parseAndEval string - STRINGP val => - val = '"Syntax Error " => '"Error: Syntax Error " - condErrorMsg pattern - [type, : data] := val - newType := CATCH('SPAD__READER, resolveTM(type, pattern)) - null newType => - condErrorMsg pattern - coerceInt(val, newType) - -condErrorMsg type == - typeString := form2String type - if PAIRP typeString then typeString := APPLY(function CONCAT, typeString) - CONCAT('"Error: Could not make your input into a ", typeString) - -parseAndEval string == - $InteractiveMode :fluid := true - $BOOT: fluid := NIL - $SPAD: fluid := true - $e:fluid := $InteractiveFrame - $QuietCommand:local := true - parseAndEval1 string - -parseAndEval1 string == - syntaxError := false - pform := - $useNewParser => - v := applyWithOutputToString('ncParseFromString, [string]) - CAR v => CAR v - syntaxError := true - CDR v - oldParseString string - syntaxError => - '"Syntax Error " - pform => - val := applyWithOutputToString('processInteractive, [pform, nil]) - CAR val => CAR val - '"Type Analysis Error" - nil - -oldParseString string == - tree := applyWithOutputToString('string2SpadTree, [string]) - CAR tree => parseTransform postTransform CAR tree - CDR tree - -makeSpadCommand(:l) == - opForm := CONCAT(first l, '"(") - lastArg := last l - l := rest l - argList := nil - for arg in l while arg ^= lastArg repeat - argList := [CONCAT(arg, '", "), :argList] - argList := nreverse [lastArg, :argList] - CONCAT(opForm, APPLY(function CONCAT, argList), '")") - -htMakeInputList stringList == --- makes an input form for constructing a list - lastArg := last stringList - argList := nil - for arg in stringList while arg ^= lastArg repeat - argList := [CONCAT(arg, '", "), :argList] - argList := nreverse [lastArg, :argList] - bracketString APPLY(function CONCAT, argList) - - --- predefined filter strings -bracketString string == CONCAT('"[",string,'"]") - -quoteString string == CONCAT('"_"", string, '"_"") - -$funnyQuote := char 127 -$funnyBacks := char 128 - -htEscapeString str == - str := SUBSTITUTE($funnyQuote, char '_", str) - SUBSTITUTE($funnyBacks, char '_\, str) - -unescapeStringsInForm form == - STRINGP form => - str := NSUBSTITUTE(char '_", $funnyQuote, form) - NSUBSTITUTE(char '_\, $funnyBacks, str) - CONSP form => - unescapeStringsInForm CAR form - unescapeStringsInForm CDR form - form - form - - - - - -@ -\eject -\begin{thebibliography}{99} -\bibitem{1} nothing -\end{thebibliography} -\end{document} |