all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Eli Zaretskii <eliz@gnu.org>
To: Stefan Monnier <monnier@iro.umontreal.ca>
Cc: emacs-devel@gnu.org
Subject: Re: show-enclosing-scopes
Date: Thu, 17 May 2018 18:07:29 +0300	[thread overview]
Message-ID: <83wow2iamm.fsf@gnu.org> (raw)
In-Reply-To: <jwvtvr6749s.fsf-monnier+gmane.emacs.devel@gnu.org> (message from Stefan Monnier on Thu, 17 May 2018 10:31:44 -0400)

> From: Stefan Monnier <monnier@iro.umontreal.ca>
> Date: Thu, 17 May 2018 10:31:44 -0400
> 
> > (progn (scroll-up 1) (beginning-of-buffer))
> 
> So you have here an ambiguous specification: on the one hand you
> specified the window-start via scroll-up, on the other you specified
> point with beginning-of-buffer.  Since point needs to be within the
> visible part of the buffer, the redisplay engine has to choose which of
> the two requests to override.

Right.  And using scroll commands forces redisplay to obey the
window-start setting.

> Now the question is why does your package end up in situations with such
> ambiguous specifications?

I don't understand that, either.  I looked at the relevant code in the
package, and my interpretation is this:

  . scroll-up/down is used to prevent text in the window from moving
    vertically when the window showing the scopes is deleted: without
    the scroll, text would move up, since the window to be deleted is
    above the window showing the current buffer.  (Why the scopes
    window needs to be deleted and recreated anew each command, and
    why is it shown above and not below, are two other relevant
    questions, but let's assume it's indeed required.)
  . goto-char is called in the same function that calls scroll-up/down
    so that point is kept where it was before

Assuming that my interpretation is accurate, I have two questions:

  . why is there a need to call goto-char at all?  Since all the text
    that was visible before the scroll will also be visible after it,
    point should be visible as well, and there should be no need to
    move it.

  . if indeed there is a need to move point due to some factor I'm
    missing, that goto-char should bring point back into the window,
    in which case redisplay will not need to move point again.  IOW,
    using beginning-of-buffer in the short recipe posted to explain
    the problem does not seem to be representative of the real-life
    use, and I again don't understand the need for calling 'redisplay'
    to avoid something.

> Assuming you don't have any control over the scroll-up part and you want
> to override it via beginning-of-buffer, there is indeed currently no
> easy way to get that, AFAICT: this is controlled by the `force_start`
> field in the window which will have been set by scroll-up (and can be
> set via set-window-start) but can't be "unset" directly.
> Maybe you can try
> 
>     (defun my-unset-window-force-start ()
>       (cl-assert (eq (current-buffer) (window-buffer)))
>       (save-excursion
>         (let ((buf (current-buffer)))
>           (with-temp-buffer
>             (set-window-buffer (selected-window) (current-buffer) 'keep-margins)
>             (set-window-buffer (selected-window) buf 'keep-margins)))))
> 
> since it seems that set-window-buffer does unset `force-start`.
> It will also cause undesirable side-effects, but maybe in your case they
> will be less annoying than those of `redisplay`.

I'd say if it is known that the goal point is not inside the visible
portion of the buffer after scrolling, don't scroll at all; instead,
just move point to the goal.

But as I said above, I don't think I understand the details well
enough yet.



  reply	other threads:[~2018-05-17 15:07 UTC|newest]

Thread overview: 24+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-05-16  6:41 show-enclosing-scopes Jefferson Carpenter
2018-05-16  8:03 ` show-enclosing-scopes Eli Zaretskii
2018-05-16 21:46   ` show-enclosing-scopes Jefferson Carpenter
2018-05-17 14:31     ` show-enclosing-scopes Stefan Monnier
2018-05-17 15:07       ` Eli Zaretskii [this message]
2018-05-17 17:41         ` show-enclosing-scopes Stefan Monnier
2018-05-17 19:16           ` show-enclosing-scopes Eli Zaretskii
2018-05-17 20:24             ` show-enclosing-scopes Stefan Monnier
2018-05-18  1:13               ` show-enclosing-scopes Jefferson Carpenter
2018-05-18  1:16                 ` show-enclosing-scopes Jefferson Carpenter
2018-05-18  6:15                   ` show-enclosing-scopes Eli Zaretskii
2018-05-18  2:22                 ` show-enclosing-scopes Stefan Monnier
2018-05-18  6:02                   ` show-enclosing-scopes Jefferson Carpenter
2018-05-18  6:18                     ` show-enclosing-scopes Jefferson Carpenter
2018-05-18  6:26                       ` show-enclosing-scopes Jefferson Carpenter
2018-05-18  7:01                       ` show-enclosing-scopes Eli Zaretskii
2018-05-18  8:46                     ` show-enclosing-scopes Eli Zaretskii
2018-05-19  4:17                       ` show-enclosing-scopes Jefferson Carpenter
2018-05-19  8:38                         ` show-enclosing-scopes Eli Zaretskii
2018-05-21  3:31                           ` show-enclosing-scopes Jefferson Carpenter
2018-05-25  7:07                             ` show-enclosing-scopes Jefferson Carpenter
2018-05-18  9:02                     ` show-enclosing-scopes Eli Zaretskii
2018-06-03 18:35                       ` show-enclosing-scopes Jefferson Carpenter
  -- strict thread matches above, loose matches on Subject: below --
2018-05-16  6:40 show-enclosing-scopes Jefferson Carpenter

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=83wow2iamm.fsf@gnu.org \
    --to=eliz@gnu.org \
    --cc=emacs-devel@gnu.org \
    --cc=monnier@iro.umontreal.ca \
    /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.