Add lambda-lists with &rest support
authorDavid Vazquez <davazp@gmail.com>
Sun, 16 Dec 2012 00:27:45 +0000 (00:27 +0000)
committerDavid Vazquez <davazp@gmail.com>
Sun, 16 Dec 2012 00:27:45 +0000 (00:27 +0000)
lispstrack.lisp
test.lisp

index 16be306..883d25e 100644 (file)
           (ls-compile true env fenv)
           (ls-compile false env fenv)))
 
-(define-compilation lambda (args &rest body)
-  (let ((new-env (extend-env args env)))
-    (concat "(function ("
-           (join (mapcar (lambda (x) (lookup-variable x new-env))
-                          args)
-                  ",")
-           "){
+;;; Return the required args of a lambda list
+(defun lambda-list-required-argument (lambda-list)
+  (if (or (null lambda-list) (eq (car lambda-list) '&rest))
+      nil
+      (cons (car lambda-list) (lambda-list-required-argument (cdr lambda-list)))))
+
+(defun lambda-list-rest-argument (lambda-list)
+  (second (member '&rest lambda-list)))
+
+(define-compilation lambda (lambda-list &rest body)
+  (let ((required-arguments (lambda-list-required-argument lambda-list))
+        (rest-argument (lambda-list-rest-argument lambda-list)))
+    (let ((new-env (extend-env (cons rest-argument required-arguments) env)))
+      (concat "(function ("
+              (join (mapcar (lambda (x) (lookup-variable x new-env))
+                            required-arguments)
+                    ",")
+              "){
 "
-            (concat (ls-compile-block (butlast body) new-env fenv)
-                    "return " (ls-compile (car (last body)) new-env fenv) ";")
-           "
-})")))
+              (if rest-argument
+                  (concat "var " (lookup-variable rest-argument new-env)
+                          " = arguments.slice("
+                          (prin1-to-string (length required-arguments)) ");
+")
+                  "")
+
+              (concat (ls-compile-block (butlast body) new-env fenv)
+                      "return " (ls-compile (car (last body)) new-env fenv) ";")
+              "
+})"))))
 
 (define-compilation fsetq (var val)
   (format nil "~a = ~a" (lookup-function var fenv) (ls-compile val env fenv)))
index 86848e0..e7209a1 100644 (file)
--- a/test.lisp
+++ b/test.lisp
@@ -48,3 +48,9 @@
 (setq x 10)
 (%incf x)
 (debug x)
+
+
+;;; &rest lambda-list
+
+(debug (lambda (&rest x) x))
+(debug (lambda (x y &rest z) x))