mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-25 12:28:09 +01:00
contrib: pick: remove hack notmuch-pick-show-match-message-with-wait
This function was a horrible hack (sleeping while waiting for the correct message). The new target code can just open the message in the message window when it arrives.
This commit is contained in:
parent
f9aad24f02
commit
a9dbcbb00c
1 changed files with 12 additions and 25 deletions
|
@ -157,6 +157,8 @@
|
||||||
(make-variable-buffer-local 'notmuch-pick-query-context)
|
(make-variable-buffer-local 'notmuch-pick-query-context)
|
||||||
(defvar notmuch-pick-target-msg nil)
|
(defvar notmuch-pick-target-msg nil)
|
||||||
(make-variable-buffer-local 'notmuch-pick-target-msg)
|
(make-variable-buffer-local 'notmuch-pick-target-msg)
|
||||||
|
(defvar notmuch-pick-open-target nil)
|
||||||
|
(make-variable-buffer-local 'notmuch-pick-open-target)
|
||||||
(defvar notmuch-pick-buffer-name nil)
|
(defvar notmuch-pick-buffer-name nil)
|
||||||
(make-variable-buffer-local 'notmuch-pick-buffer-name)
|
(make-variable-buffer-local 'notmuch-pick-buffer-name)
|
||||||
;; This variable is the window used for the message pane. It is set
|
;; This variable is the window used for the message pane. It is set
|
||||||
|
@ -349,8 +351,8 @@ Does NOT change the database."
|
||||||
(notmuch-pick (notmuch-search-find-thread-id)
|
(notmuch-pick (notmuch-search-find-thread-id)
|
||||||
notmuch-search-query-string
|
notmuch-search-query-string
|
||||||
nil
|
nil
|
||||||
(notmuch-prettify-subject (notmuch-search-find-subject)))
|
(notmuch-prettify-subject (notmuch-search-find-subject))
|
||||||
(notmuch-pick-show-match-message-with-wait))
|
t))
|
||||||
|
|
||||||
(defun notmuch-pick-message-window-kill-hook ()
|
(defun notmuch-pick-message-window-kill-hook ()
|
||||||
(let ((buffer (current-buffer)))
|
(let ((buffer (current-buffer)))
|
||||||
|
@ -489,22 +491,6 @@ message will be \"unarchived\", i.e. the tag changes in
|
||||||
(when (window-live-p notmuch-pick-message-window)
|
(when (window-live-p notmuch-pick-message-window)
|
||||||
(notmuch-pick-show-message)))
|
(notmuch-pick-show-message)))
|
||||||
|
|
||||||
(defun notmuch-pick-show-match-message-with-wait ()
|
|
||||||
"Show the first matching message but wait for it to appear or search to finish."
|
|
||||||
(interactive)
|
|
||||||
(unless (notmuch-pick-get-match)
|
|
||||||
(notmuch-pick-next-matching-message))
|
|
||||||
(while (and (not (notmuch-pick-get-match))
|
|
||||||
(get-buffer-process (current-buffer)))
|
|
||||||
(message "waiting for message")
|
|
||||||
(sit-for 0.1)
|
|
||||||
(goto-char (point-min))
|
|
||||||
(unless (notmuch-pick-get-match)
|
|
||||||
(notmuch-pick-next-matching-message)))
|
|
||||||
(message nil)
|
|
||||||
(when (notmuch-pick-get-match)
|
|
||||||
(notmuch-pick-show-message)))
|
|
||||||
|
|
||||||
(defun notmuch-pick-refresh-view ()
|
(defun notmuch-pick-refresh-view ()
|
||||||
"Refresh view."
|
"Refresh view."
|
||||||
(interactive)
|
(interactive)
|
||||||
|
@ -658,7 +644,9 @@ unchanged ADDRESS if parsing fails."
|
||||||
(string= msg-id target))
|
(string= msg-id target))
|
||||||
(setq notmuch-pick-target-msg "found")
|
(setq notmuch-pick-target-msg "found")
|
||||||
(goto-char (point-max))
|
(goto-char (point-max))
|
||||||
(forward-line -1))))
|
(forward-line -1)
|
||||||
|
(when notmuch-pick-open-target
|
||||||
|
(notmuch-pick-show-message)))))
|
||||||
|
|
||||||
(defun notmuch-pick-insert-tree (tree depth tree-status first last)
|
(defun notmuch-pick-insert-tree (tree depth tree-status first last)
|
||||||
"Insert the message tree TREE at depth DEPTH in the current thread."
|
"Insert the message tree TREE at depth DEPTH in the current thread."
|
||||||
|
@ -778,13 +766,14 @@ Complete list of currently available key bindings:
|
||||||
(notmuch-sexp-parse-partial-list 'notmuch-pick-insert-forest-thread
|
(notmuch-sexp-parse-partial-list 'notmuch-pick-insert-forest-thread
|
||||||
results-buf)))))
|
results-buf)))))
|
||||||
|
|
||||||
(defun notmuch-pick-worker (basic-query &optional query-context target buffer)
|
(defun notmuch-pick-worker (basic-query &optional query-context target buffer open-target)
|
||||||
(interactive)
|
(interactive)
|
||||||
(notmuch-pick-mode)
|
(notmuch-pick-mode)
|
||||||
(setq notmuch-pick-basic-query basic-query)
|
(setq notmuch-pick-basic-query basic-query)
|
||||||
(setq notmuch-pick-query-context query-context)
|
(setq notmuch-pick-query-context query-context)
|
||||||
(setq notmuch-pick-buffer-name (buffer-name buffer))
|
(setq notmuch-pick-buffer-name (buffer-name buffer))
|
||||||
(setq notmuch-pick-target-msg target)
|
(setq notmuch-pick-target-msg target)
|
||||||
|
(setq notmuch-pick-open-target open-target)
|
||||||
|
|
||||||
(erase-buffer)
|
(erase-buffer)
|
||||||
(goto-char (point-min))
|
(goto-char (point-min))
|
||||||
|
@ -816,7 +805,7 @@ Complete list of currently available key bindings:
|
||||||
(insert "End of search results.\n"))))))
|
(insert "End of search results.\n"))))))
|
||||||
|
|
||||||
|
|
||||||
(defun notmuch-pick (&optional query query-context target buffer-name show-first-match)
|
(defun notmuch-pick (&optional query query-context target buffer-name open-target)
|
||||||
"Run notmuch pick with the given `query' and display the results"
|
"Run notmuch pick with the given `query' and display the results"
|
||||||
(interactive "sNotmuch pick: ")
|
(interactive "sNotmuch pick: ")
|
||||||
(if (null query)
|
(if (null query)
|
||||||
|
@ -830,11 +819,9 @@ Complete list of currently available key bindings:
|
||||||
;; Don't track undo information for this buffer
|
;; Don't track undo information for this buffer
|
||||||
(set 'buffer-undo-list t)
|
(set 'buffer-undo-list t)
|
||||||
|
|
||||||
(notmuch-pick-worker query query-context target buffer)
|
(notmuch-pick-worker query query-context target buffer open-target)
|
||||||
|
|
||||||
(setq truncate-lines t)
|
(setq truncate-lines t)))
|
||||||
(when show-first-match
|
|
||||||
(notmuch-pick-show-match-message-with-wait))))
|
|
||||||
|
|
||||||
|
|
||||||
;; Set up key bindings from the rest of notmuch.
|
;; Set up key bindings from the rest of notmuch.
|
||||||
|
|
Loading…
Reference in a new issue