- `(progn
- (defcfun ,(concatenate 'string c-type " gacela_" name " (void)") 0
- ,(concatenate 'string "return " name ";"))
- (defentry ,(intern (string-upcase name)) ()
- (,type ,(concatenate 'string "gacela_" name)))))
-
+ (let ((c-header (concatenate 'string c-type " gacela_" name " (void)"))
+ (c-body (concatenate 'string "return " name ";"))
+ (c-name (concatenate 'string "gacela_" name))
+ (lisp-name (intern (string-upcase name))))
+ `(progn
+ (defcfun ,c-header 0 ,c-body)
+ (defentry ,lisp-name () (,type ,c-name))
+ (eval-when (load) (defconstant ,lisp-name (,lisp-name))))))