X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=gacela_objects.lisp;h=c3f9ea255ab258d8ab895b8cf1e2e6c6db54a767;hb=21d0c96bd43aa2cc5f8546af2c2953d993e9986e;hp=00ade7fd0d7503419091d7967517692f859ead5c;hpb=4305910b0019e2b4b655c8af4e3347fd6944fad6;p=gacela.git diff --git a/gacela_objects.lisp b/gacela_objects.lisp index 00ade7f..c3f9ea2 100755 --- a/gacela_objects.lisp +++ b/gacela_objects.lisp @@ -74,11 +74,16 @@ active-objects)) -(defmacro make-object (&key name class attr bhv look) - `(let ((object - '(:name ,name :class ,class :attr ,(make-object-attributes attr) :bhv ,(make-object-behaviour bhv) :look ,look))) - (add-object object) - object)) +(defun make-object-old (name &key attr bhv look) + (let ((object + `(:name ,name :attr ,(make-object-attributes attr) :bhv ,(make-object-behaviour bhv) :look ,look))) + (add-object object) + object)) + +(defmacro make-object (name attr bhv &body look) + `(let ((attr ,(make-object-attributes attr) bhv ,(make-object-behaviour bhv))) + (defun ,name (option) ,@look) + )) (defun make-object-attributes (attr) (cond ((or (null attr) (atom attr)) nil) @@ -95,5 +100,6 @@ `(,pname ,value))) (defun make-object-behaviour (bhv) - (cond ((consp bhv) bhv) - (t (list bhv)))) + (cond ((null bhv) nil) + ((atom bhv) (list bhv)) + (t bhv)))