Improve sitemap publishing with org-publish.
Patch from Sebastian Rose.
This commit is contained in:
parent
69673b3c1f
commit
0aa74caefc
|
@ -1,5 +1,8 @@
|
||||||
2008-06-16 Carsten Dominik <dominik@science.uva.nl>
|
2008-06-16 Carsten Dominik <dominik@science.uva.nl>
|
||||||
|
|
||||||
|
* org-publish.el (org-publish-org-index): Make a properly indented
|
||||||
|
list.
|
||||||
|
|
||||||
* org.el (org-calendar-agenda-action-key): New option.
|
* org.el (org-calendar-agenda-action-key): New option.
|
||||||
(org-get-cursor-date): New function.
|
(org-get-cursor-date): New function.
|
||||||
(org-mark-entry-for-agenda-action): New command.
|
(org-mark-entry-for-agenda-action): New command.
|
||||||
|
|
|
@ -595,8 +595,10 @@ Default for INDEX-FILENAME is 'index.org'."
|
||||||
(let* ((project-plist (cdr project))
|
(let* ((project-plist (cdr project))
|
||||||
(dir (file-name-as-directory
|
(dir (file-name-as-directory
|
||||||
(plist-get project-plist :base-directory)))
|
(plist-get project-plist :base-directory)))
|
||||||
|
(localdir (file-name-directory dir))
|
||||||
|
(indent-str (make-string 2 ?\ ))
|
||||||
(exclude-regexp (plist-get project-plist :exclude))
|
(exclude-regexp (plist-get project-plist :exclude))
|
||||||
(files (org-publish-get-base-files project exclude-regexp))
|
(files (nreverse (org-publish-get-base-files project exclude-regexp)))
|
||||||
(index-filename (concat dir (or index-filename "index.org")))
|
(index-filename (concat dir (or index-filename "index.org")))
|
||||||
(index-title (or (plist-get project-plist :index-title)
|
(index-title (or (plist-get project-plist :index-title)
|
||||||
(concat "Index for project " (car project))))
|
(concat "Index for project " (car project))))
|
||||||
|
@ -609,12 +611,29 @@ Default for INDEX-FILENAME is 'index.org'."
|
||||||
(with-temp-buffer
|
(with-temp-buffer
|
||||||
(insert (concat index-title "\n\n"))
|
(insert (concat index-title "\n\n"))
|
||||||
(while (setq file (pop files))
|
(while (setq file (pop files))
|
||||||
(let ((fn (substring (expand-file-name file)
|
(let ((fn (file-name-nondirectory file))
|
||||||
(length (expand-file-name dir)))))
|
(link (file-relative-name file dir))
|
||||||
|
(oldlocal localdir))
|
||||||
;; index shouldn't index itself
|
;; index shouldn't index itself
|
||||||
(unless (string= fn ifn)
|
(unless (string= fn ifn)
|
||||||
(insert (concat " + [[file:" fn "]["
|
(setq localdir (concat (file-name-as-directory dir)
|
||||||
(org-publish-find-title (concat dir fn))
|
(file-name-directory link)))
|
||||||
|
(unless (string= localdir oldlocal)
|
||||||
|
(if (string= localdir dir)
|
||||||
|
(setq indent-str (make-string 2 ?\ ))
|
||||||
|
(let ((subdirs
|
||||||
|
(split-string
|
||||||
|
(directory-file-name
|
||||||
|
(file-name-directory
|
||||||
|
(file-relative-name localdir dir))) "/"))
|
||||||
|
(subdir ""))
|
||||||
|
(setq indent-str (make-string 2 ?\ ))
|
||||||
|
(dolist (d subdirs)
|
||||||
|
(setq subdir (concat subdir d "/"))
|
||||||
|
(insert (concat indent-str " + [[file:" subdir "][" d "/]]\n"))
|
||||||
|
(setq indent-str (make-string (+ (length indent-str) 2) ?\ ))))))
|
||||||
|
(insert (concat indent-str " + [[file:" link "]["
|
||||||
|
(file-name-sans-extension fn)
|
||||||
"]]\n")))))
|
"]]\n")))))
|
||||||
(write-file index-filename)
|
(write-file index-filename)
|
||||||
(kill-buffer (current-buffer)))))
|
(kill-buffer (current-buffer)))))
|
||||||
|
|
Loading…
Reference in New Issue