[PATCH] v2 [RFC] emacs: merge overhauled `notmuch-cycle-notmuch-buffers' into `notmuch'
Pieter Praet
pieter at praet.org
Mon Jan 16 08:46:55 PST 2012
Make `notmuch-cycle-notmuch-buffers' more Lispy and merge into `notmuch',
eliminating the need to hog yet another keybind.
---
emacs/notmuch.el | 40 ++++++++++++++--------------------------
1 files changed, 14 insertions(+), 26 deletions(-)
diff --git a/emacs/notmuch.el b/emacs/notmuch.el
index ef4dcc7..539b3a0 100644
--- a/emacs/notmuch.el
+++ b/emacs/notmuch.el
@@ -1067,7 +1067,20 @@ current search results AND that are tagged with the given tag."
(defun notmuch ()
"Run notmuch and display saved searches, known tags, etc."
(interactive)
- (notmuch-hello))
+ (let* ((old-buffer (current-buffer))
+ (interesting-buffers
+ (delq nil (mapcar (lambda (b)
+ (if (notmuch-interesting-buffer b) b))
+ (buffer-list))))
+ (next-buffer (first
+ (delq nil (mapcar (lambda (b)
+ (unless (eq old-buffer b) b))
+ interesting-buffers)))))
+ (if next-buffer
+ (progn
+ (switch-to-buffer next-buffer)
+ (bury-buffer old-buffer))
+ (notmuch-hello))))
(defun notmuch-interesting-buffer (b)
"Is the current buffer of interest to a notmuch user?"
@@ -1078,31 +1091,6 @@ current search results AND that are tagged with the given tag."
message-mode))))
;;;###autoload
-(defun notmuch-cycle-notmuch-buffers ()
- "Cycle through any existing notmuch buffers (search, show or hello).
-
-If the current buffer is the only notmuch buffer, bury it. If no
-notmuch buffers exist, run `notmuch'."
- (interactive)
-
- (let (start first)
- ;; If the current buffer is a notmuch buffer, remember it and then
- ;; bury it.
- (when (notmuch-interesting-buffer (current-buffer))
- (setq start (current-buffer))
- (bury-buffer))
-
- ;; Find the first notmuch buffer.
- (setq first (loop for buffer in (buffer-list)
- if (notmuch-interesting-buffer buffer)
- return buffer))
-
- (if first
- ;; If the first one we found is any other than the starting
- ;; buffer, switch to it.
- (unless (eq first start)
- (switch-to-buffer first))
- (notmuch))))
(setq mail-user-agent 'notmuch-user-agent)
--
1.7.8.1
More information about the notmuch
mailing list