X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;ds=sidebyside;f=gacela_mobs.lisp;h=0cd56ae480c57e16a48ac0a7903c15d8df9c461a;hb=88b17cb18b5b646782b7308edfded33e35559338;hp=79a8be2b98e1a3340ea2722254e0fd143e550249;hpb=edd70b0d0e5f54a346fcf6850ab6e10335ac6751;p=gacela.git diff --git a/gacela_mobs.lisp b/gacela_mobs.lisp index 79a8be2..0cd56ae 100755 --- a/gacela_mobs.lisp +++ b/gacela_mobs.lisp @@ -17,10 +17,18 @@ ;;; World of Mob -(in-package :gacela) +;(in-package :gacela) (defmacro makemob (name variables &rest methods) - `(lambda , + `(let ,variables + (defun ,name (&rest args &aux (option (car args))) + ,(mob-options methods)))) + +(defun mob-options (methods) + (labels ((options (m &aux (option (car m)) (vars (cadr m)) (body (caddr m))) + (cond ((null m) nil) + (t (cons option (cons (lambda body (options (cdddr m)))))))) + (cons 'case (cons 'option (options methods))))) (defmacro defmob (name variables &key init logic render) `(let ((make-name ',(intern (concatenate 'string "MAKE-" (string name)))))