From d6cff3e7f183719f080abfd5b18577def7dcf640 Mon Sep 17 00:00:00 2001 From: David Vazquez Date: Tue, 18 Dec 2012 02:14:13 +0000 Subject: [PATCH] Progresses to bootstrap --- lispstrack.lisp | 29 ++++++++++++++++++++++++----- test.lisp | 19 +++++++++++++++++++ 2 files changed, 43 insertions(+), 5 deletions(-) diff --git a/lispstrack.lisp b/lispstrack.lisp index 9e864b5..f034041 100644 --- a/lispstrack.lisp +++ b/lispstrack.lisp @@ -1,3 +1,9 @@ +(defun ensure-list (x) + (if (listp x) + x + (list x))) + + (defun !reduce (func list initial) (if (null list) initial @@ -15,7 +21,12 @@ ,@body)) (defun concat-two (s1 s2) - (concatenate 'string s1 s2))) + (concatenate 'string s1 s2)) + + (defun setcar (cons new) + (setf (car cons) new)) + (defun setcdr (cons new) + (setf (cdr cons) new))) (defvar *newline* (string (code-char 10))) @@ -72,7 +83,7 @@ (defun %read-char (stream) (and (< (cdr stream) (length (car stream))) (prog1 (char (car stream) (cdr stream)) - (incf (cdr stream))))) + (setcdr stream (1+ (cdr stream)))))) (defun whitespacep (ch) (or (char= ch #\space) (char= ch #\newline) (char= ch #\tab))) @@ -172,7 +183,7 @@ (let ((string (read-until stream #'terminalp))) (if (every #'digit-char-p string) (parse-integer string) - (intern (string-upcase string))))))))) + (intern (string-upcase string)))))))) (defun ls-read-from-string (string) (ls-read (make-string-stream string))) @@ -340,8 +351,9 @@ `((lambda () ,@body))) (define-transformation let (bindings &rest body) - `((lambda ,(mapcar 'car bindings) ,@body) - ,@(mapcar 'cadr bindings))) + (let ((bindings (mapcar #'ensure-list bindings))) + `((lambda ,(mapcar 'car bindings) ,@body) + ,@(mapcar 'cadr bindings)))) ;;; A little backquote implementation without optimizations of any ;;; kind for lispstrack. @@ -416,6 +428,13 @@ (define-compilation cdr (x) (concat "(" (ls-compile x env fenv) ").cdr")) +(define-compilation setcar (x new) + (concat "((" (ls-compile x env fenv) ").car = " (ls-compile new env fenv) ")")) + +(define-compilation setcdr (x new) + (concat "((" (ls-compile x env fenv) ").cdr = " (ls-compile new env fenv) ")")) + + (define-compilation make-symbol (name) (concat "{name: " (ls-compile name env fenv) "}")) diff --git a/test.lisp b/test.lisp index 1f12dc5..7d06431 100644 --- a/test.lisp +++ b/test.lisp @@ -167,6 +167,13 @@ (or ,@(cdr forms)))))) +(defmacro prog1 (form &rest body) + (let ((value (make-symbol "VALUE"))) + `(let ((,value ,form)) + ,@body + ,value))) + + (defun char= (x y) (= x y)) @@ -183,5 +190,17 @@ (and (< (cdr stream) (length (car stream))) (char (car stream) (cdr stream)))) +;; (defun %read-char (stream) +;; (and (< (cdr stream) (length (car stream))) +;; (prog1 (char (car stream) (cdr stream)) +;; (setcdr stream (1+ (cdr stream)))))) + (defun whitespacep (ch) (or (char= ch #\space) (char= ch #\newline) (char= ch #\tab))) + +;; (defun skip-whitespaces (stream) +;; (let (ch) +;; (setq ch (%peek-char stream)) +;; (while (and ch (whitespacep ch)) +;; (%read-char stream) +;; (setq ch (%peek-char stream))))) -- 1.7.10.4