aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Bremner <david@tethera.net>2016-11-03 22:02:43 -0300
committerDavid Bremner <david@tethera.net>2016-11-04 12:51:50 -0300
commit343534d82dc8882b3f0e2a847ee9d10ba5392809 (patch)
tree616acf89bc80c11e14c129810934e2ee4a88cd16
parente5786283e7465377d828c36c951f77fe629a0885 (diff)
emacs: add notmuch-address-post-completion-hook
This hook can be used to update the message based on the results of address completion. For example using message-templ or gnus-alias to set the From address based on the To address just completed. The post-completion command is added to the notmuch-company backend to ensure that the hook is also called company completion is started without going through notmuch-address-expand-name. See the docstring of `company-backends' for more information.
-rw-r--r--emacs/notmuch-address.el14
-rw-r--r--emacs/notmuch-company.el1
2 files changed, 14 insertions, 1 deletions
diff --git a/emacs/notmuch-address.el b/emacs/notmuch-address.el
index b2e1fba7..36c796f9 100644
--- a/emacs/notmuch-address.el
+++ b/emacs/notmuch-address.el
@@ -98,6 +98,17 @@ to know how address selection is made by default."
:group 'notmuch-send
:group 'notmuch-external)
+(defcustom notmuch-address-completion-hook nil
+ "Functions called after completing address.
+
+The completed address is passed as an argument to each function.
+Note that this hook will be invoked for completion in headers
+matching `notmuch-address-completion-headers-regexp'.
+"
+ :type 'hook
+ :group 'notmuch-address
+ :group 'notmuch-hooks)
+
(defun notmuch-address-selection-function (prompt collection initial-input)
"Call (`completing-read'
PROMPT COLLECTION nil nil INITIAL-INPUT 'notmuch-address-history)"
@@ -206,7 +217,8 @@ external commands."
(progn
(push chosen notmuch-address-history)
(delete-region beg end)
- (insert chosen))
+ (insert chosen)
+ (run-hook-with-args 'notmuch-address-completion-hook chosen))
(message "No matches.")
(ding))))
(t nil)))
diff --git a/emacs/notmuch-company.el b/emacs/notmuch-company.el
index 168315ff..91c4804f 100644
--- a/emacs/notmuch-company.el
+++ b/emacs/notmuch-company.el
@@ -86,6 +86,7 @@
(match (if (string-match notmuch-company-last-prefix arg)
(match-end 0)
0))
+ (post-completion (run-hook-with-args 'notmuch-address-completion-hook arg))
(no-cache t))))