X-Git-Url: https://git.notmuchmail.org/git?a=blobdiff_plain;f=emacs%2Fnotmuch-show.el;h=aa8041c2cbcdad5a6c24fdf54281a6d7495f202c;hb=a9bf967e71cca6eb220063ee50b94a7601bc2b96;hp=203528fd62f8438a67b15672e99642f60d4fddd7;hpb=1291d1dcb17280d8a98ebd4197b4524ef89cf771;p=notmuch diff --git a/emacs/notmuch-show.el b/emacs/notmuch-show.el index 203528fd..aa8041c2 100644 --- a/emacs/notmuch-show.el +++ b/emacs/notmuch-show.el @@ -37,26 +37,59 @@ (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) +(defcustom notmuch-show-hook '(notmuch-show-pretty-hook) "A list of functions called after populating a -`notmuch-show' buffer.") - -(defvar notmuch-show-insert-text/plain-hook '(notmuch-wash-text/plain-citations) - "A list of functions called to clean up text/plain body parts.") +`notmuch-show' buffer." + :group 'notmuch + :type 'hook + :options '(notmuch-show-pretty-hook + notmuch-show-turn-off-word-wrap)) + +(defcustom notmuch-show-insert-text/plain-hook + '(notmuch-wash-tidy-citations + notmuch-wash-compress-blanks + notmuch-wash-markup-citations) + "A list of functions called to clean up text/plain body parts." + :group 'notmuch + :type 'hook + :options '(notmuch-wash-wrap-long-lines + notmuch-wash-tidy-citations + notmuch-wash-compress-blanks + notmuch-wash-markup-citations)) (defun notmuch-show-pretty-hook () (goto-address-mode 1) (visual-line-mode)) +(defun notmuch-show-turn-off-word-wrap () + ;; `toggle-word-wrap' outputs a message, which is distracting. + (setq word-wrap nil)) + (defmacro with-current-notmuch-show-message (&rest body) "Evaluate body with current buffer set to the text of current message" `(save-excursion @@ -198,7 +231,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 +449,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.