-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathspinneret.lisp
31 lines (24 loc) · 903 Bytes
/
spinneret.lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
;;;; spinneret.lisp
(in-package #:spinneret)
(define-condition spinneret-error (error)
())
(define-condition no-such-tag (spinneret-error)
((name :initarg :name))
(:report (lambda (c s)
(with-slots (name) c
(format s "No such HTML tag: ~a" name)))))
;;;; The exported macros.
(defun get-html-path ()
"Return a copy of *HTML-PATH*.
This is necessary because *HTML-PATH* itself is stack-allocated."
(copy-list *html-path*))
(defmacro with-html (&body body &environment env)
"Interpret BODY as HTML. Consult README.txt for the syntax."
`(let ((*html* (ensure-html-stream *html*)))
,(if (and (null (cdr body)) (atom (car body)))
(car body)
`(progn ,@(parse-html body env)))))
(defmacro with-html-string (&body body)
"Like WITH-HTML, but capture the output as a string."
`(with-output-to-string (*html*)
(with-html ,@body)))