Skip to content

Commit

Permalink
Merge pull request #91 from Tevo45/master
Browse files Browse the repository at this point in the history
Parenscript fixes
  • Loading branch information
ruricolist authored Jan 23, 2024
2 parents 00ad98b + e025d2f commit da599c1
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 25 deletions.
6 changes: 5 additions & 1 deletion package.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,11 @@
#:concat-constant-strings ;; unexported function
#:define-ps-symbol-macro
#:defpsmacro
#:with-ps-gensyms)
#:with-ps-gensyms
#:stringify
#:chain
#:@
#:for-in)
(:import-from #:trivial-gray-streams
#:fundamental-character-output-stream
#:stream-write-char #:stream-write-string
Expand Down
52 changes: 28 additions & 24 deletions ps.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -60,30 +60,34 @@
*props* :test #'string-equal)
attr))
(sval `(stringify ,val)))
(cond
((event? attr)
;; Set events as properties, ensuring a href.
`(setf (@ *html* ,attr) ,sval
(@ *html* href)
(or (@ *html* href) "#")))
;; Style requires special handling for IE.
((string-equal attr "style")
`(if (@ *html* style set-attribute)
(ch *html* style (set-attribute 'css-text ,sval))
(ch *html* (set-attribute ,attr ,sval))))
((rassoc attr *ie-attr-props* :test #'string-equal)
;; Other special cases for IE.
`(setf (@ *html* ,attr) ,sval))
((data-attr? attr)
`(setf (@ *html* dataset ,(data-attr-prop attr)) ,sval))
((string-equal attr "attrs")
(with-ps-gensyms (attrs attr)
`(let ((,attrs ,val))
(for-in (,attr ,attrs)
(ch *html*
(set-attribute ,attr
(stringify (@ ,attrs ,attr))))))))
(t `(ch *html* (set-attribute ,attr ,sval))))))
(flet ((set-or-remove (object attr val)
(with-ps-gensyms (actual-val)
`(let ((,actual-val ,val))
(if ,actual-val
(ch ,object (set-attribute ,attr (stringify ,actual-val)))
(ch ,object (remove-attribute ,attr)))))))
(cond
((event? attr)
;; Set events as properties, ensuring a href.
`(setf (@ *html* ,attr) ,sval
(@ *html* href)
(or (@ *html* href) "#")))
;; Style requires special handling for IE.
((string-equal attr "style")
`(if (@ *html* style set-attribute)
(ch *html* style (set-attribute 'css-text ,sval))
(ch *html* (set-attribute ,attr ,sval))))
((rassoc attr *ie-attr-props* :test #'string-equal)
;; Other special cases for IE.
`(setf (@ *html* ,attr) ,sval))
((data-attr? attr)
`(setf (@ *html* dataset ,(data-attr-prop attr)) ,sval))
((string-equal attr "attrs")
(with-ps-gensyms (attrs attr)
`(let ((,attrs ,val))
(for-in (,attr ,attrs)
,(set-or-remove '*html* attr `(@ ,attrs ,attr))))))
(t (set-or-remove '*html* attr val))))))

(defun event? (attr)
(starts-with-subseq "on" (string attr)))
Expand Down

0 comments on commit da599c1

Please sign in to comment.