diff options
-rw-r--r-- | src/ChangeLog | 10 | ||||
-rw-r--r-- | src/interp/Makefile.in | 6 | ||||
-rw-r--r-- | src/interp/bootlex.lisp | 102 | ||||
-rw-r--r-- | src/interp/lexing.boot | 42 | ||||
-rw-r--r-- | src/interp/spad.lisp | 2 |
5 files changed, 54 insertions, 108 deletions
diff --git a/src/ChangeLog b/src/ChangeLog index b997cbdf..6c61c356 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,5 +1,15 @@ 2012-05-20 Gabriel Dos Reis <gdr@cs.tamu.edu> + * interp/lexing.boot (getDecimalNumberToken): New. + (getIntegerInRadix): Likewise. + (getSpadIntegerToken): Likewise. + (getToken): Use it. + * interp/Makefile.in (bootlex.$(FASLEXT)): Remove rule. + (OBJS): Do not include it. + * interp/bootlex.lisp: Remove. + +2012-05-20 Gabriel Dos Reis <gdr@cs.tamu.edu> + * interp/spad-parser.boot (parseSexpr1): Simplify. (parseDara): Likewise. Do not set LABLASOC. * interp/bootlex.lisp (PRINT-DEFUN): Remove. diff --git a/src/interp/Makefile.in b/src/interp/Makefile.in index f9e427d9..5c8aa886 100644 --- a/src/interp/Makefile.in +++ b/src/interp/Makefile.in @@ -101,7 +101,7 @@ OBJS= boot-pkg.$(FASLEXT) types.$(FASLEXT) \ server.$(FASLEXT) setvars.$(FASLEXT) \ sfsfun-l.$(FASLEXT) sfsfun.$(FASLEXT) \ slam.$(FASLEXT) \ - preparse.$(FASLEXT) bootlex.$(FASLEXT) \ + preparse.$(FASLEXT) \ spad.$(FASLEXT) termrw.$(FASLEXT) \ trace.$(FASLEXT) word.$(FASLEXT) \ fortcall.$(FASLEXT) i-parser.$(FASLEXT) \ @@ -320,8 +320,6 @@ spad-parser.$(FASLEXT): parse.$(FASLEXT) preparse.$(FASLEXT) parse.$(FASLEXT): parsing.$(FASLEXT) postpar.$(FASLEXT) packtran.$(FASLEXT): sys-macros.$(FASLEXT) postpar.$(FASLEXT): macros.$(FASLEXT) -bootlex.$(FASLEXT): preparse.$(FASLEXT) macros.$(FASLEXT) \ - nlib.$(FASLEXT) sys-globals.$(FASLEXT) newaux.$(FASLEXT): macros.$(FASLEXT) preparse.$(FASLEXT): parsing.$(FASLEXT) parsing.$(FASLEXT): lexing.$(FASLEXT) macros.$(FASLEXT) @@ -355,7 +353,7 @@ dq.$(FASLEXT): types.$(FASLEXT) ## General support and utilities. daase.$(FASLEXT): sys-utility.$(FASLEXT) debug.$(FASLEXT): macros.$(FASLEXT) parsing.$(FASLEXT) -spad.$(FASLEXT): bootlex.$(FASLEXT) postpar.$(FASLEXT) debug.$(FASLEXT) +spad.$(FASLEXT): spad-parser.$(FASLEXT) postpar.$(FASLEXT) debug.$(FASLEXT) monitor.$(FASLEXT): macros.$(FASLEXT) sfsfun-l.$(FASLEXT): sys-macros.$(FASLEXT) trace.$(FASLEXT): debug.$(FASLEXT) diff --git a/src/interp/bootlex.lisp b/src/interp/bootlex.lisp deleted file mode 100644 index b7a22269..00000000 --- a/src/interp/bootlex.lisp +++ /dev/null @@ -1,102 +0,0 @@ -;; Copyright (c) 1991-2002, The Numerical Algorithms Group Ltd. -;; All rights reserved. -;; Copyright (C) 2007-2012, Gabriel Dos Reis. -;; 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. - - -; NAME: BootLex.lisp -; PURPOSE: Parsing support routines for Boot and Spad code -; CONTENTS: -; -; 0. Global parameters -; 1. BOOT File Handling -; 2. BOOT Line Handling -; 3. BOOT Token Handling -; 4. BOOT Token Parsing Actions -; 5. BOOT Error Handling - -(import-module "sys-globals") -(IMPORT-MODULE "preparse") -(IMPORT-MODULE "macros") -(IMPORT-MODULE "nlib") -(in-package "BOOT") - -; *** 3. BOOT Token Handling *** - -;; -*- Parse an integer number -*- -;; The number may be written in plain format, where the radix -;; is implicitly taken to be 10. Or the spelling can explicitly -;; specify a radix. That radix can be anything in the range 2..36 - -;; Subroutine GET-NUMBER-TOKEN-MAYBE-WITH-RADIX. -;; Read a the characters of a decimal integer and returns its -;; value. -(defun get-decimal-number-token (buf) - (tagbody lp - (suffix (|currentChar|) buf) - (let ((next-chr (|nextChar|))) - (cond ((digitp next-chr) - (|advanceChar!|) - (go lp))))) - (parse-integer buf)) - -;; Subroutine of GET-NUMBER-TOKEN-MAYBE-WITH-RADIX. -;; We just read the radix of an integer number; parse the -;; digits forming that integer token. -(defun get-integer-in-radix (buf r) - (unless (> r 1) - (spad_syntax_error)) - (let ((mark (1+ (size buf)))) - (tagbody lp - (suffix (|currentChar|) buf) - (let* ((nxt (|nextChar|)) - (dig (|rdigit?| nxt))) - (when dig - (unless (< dig r) - (spad_syntax_error)) - (|advanceChar!|) - (go lp)))) - (parse-integer buf :start mark :radix r))) - -(defun is-radix-char (c) - (or (eql c #\r) - (eql c #\R))) - -;; Parse an integer token, written either implicitly in decimal form, -;; or explicitly specified radix. -(defun get-spad-integer-token (token) - (let* ((buf (make-adjustable-string 0)) - (val (get-decimal-number-token buf))) - (|advanceChar!|) - (when (is-radix-char (|currentChar|)) - (setq val (get-integer-in-radix buf val)) - (|advanceChar!|)) - (|tokenInstall| val 'number token (size buf)))) diff --git a/src/interp/lexing.boot b/src/interp/lexing.boot index 940f0e4d..3143b23c 100644 --- a/src/interp/lexing.boot +++ b/src/interp/lexing.boot @@ -189,6 +189,46 @@ tokenInstall(sym,typ,tok,nonblank == true) == tokenNonblank?(tok) := nonblank tok +++ Subroutine of getSpadIntegerToken. +++ Read a the characters of a decimal integer and returns its value. +getDecimalNumberToken buf == + repeat + SUFFIX(currentChar(),buf) + not DIGITP nextChar() => leave nil + advanceChar!() + readIntegerIfCan buf + +++ Subroutine of getSpadIntegerToken. +++ We just read the radix of an integer number; parse the +++ digits forming that integer token. +getIntegerInRadix(buf,r) == + r < 2 => SPAD__SYNTAX__ERROR() + mark := #buf + 1 + repeat + SUFFIX(currentChar(),buf) + d := rdigit? nextChar() + d = nil => leave nil + d >= r => SPAD__SYNTAX__ERROR() + advanceChar!() + PARSE_-INTEGER(buf,KEYWORD::START,mark,KEYWORD::RADIX,r) + +radixSuffix? c == + c = char "r" or c = char "R" + +++ Parse an integer token, written either implicitly in decimal form, +++ or explicitly specified radix. The number may be written in plain +++ format, where the radix is implicitly taken to be 10. Or the spelling +++ can explicitly specify a radix. That radix can be anything +++ in the range 2..36 +getSpadIntegerToken tok == + buf := MAKE_-ADJUSTABLE_-STRING 0 + val := getDecimalNumberToken buf + advanceChar!() + if radixSuffix? currentChar() then + val := getIntegerInRadix(buf,val) + advanceChar!() + tokenInstall(val,'NUMBER,tok,#buf) + getNumberToken tok == buf := nil repeat @@ -214,7 +254,7 @@ getToken tok == getIdentifier(tok,true) tt is 'ARGUMENT_-DESIGNATOR => getArgumentDesignator tok tt is 'ID => getIdentifier(tok,false) - tt is 'NUM => GET_-SPAD_-INTEGER_-TOKEN tok + tt is 'NUM => getSpadIntegerToken tok tt is 'STRING => getSpadString tok tt is 'SPECIAL_-CHAR => getSpecial tok getGliph(tok,tt) diff --git a/src/interp/spad.lisp b/src/interp/spad.lisp index a5cc55e6..51127730 100644 --- a/src/interp/spad.lisp +++ b/src/interp/spad.lisp @@ -35,7 +35,7 @@ ; NAME: Scratchpad Package ; PURPOSE: This is an initialization and system-building file for Scratchpad. -(IMPORT-MODULE "bootlex") +(IMPORT-MODULE "spad-parser") (import-module "postpar") (import-module "debug") (in-package "BOOT") |