From: Stephen Berman <stephen.berman@gmx.net>
To: Eli Zaretskii <eliz@gnu.org>
Cc: emacs-devel@gnu.org
Subject: Re: line-number-mode at EOB
Date: Tue, 18 Jul 2017 18:33:08 +0200 [thread overview]
Message-ID: <87zic1aenv.fsf@rosalinde> (raw)
In-Reply-To: <83a841dcb6.fsf@gnu.org> (Eli Zaretskii's message of "Tue, 18 Jul 2017 17:55:41 +0300")
On Tue, 18 Jul 2017 17:55:41 +0300 Eli Zaretskii <eliz@gnu.org> wrote:
>> From: Stephen Berman <stephen.berman@gmx.net>
>> Cc: emacs-devel@gnu.org
>> Date: Tue, 18 Jul 2017 00:20:10 +0200
>>
>> > By that reasoning, line-number-mode (the %l construct) should be changed
>> > so as not to display a number when point is at EOB. Perhaps it should
>> > display "EOB" or "END" instead.
>>
>> I attempted to implement this change in the mode line display (see
>> attached patch) and the result, while admittedly only "minor aesthetic
>> sugar", seems to me not too bad: it makes line-number-mode consistent
>> not only with vertically displayed line numbers but also with
>> `count-words-region' (and hence with `count-lines'). What do others
>> think?
>
> Hmm... I don't understand why you needed to change the format spec to
> %l, and also why the change in mode_line_update_needed. Isn't it
> enough to just produce "EOB" instead of a number?
If just mode-line-position in bindings.el is changed, that fails to
update the mode line frequently enough: if you go to point-max in
*scratch*, so the mode line displays "EOB", then continually typing C-b
or C-p doesn't change the "EOB". Conversely, if just decode_mode_spec
is changed to output "EOB" at point-max, the current code in
mode-line-position will make the mode line display "LEOB" when
column-number-mode is disabled. Finally, even with both of the other
changes, without the change in mode_line_update_needed, if the character
immediately before EOB is not a newline (and column-number-mode is not
enabled), then if point is at EOB, continually typing C-b will keep
displaying "EOB" until the line number changes, and if point in on the
last line but before EOB, typing C-f to move to EOB will not change the
display to "EOB".
>> static bool
>> mode_line_update_needed (struct window *w)
>> {
>> - return (w->column_number_displayed != -1
>> - && !(PT == w->last_point && !window_outdated (w))
>> - && (w->column_number_displayed != current_column ()));
>> + return ((w->column_number_displayed != -1
>> + && !(PT == w->last_point && !window_outdated (w))
>> + && (w->column_number_displayed != current_column ()))
>> + || (line_number_displayed
>> + && ((ZV == w->last_point && PT != ZV)
>> + || (ZV != w->last_point && PT == ZV))));
>
> The last 2 lines can be written more succinctly as
>
> && ((ZV == w->last_point) != (PT == ZV))
Thanks! (I felt sure there was a shorter equivalent expression, but it
was late when I posted and I couldn't get my head around it.)
Steve Berman
next prev parent reply other threads:[~2017-07-18 16:33 UTC|newest]
Thread overview: 49+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-06-24 17:27 Native display of line numbers, improved Eli Zaretskii
2017-06-24 18:40 ` Clément Pit-Claudel
2017-06-24 18:51 ` Eli Zaretskii
2017-06-24 20:53 ` Stephen Berman
2017-06-25 14:07 ` Eli Zaretskii
2017-06-25 14:34 ` Stephen Berman
2017-06-25 15:10 ` Eli Zaretskii
2017-06-25 15:41 ` Stephen Berman
2017-06-25 16:02 ` Eli Zaretskii
2017-06-25 19:00 ` Stephen Berman
2017-06-24 21:23 ` Stephen Berman
2017-06-25 14:03 ` Eli Zaretskii
2017-06-25 14:34 ` Stephen Berman
2017-06-25 14:57 ` Eli Zaretskii
2017-07-17 22:20 ` line-number-mode at EOB (was: Native display of line numbers, improved) Stephen Berman
2017-07-18 4:16 ` line-number-mode at EOB Stefan Monnier
2017-07-18 14:04 ` Stephen Berman
2017-07-18 14:30 ` Stefan Monnier
2017-07-18 14:51 ` Eli Zaretskii
2017-07-18 15:04 ` Stefan Monnier
2017-07-20 20:25 ` Paul Eggert
2017-07-20 20:43 ` Stephen Berman
2017-07-20 21:19 ` Paul Eggert
2017-07-20 21:35 ` Stephen Berman
2017-07-18 14:55 ` line-number-mode at EOB (was: Native display of line numbers, improved) Eli Zaretskii
2017-07-18 16:33 ` Stephen Berman [this message]
2017-07-18 19:03 ` line-number-mode at EOB Eli Zaretskii
2017-07-18 20:38 ` Stephen Berman
2017-06-25 9:59 ` Native display of line numbers, improved martin rudalics
2017-06-25 13:54 ` Eli Zaretskii
2017-06-25 15:58 ` martin rudalics
2017-06-25 20:30 ` Alex
2017-06-26 2:39 ` Eli Zaretskii
2017-06-26 3:43 ` Alex
2017-06-26 3:50 ` Alex
2017-06-26 14:58 ` Eli Zaretskii
2017-06-26 19:41 ` Alex
2017-06-27 14:25 ` Eli Zaretskii
2017-06-29 20:25 ` Native line numbers column disappears at times Kaushal Modi
2017-06-30 6:00 ` Eli Zaretskii
2017-07-10 18:53 ` Kaushal Modi
2017-07-10 19:31 ` Eli Zaretskii
2017-07-10 20:56 ` Kaushal Modi
2017-06-26 14:54 ` Native display of line numbers, improved Eli Zaretskii
2017-06-26 15:28 ` Stefan Monnier
2017-06-26 15:56 ` Eli Zaretskii
2017-06-26 16:12 ` Stefan Monnier
2017-06-26 16:26 ` Eli Zaretskii
2017-06-26 19:36 ` Alex
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87zic1aenv.fsf@rosalinde \
--to=stephen.berman@gmx.net \
--cc=eliz@gnu.org \
--cc=emacs-devel@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).