unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
* [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).