From: Raimon Grau Date: Sat, 15 Dec 2012 00:45:30 +0000 (+0100) Subject: re-added compile-test X-Git-Url: http://repo.macrolet.net/gitweb/?a=commitdiff_plain;h=ecdc7afa83611b0effe71862c8269d7a487d05bd;p=jscl.git re-added compile-test --- diff --git a/lispstrack.lisp b/lispstrack.lisp index ba97bd6..cc3d183 100644 --- a/lispstrack.lisp +++ b/lispstrack.lisp @@ -93,11 +93,31 @@ body can access to the local environment through the variable env" (define-compilation debug (form) (format nil "console.log(~a)" (ls-compile form env))) +(defun compile-test () + (with-open-file (in "test.lisp") + (with-open-file (out "test.js" :direction :output :if-exists :supersede) + (loop + for x = (read in nil) while x + do (write-string (ls-compile x) out))))) + (define-compilation while (pred &rest body) (format nil "(function(){while(~a){~a}})() " (ls-compile pred env) (ls-compile-sexps body env))) +(define-compilation + (x y) + (concat "((" (ls-compile x env) ") + (" (ls-compile y env) "))")) + +(define-compilation - (x y) + (concat "((" (ls-compile x env) ") - (" (ls-compile y env) "))")) + +(define-compilation * (x y) + (concat "((" (ls-compile x env) ") * (" (ls-compile y env) "))")) + +(define-compilation / (x y) + (concat "((" (ls-compile x env) ") / (" (ls-compile y env) "))")) + + (defparameter *env* '()) (defparameter *env-fun* '()) @@ -110,5 +130,6 @@ body can access to the local environment through the variable env" (let ((compiler-func (second (assoc (car sexp) *compilations*)))) (if compiler-func (apply compiler-func env (cdr sexp)) + (funcall (ls-compile (car sexp) env) ) ;; funcall )))))