emacs: wash: make word-wrap bound message width

Previously if notmuch-wash-wrap-lines-length was set then all messages
would be wrapped at this value (or window-width if that is
smaller). This was done regardless of the message's depth in a thread --
for example, if the n.w.w.l.l is 80 and the messages depth is 20
(so indented 20 by default) the messages text only got 60 characters
of space.

This commit changes that so a message always gets the full n.w.w.l.l
of width regardless of its indentation (unless that goes over
window-width of course).
This commit is contained in:
Mark Walters 2016-08-06 16:29:34 +01:00 committed by David Bremner
parent f949215207
commit 7b7960ea22

View file

@ -122,8 +122,8 @@ collapse the remaining lines into a button."
If this is nil, lines in messages will be wrapped to fit in the If this is nil, lines in messages will be wrapped to fit in the
current window. If this is a number, lines will be wrapped after current window. If this is a number, lines will be wrapped after
this many characters or at the window width (whichever one is this many characters (ignoring indentation due to thread depth)
lower)." or at the window width (whichever one is lower)."
:type '(choice (const :tag "window width" nil) :type '(choice (const :tag "window width" nil)
(integer :tag "number of characters")) (integer :tag "number of characters"))
:group 'notmuch-wash) :group 'notmuch-wash)
@ -338,7 +338,7 @@ the wrapped text are maintained."
(let* ((coolj-wrap-follows-window-size nil) (let* ((coolj-wrap-follows-window-size nil)
(indent (* depth notmuch-show-indent-messages-width)) (indent (* depth notmuch-show-indent-messages-width))
(limit (if (numberp notmuch-wash-wrap-lines-length) (limit (if (numberp notmuch-wash-wrap-lines-length)
(min notmuch-wash-wrap-lines-length (min (+ notmuch-wash-wrap-lines-length indent)
(window-width)) (window-width))
(window-width))) (window-width)))
(fill-column (- limit (fill-column (- limit