我正在寻找一种解决方案,它允许我编写原生 Emacs Lisp 代码并在编译时将其转换为 HTML,例如 Franz's htmlgen :
(html
((:div class "post")
(:h1 "Title")
(:p "Hello, World!")))
我当然可以write my own macros , 但我对是否有任何解决此问题的项目感兴趣。
最佳答案
如你found out , xmlgen
从列表结构生成 XML。我确实对 ``xmlgen` 包感到失望,因为它支持的格式与 Emacs 的格式并不完全相反' xml parser .
我确实将它添加到我的 xmlgen 副本中:
;; this creates a routine to be the inverse of what xml-parse does
;;;###autoload
(defun xml-gen (form &optional in-elm level)
"Convert a sexp to xml:
'(p :class \"big\")) => \"<p class=\\\"big\\\" />\""
(let ((level (or level 0)))
(cond
((numberp form) (number-to-string form))
((stringp form) form)
((listp form)
(destructuring-bind (xml attrs) (xml-gen-extract-plist form)
(let ((el (car xml)))
(unless (symbolp el)
(error "Element must be a symbol (got '%S')." el))
(setq el (symbol-name el))
(concat "<" el (xml-gen-attr-to-string attrs)
(if (> (length xml) 1)
(concat ">" (mapconcat
(lambda (s) (xml-gen s el (1+ level)))
(cdr xml)
"")
"</" el ">")
"/>"))))))))
(defun xml-gen-attr-to-string (plist)
(reduce 'concat (mapcar (lambda (p) (concat " " (symbol-name (car p)) "=\"" (cdr p) "\"")) plist)))
(defun xml-gen-extract-plist (list)
(list (cons (car list) (let ((kids (xml-node-children list)))
(if (= 1 (length kids))
kids
(remove-if-not 'listp kids))))
(xml-node-attributes list)))
注意:这个的接口(interface)是xml-gen
(不是原始解析的xmlgen
)。
有了这个接口(interface),以下内容成立:
(string-equal (xml-gen (car (xml-parse-region <some-region-of-xml>)))
<some-region-of-xml>)
和
(equal (car (xml-parse-region (insert (xml-gen <some-xml-form>))))
<some-xml-form>)
新的 xml-gen
并不努力保留 xml-parse-region
例程生成的周围的空白。
关于html - 是否有用于生成 HTML 的 Emacs Lisp 库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/797442/