(defun my-blog-create-tags-files (plist)
"Create org files for each tag defined in FILETAGS in posts, storing them in my-blog-tags-folder."
- (unless (file-directory-p my-blog-tags-folder) (make-directory my-blog-tags-folder))
- (with-temp-file (file-name-concat my-blog-source-folder "tag-index.org")
+ (let* ((tagfolder (file-name-concat
+ (plist-get (cdr (assoc "landing" org-publish-project-alist)) :base-directory)))
+ (postfolder (file-name-concat
+ (plist-get (cdr (assoc "posts" org-publish-project-alist)) :base-directory)))
+ (relpostfolder (file-relative-name postfolder tagfolder)))
+ (unless (file-directory-p my-blog-tags-folder) (make-directory my-blog-tags-folder))
+ (with-temp-file (file-name-concat tagfolder "tag-index.org")
(insert (concat "#+mustache-template: " (file-name-concat my-blog-mustache-folder "tags-index.mustache") "\n"))
(insert (concat "#+TITLE: Blog - All tags\n"))
(insert "#+OPTIONS: ^:nil\n") ; do not use underscores as subscript
(insert "\n")
(dolist (tag (sort (my-org-get-all-filetags) (lambda (x y) (string-lessp (car x) (car y))) ))
- (insert (concat "- [[file:" (file-name-concat my-blog-posts-folder (concat "tag-" (car tag) ".org")) "][" (car tag) "]]\n"))))
+ (insert (concat "- [[file:" (file-name-concat relpostfolder (concat "tag-" (car tag) ".org")) "][" (car tag) "]]\n")))))
(dolist (tag (my-org-get-all-filetags))
(with-temp-file (file-name-concat my-blog-tags-folder (concat "tag-" (car tag) ".org"))
(insert (concat "#+mustache-template: " (file-name-concat my-blog-mustache-folder "tags.mustache") "\n"))
(defun my-blog-cleanup-sitemaps (plist)
"Clean up temporary files created in the process of publishing"
- ;; Create a body-only version of the tags index.
+ ;; Create a body-only version of the tags index. Needs absolute path to posts folder.
(with-temp-file (file-name-concat
- (plist-get (cdr (assoc "posts" org-publish-project-alist)) :publishing-directory)
+ (plist-get (cdr (assoc "landing" org-publish-project-alist)) :publishing-directory)
"tag-index-body.html")
(insert-file-contents (file-name-concat
(plist-get (cdr (assoc "landing" org-publish-project-alist)) :base-directory)
"tag-index.org"))
- (org-export-to-buffer 'mustache-html (current-buffer) nil nil nil t nil))
+ (org-export-to-buffer 'mustache-html (current-buffer) nil nil nil t nil)
+ (replace-string "href=\"posts" "href=\"/posts"))
(delete-file (file-name-concat my-blog-source-folder "sitemap.org"))
(delete-file (file-name-concat my-blog-posts-folder "sitemap.org"))
(delete-file (file-name-concat my-blog-posts-folder "sitemap.org~")))