-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathstaple.ext.lisp
52 lines (45 loc) · 2.29 KB
/
staple.ext.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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
(asdf:load-system :staple-markdown)
(defclass my-page (staple:simple-page) ())
(defmethod staple:page-type ((system (eql (asdf:find-system :d2clone-kit))))
'my-page)
(defmethod staple:packages ((system (eql (asdf:find-system :d2clone-kit))))
(mapcar #'find-package '(:d2clone-kit)))
(defmethod staple:format-documentation ((docstring string) (page my-page))
(flet ((replace-see (string start end mstart mend rstart rend)
(declare (ignore start end))
(let* ((match (subseq string (aref rstart 0) (aref rend 0)))
(identifier (plump:decode-entities match))
xref)
(cond ((cl-ppcre:scan "^[-a-zA-Z]+://" identifier)
(format NIL "See <a href=\"~a\" class=\"exref\">~a</a><br>"
match match))
((setf xref (staple:xref identifier))
(format NIL "See <a href=\"~a\" class=\"xref\">~a</a><br>"
(plump:encode-entities xref) match))
(T
(subseq string mstart mend))))))
(let* ((docstring (plump:encode-entities docstring))
(docstring (cl-ppcre:regex-replace-all "[sS]ee (.*)" docstring
#'replace-see))
(*package* (first (staple:packages page))))
(staple:markup-code-snippets-ignoring-errors
(staple:compile-source docstring :markdown)))))
(defmethod staple:definition-wanted-p :around ((definition
definitions:definition)
(__ my-page))
(if (or (typep definition 'definitions:transform)
(typep definition 'definitions:source-transform))
nil
(call-next-method)))
(defmethod staple:definition-wanted-p ((definition definitions:method)
(__ my-page))
(let* ((designator (definitions:designator definition))
(symbol (etypecase designator
(cons (cadr designator))
(symbol designator))))
(and
(string= "D2CLONE-KIT" (package-name (symbol-package symbol)))
(some
(lambda (method) (documentation method 't))
(closer-mop:generic-function-methods (symbol-function symbol))))))
;; TODO : document structure fields?..