From 3d8fad8e3fe4539f526d84e2f1f0a85470bfd3ec Mon Sep 17 00:00:00 2001 From: paku Date: Sat, 3 Feb 2024 22:37:58 +0900 Subject: [PATCH] Wrap user element functions with macro --- src/piccolo.lisp | 32 ++++++++++++++++++-------------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/src/piccolo.lisp b/src/piccolo.lisp index bea2206..e47dcc5 100644 --- a/src/piccolo.lisp +++ b/src/piccolo.lisp @@ -149,20 +149,24 @@ When given :ASCII and :ATTR, it's possible to insert html text as a children, e. (call-next-method)) (defmacro! define-element (name (&rest args) &body body) - `(defun ,name (&rest ,g!attrs-and-children) - (multiple-value-bind (,g!attrs ,g!children) - (split-attrs-and-children ,g!attrs-and-children) - (let ((,g!element - (make-user-element :tag (string-downcase ',name) :attrs ,g!attrs - :children ,g!children))) - (setf (user-element-expander ,g!element) - (lambda (tag attrs children) - (declare (ignorable tag attrs children)) - (let ,(mapcar (lambda (arg) - (list arg `(attr attrs (make-keyword ',arg)))) - args) - (progn ,@body)))) - ,g!element)))) + (let ((%name (alexandria:symbolicate '% name))) + `(progn + (defun ,%name (&rest ,g!attrs-and-children) + (multiple-value-bind (,g!attrs ,g!children) + (split-attrs-and-children ,g!attrs-and-children) + (let ((,g!element + (make-user-element :tag (string-downcase ',name) :attrs ,g!attrs + :children ,g!children))) + (setf (user-element-expander ,g!element) + (lambda (tag attrs children) + (declare (ignorable tag attrs children)) + (let ,(mapcar (lambda (arg) + (list arg `(attr attrs (make-keyword ',arg)))) + args) + (progn ,@body)))) + ,g!element))) + (defmacro ,name (&body attrs-and-children) + `(,',%name ,@attrs-and-children))))) (defvar *expand-user-element* t)