summaryrefslogtreecommitdiff
path: root/bog.el
diff options
context:
space:
mode:
authorKyle Meyer <kyle@kyleam.com>2014-10-15 02:18:51 -0400
committerKyle Meyer <kyle@kyleam.com>2014-10-15 02:28:05 -0400
commitf17083abfd13b947f8c3a819449cc372c13511df (patch)
tree186802769d8fc93a283fcb2c4a58809443463644 /bog.el
parentf143cbd5e34a553a6a195649746a7a303d8e2fbf (diff)
downloadbog-f17083abfd13b947f8c3a819449cc372c13511df.tar.gz
Add command bog-insert-heading-citekey
Diffstat (limited to 'bog.el')
-rw-r--r--bog.el12
1 files changed, 12 insertions, 0 deletions
diff --git a/bog.el b/bog.el
index 78f16df..8d6b10f 100644
--- a/bog.el
+++ b/bog.el
@@ -742,6 +742,17 @@ Sorting is only done if the heading's level matches
(not (bog-citekey-from-heading)))
(org-sort-entries nil sorting-type))))
+(defun bog-insert-heading-citekey (&optional current-buffer)
+ "Select a citekey to insert at point.
+By default, offer heading citekeys from all files. With prefix
+argument CURRENT-BUFFER, limit to heading citekeys from the
+current buffer."
+ (interactive "P")
+ (let ((citekey-func (if current-buffer
+ 'bog-heading-citekeys-in-buffer
+ 'bog-all-heading-citekeys)))
+ (insert (bog-select-citekey (funcall citekey-func)))))
+
;;; Font-lock
@@ -862,6 +873,7 @@ chosen."
(define-key prefix-map "r" 'bog-rename-staged-file-to-citekey)
(define-key prefix-map "s" 'bog-search-notes)
(define-key prefix-map "w" 'bog-refile)
+ (define-key prefix-map "y" 'bog-insert-heading-citekey)
(define-key map bog-keymap-prefix prefix-map))
map)
"Keymap for Bog.")