2008-02-07 11:31:50 -05:00
|
|
|
;;; org-annotate-file.el --- Annotate a file with org syntax
|
|
|
|
|
2014-01-07 08:18:17 -05:00
|
|
|
;; Copyright (C) 2008-2014 Philip Jackson
|
2008-02-07 11:31:50 -05:00
|
|
|
|
|
|
|
;; Author: Philip Jackson <phil@shellarchive.co.uk>
|
|
|
|
;; Version: 0.2
|
|
|
|
|
|
|
|
;; This file is not currently part of GNU Emacs.
|
|
|
|
|
|
|
|
;; This program is free software; you can redistribute it and/or
|
|
|
|
;; modify it under the terms of the GNU General Public License as
|
|
|
|
;; published by the Free Software Foundation; either version 2, or (at
|
|
|
|
;; your option) any later version.
|
|
|
|
|
|
|
|
;; This program is distributed in the hope that it will be useful, but
|
|
|
|
;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
;; General Public License for more details.
|
|
|
|
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
|
|
|
;; along with this program ; see the file COPYING. If not, write to
|
|
|
|
;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
;; Boston, MA 02111-1307, USA.
|
|
|
|
|
|
|
|
;;; Commentary:
|
|
|
|
|
|
|
|
;; This is yet another implementation to allow the annotation of a
|
2014-03-15 11:50:04 -04:00
|
|
|
;; file without modification of the file itself. The annotation is in
|
2008-02-07 11:31:50 -05:00
|
|
|
;; org syntax so you can use all of the org features you are used to.
|
|
|
|
|
|
|
|
;; To use you might put the following in your .emacs:
|
|
|
|
;;
|
|
|
|
;; (require 'org-annotate-file)
|
|
|
|
;; (global-set-key (kbd "C-c C-l") 'org-annotate-file) ; for example
|
|
|
|
;;
|
|
|
|
;; To change the location of the annotation file:
|
|
|
|
;;
|
|
|
|
;; (setq org-annotate-file-storage-file "~/annotated.org")
|
|
|
|
;;
|
|
|
|
;; Then when you visit any file and hit C-c C-l you will find yourself
|
|
|
|
;; in an org buffer on a headline which links to the file you were
|
|
|
|
;; visiting, e.g:
|
|
|
|
|
|
|
|
;; * ~/org-annotate-file.el
|
|
|
|
|
|
|
|
;; Under here you can put anything you like, save the file
|
|
|
|
;; and next time you hit C-c C-l you will hit those notes again.
|
|
|
|
;;
|
|
|
|
;; To put a subheading with a text search for the current line set
|
2014-03-15 11:50:04 -04:00
|
|
|
;; `org-annotate-file-add-search` to non-nil value. Then when you hit
|
2008-02-07 11:31:50 -05:00
|
|
|
;; C-c C-l (on the above line for example) you will get:
|
|
|
|
|
|
|
|
;; * ~/org-annotate-file.el
|
2014-03-15 11:50:04 -04:00
|
|
|
;; ** `org-annotate-file-add-search` to non-nil value. Then whe...
|
2008-02-07 11:31:50 -05:00
|
|
|
|
|
|
|
;; Note that both of the above will be links.
|
|
|
|
|
2014-03-15 11:50:04 -04:00
|
|
|
;;; Code:
|
|
|
|
|
2008-02-07 11:31:50 -05:00
|
|
|
(require 'org)
|
|
|
|
|
|
|
|
(defvar org-annotate-file-storage-file "~/.org-annotate-file.org"
|
|
|
|
"File in which to keep annotations.")
|
|
|
|
|
|
|
|
(defvar org-annotate-file-add-search nil
|
2014-03-15 11:50:04 -04:00
|
|
|
"If non-nil, add a link as a second level to the actual file location.")
|
2008-02-07 11:31:50 -05:00
|
|
|
|
|
|
|
(defvar org-annotate-file-always-open t
|
2014-03-15 11:50:04 -04:00
|
|
|
"If non-nil, always expand the full tree when visiting the annotation file.")
|
2008-02-07 11:31:50 -05:00
|
|
|
|
2014-03-15 11:50:04 -04:00
|
|
|
(defun org-annotate-file-ellipsify-desc (string &optional after)
|
|
|
|
"Return shortened STRING with appended ellipsis.
|
|
|
|
Trim whitespace at beginning and end of STRING and replace any
|
|
|
|
characters that appear after the occurrence of AFTER with '...'"
|
2008-03-05 05:26:40 -05:00
|
|
|
(let* ((after (number-to-string (or after 30)))
|
|
|
|
(replace-map (list (cons "^[ \t]*" "")
|
|
|
|
(cons "[ \t]*$" "")
|
|
|
|
(cons (concat "^\\(.\\{" after
|
|
|
|
"\\}\\).*") "\\1..."))))
|
|
|
|
(mapc (lambda (x)
|
|
|
|
(when (string-match (car x) string)
|
|
|
|
(setq string (replace-match (cdr x) nil nil string))))
|
|
|
|
replace-map)
|
2008-02-07 11:31:50 -05:00
|
|
|
string))
|
|
|
|
|
2014-03-15 13:00:46 -04:00
|
|
|
;;;###autoload
|
2008-02-07 11:31:50 -05:00
|
|
|
(defun org-annotate-file ()
|
2014-03-15 12:21:50 -04:00
|
|
|
"Visit `org-annotate-file-storage-file` and add a new annotation section.
|
|
|
|
The annotation is opened at the new section which will be referencing
|
|
|
|
the point in the current file."
|
2008-02-07 11:31:50 -05:00
|
|
|
(interactive)
|
|
|
|
(unless (buffer-file-name)
|
2014-03-15 11:50:04 -04:00
|
|
|
(error "This buffer has no associated file!"))
|
2014-03-15 12:21:50 -04:00
|
|
|
(switch-to-buffer
|
|
|
|
(org-annotate-file-show-section org-annotate-file-storage-file)))
|
|
|
|
|
2014-03-15 13:00:46 -04:00
|
|
|
;;;###autoload
|
2014-03-15 12:21:50 -04:00
|
|
|
(defun org-annotate-file-show-section (storage-file &optional annotated-buffer)
|
|
|
|
"Add or show annotation entry in STORAGE-FILE and return the buffer.
|
|
|
|
The annotation will link to ANNOTATED-BUFFER if specified,
|
|
|
|
otherwise the current buffer is used."
|
|
|
|
(let ((filename (abbreviate-file-name (or annotated-buffer
|
|
|
|
(buffer-file-name))))
|
|
|
|
(line (buffer-substring-no-properties (point-at-bol) (point-at-eol)))
|
|
|
|
(annotation-buffer (find-file-noselect storage-file)))
|
|
|
|
(with-current-buffer annotation-buffer
|
|
|
|
(org-annotate-file-annotate filename line))
|
|
|
|
annotation-buffer))
|
|
|
|
|
|
|
|
(defun org-annotate-file-annotate (filename line)
|
|
|
|
"Add annotation for FILENAME at LINE using current buffer."
|
|
|
|
(let* ((link (org-make-link-string (concat "file:" filename) filename))
|
2008-02-07 11:31:50 -05:00
|
|
|
(search-link (org-make-link-string
|
|
|
|
(concat "file:" filename "::" line)
|
2014-03-15 12:21:50 -04:00
|
|
|
(org-annotate-file-ellipsify-desc line))))
|
|
|
|
(unless (eq major-mode 'org-mode)
|
|
|
|
(org-mode))
|
|
|
|
(goto-char (point-min))
|
|
|
|
(widen)
|
|
|
|
(when org-annotate-file-always-open
|
|
|
|
(show-all))
|
|
|
|
(unless (search-forward-regexp
|
|
|
|
(concat "^* " (regexp-quote link)) nil t)
|
|
|
|
(org-annotate-file-add-upper-level link))
|
|
|
|
(beginning-of-line)
|
|
|
|
(org-narrow-to-subtree)
|
|
|
|
;; deal with a '::' search if need be
|
|
|
|
(when org-annotate-file-add-search
|
2008-02-07 11:31:50 -05:00
|
|
|
(unless (search-forward-regexp
|
2014-03-15 12:21:50 -04:00
|
|
|
(concat "^** " (regexp-quote search-link)) nil t)
|
|
|
|
(org-annotate-file-add-second-level search-link)))))
|
2008-02-07 11:31:50 -05:00
|
|
|
|
|
|
|
(defun org-annotate-file-add-upper-level (link)
|
2014-03-15 11:50:04 -04:00
|
|
|
"Add and link heading to LINK."
|
2008-02-07 11:31:50 -05:00
|
|
|
(goto-char (point-min))
|
|
|
|
(call-interactively 'org-insert-heading)
|
|
|
|
(insert link))
|
|
|
|
|
|
|
|
(defun org-annotate-file-add-second-level (link)
|
2014-03-15 11:50:04 -04:00
|
|
|
"Add and link subheading to LINK."
|
2008-02-07 11:31:50 -05:00
|
|
|
(goto-char (point-at-eol))
|
|
|
|
(call-interactively 'org-insert-subheading)
|
|
|
|
(insert link))
|
|
|
|
|
|
|
|
(provide 'org-annotate-file)
|
2011-08-17 08:42:34 -04:00
|
|
|
|
2008-02-07 11:31:50 -05:00
|
|
|
;;; org-annotate-file.el ends here
|