diff options
Diffstat (limited to 'src/interp')
-rw-r--r-- | src/interp/parsing.lisp | 34 | ||||
-rw-r--r-- | src/interp/spad-parser.boot | 29 | ||||
-rw-r--r-- | src/interp/spad.lisp | 25 |
3 files changed, 32 insertions, 56 deletions
diff --git a/src/interp/parsing.lisp b/src/interp/parsing.lisp index 828de1db..a6a321e7 100644 --- a/src/interp/parsing.lisp +++ b/src/interp/parsing.lisp @@ -243,38 +243,10 @@ the stack, then stack a NIL. Return the value of prod." (defun action (dothis) (or dothis t)) -; 3A. Manipulating the token stack and reading tokens - -; This section is broken up into 3 levels: -; -; (0) String grabbing: Match String, Match Advance String -; (1) Token handling: Current Token, Next Token, Advance Token -; (2) Character handling: Current Char, Next Char, Advance Char -; (3) Line handling: Next Line, Print Next Line -; (X) Random Stuff - -(defun match-advance-special (str) - (and (|matchToken| (|currentToken|) 'special-char (character str)) - (action (|advanceToken|)))) - -(defun match-special (str) - (|matchToken| (|currentToken|) 'special-char (character str))) - -(defun match-keyword-next (str) - (|matchToken| (|nextToken|) 'keyword (intern str))) - -(defun initial-substring-p (part whole) - "Returns length of part if part matches initial segment of whole." - (let ((x (string<= part whole))) - (and x (= x (length part)) x))) - ; 3B. Error handling (defparameter line nil) -(defun termchr () "Is CHR a terminating character?" - (|findChar| (|currentChar|) " *,;<>()[]/\\")) - ; 5. Routines for inspecting and resetting total I/O system state ; ; The package largely assumes that: @@ -310,9 +282,3 @@ the stack, then stack a NIL. Return the value of prod." (DIGITP (ELT S I))))) (READ-FROM-STRING S t nil :start 1) NIL)) - -(defun |dollarTran| (dom rand) - (let ((eltWord (if |$InteractiveMode| '|$elt| '|elt|))) - (if (and (not (atom rand)) (cdr rand)) - (cons (list eltWord dom (car rand)) (cdr rand)) - (list eltWord dom rand)))) diff --git a/src/interp/spad-parser.boot b/src/interp/spad-parser.boot index 3e821cda..2799d88f 100644 --- a/src/interp/spad-parser.boot +++ b/src/interp/spad-parser.boot @@ -420,6 +420,10 @@ parseCommand() == parseTokenOption() == matchAdvanceString '")" and compulsorySyntax PARSE_-TokenList() +dollarTran(dom,x) == + x is [.,:.] => [['elt,dom,first x],:rest x] + ['elt,dom,x] + parseQualification() == matchAdvanceString '"$" => compulsorySyntax parsePrimary1() @@ -931,6 +935,31 @@ parseSpecialCommand() == --% +translateSpad x == + $Index: local := 0 + _*PRETTY_-PRINT_*: local := true + $MACROASSOC: local := nil + $NEWSPAD: local := true + $currentFunction: local := nil + $topOp: local := nil + $semanticErrorStack: local := [] + $warningStack: local := [] + $returnMode: local := $EmptyMode + $leaveLevelStack: local := [] + $insideFunctorIfTrue: local := false + $insideExpressionIfTrue: local := false + $insideCoerceInteractiveHardIfTrue: local := false + $insideWhereIfTrue: local := false + $insideCategoryIfTrue: local := false + $insideCapsuleFunctionIfTrue: local := false + $form: local := nil + $e: local := $EmptyEnvironment + $genSDVar: local := 0 + $previousTime: local := TEMPUS_-FUGIT() + compileParseTree x + +--% + ++ Given a pathname to a source file containing Spad code, returns ++ a list of (old) AST objects representing the toplevel expressions ++ in that file. diff --git a/src/interp/spad.lisp b/src/interp/spad.lisp index 51127730..cc25cde5 100644 --- a/src/interp/spad.lisp +++ b/src/interp/spad.lisp @@ -130,7 +130,7 @@ (let ((parseout (|popStack1|)) ) (when parseout (let ((|$OutputStream| out-stream)) - (S-PROCESS parseout)) + (|translateSpad| parseout)) (format out-stream "~&"))) ;(IOClear in-stream out-stream) )))) @@ -150,7 +150,7 @@ (|addBinding| '|$DomainsInScope| proplist (|addBinding| '|$Information| NIL (COPY-TREE |$InitialModemapFrame|)))) - (RETURN (PROGN (S-PROCESS X) NIL)))) + (RETURN (PROGN (|translateSpad| X) NIL)))) ;; NIL needed below since END\_UNIT is not generated by current parser @@ -275,25 +275,6 @@ (defun \,max (x y) (max x y)) (defun \,min (x y) (min x y)) -(defun S-PROCESS (X) - (let ((|$Index| 0) - (*print-pretty* t) - ($MACROASSOC ()) - ($NEWSPAD T) - |$currentFunction| - |$topOp| - (|$semanticErrorStack| ()) - (|$warningStack| ()) - (|$returnMode| |$EmptyMode|) - (|$leaveLevelStack| ()) - |$insideFunctorIfTrue| |$insideExpressionIfTrue| - |$insideCoerceInteractiveHardIfTrue| |$insideWhereIfTrue| - |$insideCategoryIfTrue| |$insideCapsuleFunctionIfTrue| |$form| - (|$e| |$EmptyEnvironment|) - (|$genSDVar| 0) - (|$previousTime| (TEMPUS-FUGIT))) - (|compileParseTree| X))) - (MAKEPROP 'END_UNIT 'KEY T) (defun |process| (x) @@ -301,7 +282,7 @@ (SETQ DEBUGMODE 'NO) (SPAD_SYNTAX_ERROR) (if |$InteractiveMode| (|spadThrow|)) - (S-PROCESS x)))) + (|translateSpad| x)))) (defun INITIALIZE () (init-boot/spad-reader) |