This commit is contained in:
Francis St-Amour 2023-12-21 12:40:05 -05:00
parent 90ebcd6e82
commit a4bf72232f

View file

@ -84,9 +84,13 @@ When given :ASCII and :ATTR, it's possible to insert html text as a children, e.
(setf (gethash :html *builtin-elements*) t) (setf (gethash :html *builtin-elements*) t)
(defmacro define-builtin-element (element-name) (defmacro define-builtin-element (element-name)
`(defun ,element-name (&rest attrs-and-children) `(progn
(defun ,element-name (&rest attrs-and-children)
(multiple-value-bind (attrs children) (multiple-value-bind (attrs children)
(split-attrs-and-children attrs-and-children) (split-attrs-and-children attrs-and-children)
(make-builtin-element :tag (string-downcase (mkstr ',element-name))
:attrs attrs :children children)))
(defun ,(alexandria:symbolicate element-name '*) (attrs children)
(make-builtin-element :tag (string-downcase (mkstr ',element-name)) (make-builtin-element :tag (string-downcase (mkstr ',element-name))
:attrs attrs :children children)))) :attrs attrs :children children))))
@ -95,6 +99,7 @@ When given :ASCII and :ATTR, it's possible to insert html text as a children, e.
,@(mapcan (lambda (e) ,@(mapcan (lambda (e)
(list `(define-builtin-element ,e) (list `(define-builtin-element ,e)
`(setf (gethash (make-keyword ',e) *builtin-elements*) t) `(setf (gethash (make-keyword ',e) *builtin-elements*) t)
`(setf (gethash (make-keyword ,(format nil "~a*" e)) *builtin-elements*) t)
`(export ',e))) `(export ',e)))
element-names))) element-names)))
@ -114,6 +119,16 @@ When given :ASCII and :ATTR, it's possible to insert html text as a children, e.
(format stream " ~{~a=~s~^ ~}" (alist-plist* (attrs-alist attrs))) (format stream " ~{~a=~s~^ ~}" (alist-plist* (attrs-alist attrs)))
(format stream ""))) (format stream "")))
(defun self-closing-p (element)
(gethash (if (symbolp element)
element
(intern (string-downcase element) #.*package*))
#.(let ((self-closing-tags (make-hash-table)))
(loop :for tag :in '(area base br col embed hr img input keygen
link meta param source track wbr)
:do (setf (gethash tag self-closing-tags) tag))
self-closing-tags)))
(defmethod print-object ((element element) stream) (defmethod print-object ((element element) stream)
(if (element-children element) (if (element-children element)
(format stream (if (rest (element-children element)) (format stream (if (rest (element-children element))
@ -123,7 +138,12 @@ When given :ASCII and :ATTR, it's possible to insert html text as a children, e.
(element-attrs element) (element-attrs element)
(element-children element) (element-children element)
(element-tag element)) (element-tag element))
(format stream "<~a~a>" (element-tag element) (element-attrs element)))) (format stream (if (self-closing-p (element-tag element))
"<~a~a>"
"<~a~a></~a>")
(element-tag element)
(element-attrs element)
(element-tag element))))
(defmethod print-object ((element builtin-element-with-prefix) stream) (defmethod print-object ((element builtin-element-with-prefix) stream)
(format stream "~a~%" (element-prefix element)) (format stream "~a~%" (element-prefix element))