all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Dmitry Gutov <dgutov@yandex.ru>
To: Eli Zaretskii <eliz@gnu.org>
Cc: 13133@debbugs.gnu.org
Subject: bug#13133: 24.2.90; scroll-conservatively is too coarse a setting
Date: Mon, 10 Dec 2012 12:28:58 +0400	[thread overview]
Message-ID: <50C59D4A.5020409@yandex.ru> (raw)
In-Reply-To: <83wqwqbd08.fsf@gnu.org>

On 10.12.2012 11:08, Eli Zaretskii wrote:
>> Date: Mon, 10 Dec 2012 10:46:51 +0400
>> From: Dmitry Gutov <dgutov@yandex.ru>
>> CC: 13133@debbugs.gnu.org
>>
>>>> Examples:
>>>> 1) I want help-button-action to bring me to the function's definition,
>>>> and I generally want in the middle of the screen. Same for imenu, etc.
>>>> 2) I really don't want to see empty space after the contents in the
>>>> compilation window. But as much as half of the window may be empty right
>>>> after compilation because of the point recentering.
>>>> 3) Ideally, if I move around with next/previous-line, I don't want
>>>> sudden jumps and recenterings. Same thing with beginning/end-of-defun
>>>> (so setting scroll-conservatively to a value larger than 0 is not a real
>>>> solution).
>>>
>>> I'm sorry, but the problem you describing is entirely unclear to me.
>>> You didn't say what value, if any, did you set scroll-conservatively
>>> to, nor if you have any other scroll-* variables customized to
>>> non-default values.  If you don't customize anything, Emacs always
>>> re-centers when point goes out of sight.  When point is re-centered, I
>>> don't think you can ever have half-window of empty space, because of
>>> the way re-centering works.
>>>
>>> Given this lack of information, I don't understand how you get the
>>> adverse effects in your 3 examples.  Please elaborate, perhaps
>>> separately about each of the examples.
>>
>> The problem is getting all 3 to work at the same time.
>>
>> For 1, scroll-conservatively needs to be < 100, something like 0-10, so
>> that recentering usually happens.
>> For 2, I have to set scroll-conservatively to 101. Some lower values may
>> also help, but there's no guarantee, as I understand it: the contents of
>> the compilation buffer are getting added in large chunks.
>> For 3, again, I have to set scroll-conservatively to a large value. For
>> C-n/C-p, the value of 5 is usually enough, for for C-M-e/C-M-a, it often
>> has to be larger than that.
>
> Why can't you use a value of scroll-conservatively around 10, then?

Just tried that with compilation, didn't help. In fact, I have to set it 
as large as 50 to not see empty space in the window (tried 40, no dice).
And that's with one specific compilation process. Run something that's 
twice as verbose, and the value will have to be 100, no?

> The way I see it, the only problem might be with 2, and even there I'm
> not sure you will see it frequently, or ever.  For 3, C-M-e/C-M-a will
> DTRT and show point in the middle of the window, unless the function
> is very short, in which case point will be near the beginning or end
> of the window; again, TRT.

Like I mentioned, I don't want C-M-e/C-M-a to recenter. Why do you think 
it's TRT?
As far as I'm concerned, recentering might be fine when we go to the end 
of a small function (it will fit on the screen anyway), but a larger 
function, which might have fit on the full screen, will be cut in half.

>> Half-window happens because when the compilation buffer is filled, the
>> point is at the end of it (when compilation-scroll-output is t, at least).
>
> Does this happen with or without setting scroll-conservatively to a
> value larger than 100?

Without.

> Just for the record: when I asked whether people who like Emacs to
> _never_ recenter would mind having that behavior in contexts that have
> nothing to do with scrolling, the response was a huge YES.  So the
> current behavior seems to be "by popular demand".

If I had to guess, it might be that people just wanted out of the 
default always-recentering behavior, and it was a quick way to end the 
discussion and get the implementation.

Anyway, I don't remember seeing that poll. And if you were asking on 
emacs-devel, that doesn't exactly represent the majority of users.

I don't think I'm asking for anything exotic here, really. I think all 3 
items are pretty much the standard in "modern" editors or IDEs.

> Another possibility would be to add more customization values to
> compilation-scroll-output, implementing the behavior of your
> compile-scroll-eob.

Yes, sure. Just set buffer-local value of scroll-conservatively, maybe?

But that won't help with C-M-a/C-M-e and, I don't know, any other 
buffers with deal with process output? I think the compilation buffer is 
a great example that not only doesn't have anything to do with 
scrolling, but also is unrelated to code navigation. And still, 
scroll-conservatively is used there.

> I won't argue what the default behavior should be, because it tends to
> become bike-shedding very fast.  FWIW, I use the default behavior,
> without customizing any scroll-related variables, and like that
> behavior, including in compilation buffers.

Do you like the behavior of compilation buffer often having wasted 
space, or do you just not mind it (with monitors being cheap and all)? I 
don't see what anyone could really like about it.





  reply	other threads:[~2012-12-10  8:28 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-12-10  3:29 bug#13133: 24.2.90; scroll-conservatively is too coarse a setting Dmitry Gutov
2012-12-10  6:30 ` Eli Zaretskii
2012-12-10  6:46   ` Dmitry Gutov
2012-12-10  7:08     ` Eli Zaretskii
2012-12-10  8:28       ` Dmitry Gutov [this message]
2012-12-10  8:52         ` Eli Zaretskii
2012-12-11  2:07           ` Dmitry Gutov
2012-12-11  7:09             ` Eli Zaretskii

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

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=50C59D4A.5020409@yandex.ru \
    --to=dgutov@yandex.ru \
    --cc=13133@debbugs.gnu.org \
    --cc=eliz@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 external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.