X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=notmuch.el;h=00a03c0ed7c1ea979f417ecc8a346b0a064bd2ef;hp=54f4a5812e997a2db270164af380f8127c5bc955;hb=a81849b5e21632cfca7d634d718501f67219bb60;hpb=07b2ef26de452e6ef9f98747e36077c2620d3bce diff --git a/notmuch.el b/notmuch.el index 54f4a581..00a03c0e 100644 --- a/notmuch.el +++ b/notmuch.el @@ -33,12 +33,38 @@ (defvar notmuch-show-mode-map (let ((map (make-sparse-keymap))) + (define-key map "n" 'notmuch-show-next-message) + (define-key map "p" 'notmuch-show-previous-message) (define-key map "q" 'kill-this-buffer) (define-key map "x" 'kill-this-buffer) map) "Keymap for \"notmuch show\" buffers.") (fset 'notmuch-show-mode-map notmuch-show-mode-map) +(defvar notmuch-show-message-begin-regexp " message{") + +(defun notmuch-show-next-message () + "Advance point to the beginning of the next message in the buffer." + (interactive) + ; First, ensure we get off the current message marker + (if (not (eobp)) + (forward-char)) + (if (not (re-search-forward notmuch-show-message-begin-regexp nil t)) + (goto-char (point-max))) + (beginning-of-line) + (recenter 0)) + +(defun notmuch-show-previous-message () + "Advance point to the beginning of the previous message in the buffer." + (interactive) + ; First, ensure we get off the current message marker + (if (not (eobp)) + (forward-char)) + (if (not (re-search-backward notmuch-show-message-begin-regexp nil t)) + (goto-char (point-min))) + (beginning-of-line) + (recenter 0)) + ;;;###autoload (defun notmuch-show-mode () "Major mode for handling the output of \"notmuch show\""