[PATCH 3/6] emacs: modify notmuch-search-tag to not prompt if tags provided as argument
Jameson Graef Rollins
jrollins at finestructure.net
Mon Apr 2 01:20:50 PDT 2012
If the argument is a full string or a list, the function will assume
this is a tag string or list and will not prompt the user. If the
argument is nil or the exact strings "-" or "+" then the user will be
prompted.
The function doc is updated accordingly.
---
emacs/notmuch.el | 16 ++++++++++++----
1 files changed, 12 insertions(+), 4 deletions(-)
diff --git a/emacs/notmuch.el b/emacs/notmuch.el
index 0ab8fc2..3b78584 100644
--- a/emacs/notmuch.el
+++ b/emacs/notmuch.el
@@ -646,13 +646,21 @@ added or removed for all threads in the region from BEG to END."
(notmuch-update-tags (notmuch-search-get-tags) tag-changes))
(forward-line))))))
-(defun notmuch-search-tag (&optional initial-input)
- "Change tags for the currently selected thread or region."
+(defun notmuch-search-tag (&optional tags)
+ "Change tags for the currently selected thread or region.
+
+If TAGS is a string or list it will be interpreted as tags to
+apply to the selected messages. If TAGS is nil or either of the
+strings `-' or `+' the user will be prompted to enter tags (with
+tab completion)."
(interactive)
(let* ((beg (if (region-active-p) (region-beginning) (point)))
(end (if (region-active-p) (region-end) (point)))
- (search-string (notmuch-search-find-thread-id-region-search beg end))
- (tags (notmuch-read-tag-changes initial-input search-string)))
+ (search-string (notmuch-search-find-thread-id-region-search beg end)))
+ (if (string-or-null-p tags)
+ (if (or (string= tags "-") (string= tags "+") (eq tags nil))
+ (setq tags (notmuch-read-tag-changes tags search-string))
+ (setq tags (list tags))))
(apply 'notmuch-search-tag-region beg end tags)))
(defun notmuch-search-add-tag ()
--
1.7.9.1
More information about the notmuch
mailing list