notmuch.el: Preserve current thread when refreshing search results.
authorCarl Worth <cworth@cworth.org>
Tue, 3 Nov 2009 19:54:34 +0000 (11:54 -0800)
committerCarl Worth <cworth@cworth.org>
Tue, 3 Nov 2009 19:54:34 +0000 (11:54 -0800)
Otherwise, try to keep point in the same place, (such as when the
current thread has been archived away).

notmuch.el

index c00d359598a85b05d4b699c8e7079c0284d810a9..a7e334e45ef7106855c34901151c28c927320e60 100644 (file)
@@ -420,11 +420,20 @@ Before moving, also remove the \"unread\" tag from the current message."
   "Refresh the current view.
 
 Kills the current buffer and runs a new search with the same
-query string as the current search."
+query string as the current search. If the current thread is in
+the new search results, then point will be placed on the same
+thread. Otherwise, point will be moved to attempt to be in the
+same relative position within the new buffer."
   (interactive)
-  (let ((query notmuch-search-query-string))
+  (let ((here (point))
+       (thread (notmuch-search-find-thread-id))
+       (query notmuch-search-query-string))
     (kill-this-buffer)
-    (notmuch-search query)))
+    (notmuch-search query)
+    (goto-char (point-min))
+    (if (re-search-forward (concat "^" thread) nil t)
+       (beginning-of-line)
+      (goto-char here))))
 
 (defun notmuch-search-filter (query)
   "Run \"notmuch search\" to refine the current search results.