Flexible Lisp Blogware. Fork for personal use. Mirrored from https://github.com/kingcons/coleslaw originally.

sitemap.lisp 1.0KB

1234567891011121314151617181920212223242526272829303132
  1. (defpackage :coleslaw-sitemap
  2. (:use :cl)
  3. (:import-from :coleslaw #:*config*
  4. #:index
  5. #:page-url
  6. #:find-all
  7. #:discover
  8. #:publish
  9. #:theme-fn
  10. #:add-document
  11. #:write-document)
  12. (:import-from :alexandria #:hash-table-values)
  13. (:export #:enable))
  14. (in-package :coleslaw-sitemap)
  15. (defclass sitemap (index)
  16. ((urls :initarg :urls :reader urls)))
  17. (defmethod page-url ((object sitemap)) "sitemap.xml")
  18. (defmethod discover ((doc-type (eql (find-class 'sitemap))))
  19. (let ((base-urls '("" "sitemap.xml"))
  20. (urls (mapcar #'page-url (hash-table-values coleslaw::*site*))))
  21. (add-document (make-instance 'sitemap :urls (append base-urls urls)))))
  22. (defmethod publish ((doc-type (eql (find-class 'sitemap))))
  23. (dolist (sitemap (find-all 'sitemap))
  24. (write-document sitemap (theme-fn 'sitemap "sitemap"))))
  25. (defun enable ())