X-Git-Url: https://git.notmuchmail.org/git?a=blobdiff_plain;f=emacs%2Fnotmuch-show.el;h=f958a3061440b66e9b0cc7c72adeaaed27b675e0;hb=a88d1d277bea178c8623e0e6a3671ff1fe13fd60;hp=95874bb26bc1161d7a23dbf8363648aa5a8cb946;hpb=e6bc99f31ffc644fde059ab6fb31b3289c13c8f1;p=notmuch diff --git a/emacs/notmuch-show.el b/emacs/notmuch-show.el index 95874bb2..f958a306 100644 --- a/emacs/notmuch-show.el +++ b/emacs/notmuch-show.el @@ -37,14 +37,30 @@ (declare-function notmuch-select-tag-with-completion "notmuch" (prompt &rest search-terms)) (declare-function notmuch-search-show-thread "notmuch" nil) -(defvar notmuch-show-headers '("Subject" "To" "Cc" "From" "Date") - "Headers that should be shown in a message, in this order. Note -that if this order is changed the headers shown when a message is -collapsed will change.") +(defcustom notmuch-message-headers '("Subject" "To" "Cc" "Date") + "Headers that should be shown in a message, in this order. + +For an open message, all of these headers will be made visible +according to `notmuch-message-headers-visible' or can be toggled +with `notmuch-show-toggle-headers'. For a closed message, only +the first header in the list will be visible." + :group 'notmuch + :type '(repeat string)) + +(defcustom notmuch-message-headers-visible t + "Should the headers be visible by default? + +If this value is non-nil, then all of the headers defined in +`notmuch-message-headers' will be visible by default in the display +of each message. Otherwise, these headers will be hidden and +`notmuch-show-toggle-headers' can be used to make the visible for +any given message." + :group 'notmuch + :type 'boolean) (defvar notmuch-show-markup-headers-hook '(notmuch-show-colour-headers) "A list of functions called to decorate the headers listed in -`notmuch-show-headers'.") +`notmuch-message-headers'.") (defvar notmuch-show-hook '(notmuch-show-pretty-hook) "A list of functions called after populating a @@ -198,7 +214,7 @@ message at DEPTH in the current thread." (if (and header-value (not (string-equal "" header-value))) (notmuch-show-insert-header header header-value)))) - notmuch-show-headers) + notmuch-message-headers) (save-excursion (save-restriction (narrow-to-region start (point-max)) @@ -416,8 +432,8 @@ current buffer, if possible." ;; the content). (notmuch-show-set-message-properties msg) - ;; Headers are hidden by default. - (notmuch-show-headers-visible msg nil) + ;; Set header visibility. + (notmuch-show-headers-visible msg notmuch-message-headers-visible) ;; Message visibility depends on whether it matched the search ;; criteria. @@ -526,7 +542,7 @@ function is used. " (define-key map "p" 'notmuch-show-previous-open-message) (define-key map (kbd "DEL") 'notmuch-show-rewind) (define-key map " " 'notmuch-show-advance-and-archive) - (define-key map (kbd "M-RET") 'notmuch-show-toggle-all) + (define-key map (kbd "M-RET") 'notmuch-show-open-or-close-all) (define-key map (kbd "RET") 'notmuch-show-toggle-message) map) "Keymap for \"notmuch show\" buffers.") @@ -907,10 +923,10 @@ to stdout or stderr will appear in the *Messages* buffer." (not (plist-get props :message-visible)))) (force-window-update)) -(defun notmuch-show-toggle-all () - "Change the visibility all of the messages in the current -thread. By default make all of the messages visible. With a -prefix argument, make them all not visible." +(defun notmuch-show-open-or-close-all () + "Set the visibility all of the messages in the current thread. +By default make all of the messages visible. With a prefix +argument, hide all of the messages." (interactive) (save-excursion (goto-char (point-min))