notmuch.el: Make next-message move to end of buffer after last message.
authorCarl Worth <cworth@cworth.org>
Wed, 4 Nov 2009 19:03:07 +0000 (11:03 -0800)
committerCarl Worth <cworth@cworth.org>
Wed, 4 Nov 2009 19:03:07 +0000 (11:03 -0800)
We need an easier way to detect when we're done with the last message
so taking advantage of the end-of-buffer position helps here.

notmuch.el

index 16ca037ed5573757280116f82e04b72503c856ed..849654b72945f19bc6a62d46402c43241efe34ce 100644 (file)
@@ -150,12 +150,13 @@ by searching backward)."
 (defun notmuch-show-next-message ()
   "Advance to the beginning of the next message in the buffer.
 
-Moves to the beginning of the current message if already on the
-last message in the buffer."
+Moves to the end of the buffer if already on the last message in
+the buffer."
   (interactive)
   (notmuch-show-move-to-current-message-summary-line)
-  (re-search-forward notmuch-show-message-begin-regexp nil t)
-  (notmuch-show-move-to-current-message-summary-line)
+  (if (re-search-forward notmuch-show-message-begin-regexp nil t)
+      (notmuch-show-move-to-current-message-summary-line)
+    (goto-char (point-max)))
   (recenter 0))
 
 (defun notmuch-show-find-next-message ()
@@ -218,9 +219,10 @@ which this thread was originally shown."
     (if (and (not unread)
             (equal next (point)))
        (notmuch-show-archive-thread)
-      (if (< (notmuch-show-find-next-message) (window-end))
-         (notmuch-show-mark-read-then-next-message)
-       (scroll-up nil)))))
+      (if (and (> next (window-end))
+              (< next (point-max)))
+         (scroll-up nil)
+       (notmuch-show-mark-read-then-next-message)))))
 
 (defun notmuch-show-markup-citations-region (beg end)
   (goto-char beg)