Remove let-over-lambda
This commit is contained in:
parent
d9d1c8287e
commit
7ea3778e34
3 changed files with 38 additions and 34 deletions
1
qlfile
1
qlfile
|
@ -1,4 +1,3 @@
|
||||||
ql fiveam
|
ql fiveam
|
||||||
ql assoc-utils
|
ql assoc-utils
|
||||||
ql let-over-lambda
|
|
||||||
ql alexandria
|
ql alexandria
|
||||||
|
|
|
@ -10,10 +10,6 @@
|
||||||
(:class qlot/source/ql:source-ql
|
(:class qlot/source/ql:source-ql
|
||||||
:initargs (:%version :latest)
|
:initargs (:%version :latest)
|
||||||
:version "ql-2023-10-21"))
|
:version "ql-2023-10-21"))
|
||||||
("let-over-lambda" .
|
|
||||||
(:class qlot/source/ql:source-ql
|
|
||||||
:initargs (:%version :latest)
|
|
||||||
:version "ql-2023-10-21"))
|
|
||||||
("alexandria" .
|
("alexandria" .
|
||||||
(:class qlot/source/ql:source-ql
|
(:class qlot/source/ql:source-ql
|
||||||
:initargs (:%version :latest)
|
:initargs (:%version :latest)
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
(uiop:define-package #:piccolo/elements
|
(uiop:define-package #:piccolo/elements
|
||||||
(:use #:cl)
|
(:use #:cl)
|
||||||
(:local-nicknames (#:asu #:assoc-utils))
|
(:local-nicknames (#:asu #:assoc-utils))
|
||||||
(:local-nicknames (#:lol #:let-over-lambda))
|
|
||||||
(:local-nicknames (#:alx #:alexandria))
|
(:local-nicknames (#:alx #:alexandria))
|
||||||
(:local-nicknames (#:esc #:piccolo/escape))
|
(:local-nicknames (#:esc #:piccolo/escape))
|
||||||
(:export #:html
|
(:export #:html
|
||||||
|
@ -114,29 +113,38 @@
|
||||||
|
|
||||||
;;; elements
|
;;; elements
|
||||||
|
|
||||||
|
(defun flatten (x)
|
||||||
|
(labels ((rec (x acc)
|
||||||
|
(cond ((null x) acc)
|
||||||
|
((atom x) (cons x acc))
|
||||||
|
(t (rec
|
||||||
|
(car x)
|
||||||
|
(rec (cdr x) acc))))))
|
||||||
|
(rec x nil)))
|
||||||
|
|
||||||
(defun split-attrs-and-children (attrs-and-children)
|
(defun split-attrs-and-children (attrs-and-children)
|
||||||
(cond
|
(cond
|
||||||
((attrs-p (first attrs-and-children))
|
((attrs-p (first attrs-and-children))
|
||||||
(values (first attrs-and-children) (lol:flatten (rest attrs-and-children))))
|
(values (first attrs-and-children) (flatten (rest attrs-and-children))))
|
||||||
((asu:alistp (first attrs-and-children))
|
((asu:alistp (first attrs-and-children))
|
||||||
(values (make-attrs :alist (first attrs-and-children))
|
(values (make-attrs :alist (first attrs-and-children))
|
||||||
(lol:flatten (rest attrs-and-children))))
|
(flatten (rest attrs-and-children))))
|
||||||
((listp (first attrs-and-children)) ;plist
|
((listp (first attrs-and-children)) ;plist
|
||||||
(values (make-attrs :alist (alx:plist-alist (first attrs-and-children)))
|
(values (make-attrs :alist (alx:plist-alist (first attrs-and-children)))
|
||||||
(lol:flatten (rest attrs-and-children))))
|
(flatten (rest attrs-and-children))))
|
||||||
((hash-table-p (first attrs-and-children))
|
((hash-table-p (first attrs-and-children))
|
||||||
(values (make-attrs :alist (asu:hash-alist (first attrs-and-children)))
|
(values (make-attrs :alist (asu:hash-alist (first attrs-and-children)))
|
||||||
(lol:flatten (rest attrs-and-children))))
|
(flatten (rest attrs-and-children))))
|
||||||
((keywordp (first attrs-and-children)) ;inline-plist
|
((keywordp (first attrs-and-children)) ;inline-plist
|
||||||
(loop for thing on attrs-and-children by #'cddr
|
(loop for thing on attrs-and-children by #'cddr
|
||||||
for (k v) = thing
|
for (k v) = thing
|
||||||
when (and (keywordp k) v)
|
when (and (keywordp k) v)
|
||||||
collect (cons k v) into attrs
|
collect (cons k v) into attrs
|
||||||
when (not (keywordp k))
|
when (not (keywordp k))
|
||||||
return (values (make-attrs :alist attrs) (lol:flatten thing))
|
return (values (make-attrs :alist attrs) (flatten thing))
|
||||||
finally (return (values (make-attrs :alist attrs) nil))))
|
finally (return (values (make-attrs :alist attrs) nil))))
|
||||||
(t
|
(t
|
||||||
(values (make-attrs :alist nil) (lol:flatten attrs-and-children)))))
|
(values (make-attrs :alist nil) (flatten attrs-and-children)))))
|
||||||
|
|
||||||
(defparameter *builtin-elements* (make-hash-table))
|
(defparameter *builtin-elements* (make-hash-table))
|
||||||
(setf (gethash :html *builtin-elements*) t)
|
(setf (gethash :html *builtin-elements*) t)
|
||||||
|
@ -158,7 +166,7 @@
|
||||||
(defun ,%element-name (&rest attrs-and-children)
|
(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 (lol:mkstr ',element-name))
|
(make-builtin-element :tag (string-downcase ',element-name)
|
||||||
:attrs attrs
|
:attrs attrs
|
||||||
:children children)))
|
:children children)))
|
||||||
(defmacro ,element-name (&body attrs-and-children)
|
(defmacro ,element-name (&body attrs-and-children)
|
||||||
|
@ -183,27 +191,28 @@
|
||||||
style sub summary sup svg table tbody td template textarea tfoot th
|
style sub summary sup svg table tbody td template textarea tfoot th
|
||||||
thead |time| title tr track u ul var video wbr)
|
thead |time| title tr track u ul var video wbr)
|
||||||
|
|
||||||
(lol:defmacro! define-element (name (&rest args) &body body)
|
(defmacro define-element (name (&rest args) &body body)
|
||||||
(let ((%name (alx:symbolicate '% name)))
|
(alx:with-gensyms (attrs children exp-children)
|
||||||
`(progn
|
(let ((%name (alx:symbolicate '% name)))
|
||||||
(defun ,%name (&rest attrs-and-children)
|
`(progn
|
||||||
(multiple-value-bind (,g!attrs ,g!children)
|
(defun ,%name (&rest attrs-and-children)
|
||||||
(split-attrs-and-children attrs-and-children)
|
(multiple-value-bind (,attrs ,children)
|
||||||
(make-user-element
|
(split-attrs-and-children attrs-and-children)
|
||||||
:tag (string-downcase ',name)
|
(make-user-element
|
||||||
:attrs ,g!attrs
|
:tag (string-downcase ',name)
|
||||||
:children ,g!children
|
:attrs ,attrs
|
||||||
:expander (lambda (tag attrs ,g!exp-children)
|
:children ,children
|
||||||
(declare (ignorable tag attrs))
|
:expander (lambda (tag attrs ,exp-children)
|
||||||
(let ((children (and ,g!exp-children
|
(declare (ignorable tag attrs))
|
||||||
(make-fragment :children ,g!exp-children))))
|
(let ((children (and ,exp-children
|
||||||
(declare (ignorable children))
|
(make-fragment :children ,exp-children))))
|
||||||
(let ,(mapcar (lambda (arg)
|
(declare (ignorable children))
|
||||||
(list arg `(attr attrs (alx:make-keyword ',arg))))
|
(let ,(mapcar (lambda (arg)
|
||||||
args)
|
(list arg `(attr attrs (alx:make-keyword ',arg))))
|
||||||
(progn ,@body)))))))
|
args)
|
||||||
(defmacro ,name (&body attrs-and-children)
|
(progn ,@body)))))))
|
||||||
`(,',%name ,@attrs-and-children)))))
|
(defmacro ,name (&body attrs-and-children)
|
||||||
|
`(,',%name ,@attrs-and-children))))))
|
||||||
|
|
||||||
(defun %<> (&rest attrs-and-children)
|
(defun %<> (&rest attrs-and-children)
|
||||||
(multiple-value-bind (attrs children)
|
(multiple-value-bind (attrs children)
|
||||||
|
|
Loading…
Reference in a new issue