X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=test.lisp;h=3abd8f5ec9cf78307d2518a1297e8b947bbf6bd6;hb=0352e2cff01edf1853e4db7d64b8ae6d94807d25;hp=3a990fe6434788341262a9e3f1b939f1d99e6432;hpb=f18b4ce1c1f49b2267c96e15b777cd416328c965;p=jscl.git diff --git a/test.lisp b/test.lisp index 3a990fe..3abd8f5 100644 --- a/test.lisp +++ b/test.lisp @@ -1,3 +1,20 @@ +;;; Library + +(eval-when-compile + (%compile-defmacro 'defmacro + (lambda (name args &rest body) + `(eval-when-compile + (%compile-defmacro ',name (lambda ,args ,@body)))))) + +(defmacro defun (name args &rest body) + `(progn + (eval-when-compile + (%compile-defun ',name)) + (fsetq ,name (lambda ,args ,@body)))) + + +;;; Tests + (lambda (x y) x) (debug "hola") @@ -26,12 +43,7 @@ ;;; Macros (debug "---MACROS---") -(eval-when-compile - (%compile-defmacro 'defmacro - (lambda (name args &rest body) - (list 'eval-when-compile - (list '%compile-defmacro (list 'quote name) - (list* 'lambda args body)))))) + (defmacro incf (x) (list 'setq x (list '+ 1 x))) @@ -68,7 +80,9 @@ (debug (lambda (x y &rest z) z)) (debug (lambda (x y &rest z) x)) -;; (debug (foo)) + +(defun f (x) (* x x)) +(debug (f 33)) ;; (eval-when-compile ;; (%compile-defmacro 'defun