* [PATCH 1/1] emacs/notmuch-address.el: add notmuch-address-selection-function
@ 2013-04-03 15:08 Tomi Ollila
2013-05-12 13:30 ` David Bremner
2013-05-14 0:37 ` David Bremner
0 siblings, 2 replies; 3+ messages in thread
From: Tomi Ollila @ 2013-04-03 15:08 UTC (permalink / raw)
To: notmuch; +Cc: tomi.ollila
Added a customizable variable notmuch-address-selection-function
and the function with the same name to provide a way for user to
change the function called to do address selection.
By default the functionality is exactly the same as it has been so
far; completing-read is called with the same parameters as before.
Setting equivalent lambda expression in place of using
notmuch-address-selection-function function is done as follows:
(setq notmuch-address-selection-function
(lambda (prompt collection initial-input)
(completing-read prompt collection nil nil initial-input)))
For example drop-in replacement with ido-completing-read can be done
easily as an one alternative to the default.
---
My replacement is:
(require 'selection-menu)
(setq notmuch-address-selection-function
(lambda (prompt collection initial-input)
(selection-menu "Send To:" collection t)))
emacs/notmuch-address.el | 23 ++++++++++++++++++++---
1 file changed, 20 insertions(+), 3 deletions(-)
diff --git a/emacs/notmuch-address.el b/emacs/notmuch-address.el
index 2bf762b..fa65cd5 100644
--- a/emacs/notmuch-address.el
+++ b/emacs/notmuch-address.el
@@ -31,6 +31,23 @@ line."
:group 'notmuch-send
:group 'notmuch-external)
+(defcustom notmuch-address-selection-function 'notmuch-address-selection-function
+ "The function to select address from given list. The function is
+called with PROMPT, COLLECTION, and INITIAL-INPUT as arguments
+(subset of what `completing-read' can be called with).
+While executed the value of `completion-ignore-case' is t.
+See documentation of function `notmuch-address-selection-function'
+to know how address selection is made by default."
+ :type 'function
+ :group 'notmuch-send
+ :group 'notmuch-external)
+
+(defun notmuch-address-selection-function (prompt collection initial-input)
+ "Call (`completing-read'
+ PROMPT COLLECTION nil nil INITIAL-INPUT 'notmuch-address-history)"
+ (completing-read
+ prompt collection nil nil initial-input 'notmuch-address-history))
+
(defvar notmuch-address-message-alist-member
'("^\\(Resent-\\)?\\(To\\|B?Cc\\|Reply-To\\|From\\|Mail-Followup-To\\|Mail-Copies-To\\):"
. notmuch-address-expand-name))
@@ -61,9 +78,9 @@ line."
((eq num-options 1)
(car options))
(t
- (completing-read (format "Address (%s matches): " num-options)
- (cdr options) nil nil (car options)
- 'notmuch-address-history)))))
+ (funcall notmuch-address-selection-function
+ (format "Address (%s matches): " num-options)
+ (cdr options) (car options))))))
(if chosen
(progn
(push chosen notmuch-address-history)
--
1.8.0
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH 1/1] emacs/notmuch-address.el: add notmuch-address-selection-function
2013-04-03 15:08 [PATCH 1/1] emacs/notmuch-address.el: add notmuch-address-selection-function Tomi Ollila
@ 2013-05-12 13:30 ` David Bremner
2013-05-14 0:37 ` David Bremner
1 sibling, 0 replies; 3+ messages in thread
From: David Bremner @ 2013-05-12 13:30 UTC (permalink / raw)
To: Tomi Ollila, notmuch
Tomi Ollila <tomi.ollila@iki.fi> writes:
> Added a customizable variable notmuch-address-selection-function
> and the function with the same name to provide a way for user to
> change the function called to do address selection.
The patch looks OK. I did notice that discussion on "selection-menu.el"
kindoff dropped off more than a year ago...
d
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH 1/1] emacs/notmuch-address.el: add notmuch-address-selection-function
2013-04-03 15:08 [PATCH 1/1] emacs/notmuch-address.el: add notmuch-address-selection-function Tomi Ollila
2013-05-12 13:30 ` David Bremner
@ 2013-05-14 0:37 ` David Bremner
1 sibling, 0 replies; 3+ messages in thread
From: David Bremner @ 2013-05-14 0:37 UTC (permalink / raw)
To: Tomi Ollila, notmuch; +Cc: tomi.ollila
Tomi Ollila <tomi.ollila@iki.fi> writes:
> Added a customizable variable notmuch-address-selection-function and
> the function with the same name to provide a way for user to change
> the function called to do address selection.
Pushed.
d
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2013-05-14 0:38 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-04-03 15:08 [PATCH 1/1] emacs/notmuch-address.el: add notmuch-address-selection-function Tomi Ollila
2013-05-12 13:30 ` David Bremner
2013-05-14 0:37 ` David Bremner
Code repositories for project(s) associated with this public inbox
https://yhetil.org/notmuch.git/
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).