From: Eli Zaretskii <eliz@gnu.org>
To: Stefan Monnier <monnier@IRO.UMontreal.CA>
Cc: 31067@debbugs.gnu.org
Subject: bug#31067: 27.0.50; After-string hidden by subsequent invisible text
Date: Thu, 05 Apr 2018 21:00:28 +0300 [thread overview]
Message-ID: <83tvsp1qkj.fsf@gnu.org> (raw)
In-Reply-To: <jwvk1tllkwg.fsf-monnier+emacsbugs@gnu.org> (message from Stefan Monnier on Thu, 05 Apr 2018 11:55:43 -0400)
> From: Stefan Monnier <monnier@IRO.UMontreal.CA>
> Cc: 31067@debbugs.gnu.org
> Date: Thu, 05 Apr 2018 11:55:43 -0400
>
> >> If some (or all) of the end of the overlay-with-after-string is made
> >> invisible, then the situation is much less clear and I could see
> >> arguments either way, but if I get to choose then I think it makes sense
> >> to consider that the after string is "attached" to the end of the
> >> overlay, i.e. if the end of the overlay is invisible then so is the
> >> after-string.
> > But that's exactly what happens in your original example.
>
> Hmmm.... not that I can see: the overlay covers "text" and none of it
> is hidden.
The overlay's end point is _after_ "text", and that's exactly where
the invisible text starts. And after-string _follows_ the end of
"text", so it starts where the invisible text starts.
> I guess you could pay attention to the stickiness of the boundaries
I don't think stickiness has anything to do with this. I could
explain how the particular implementation of these features causes the
after-string to be skipped in this case, but I prefer that we first
establish the principles and the concepts. From my POV, the
implementation does what it does because it considers after-string,
conceptually, to _follow_ the end-point of the overlay, and in this
case what follows it is invisible.
> And think this one is even more
> clearly a bug, because according to stickiness the two overlays "don't
> touch" (as can be tested by carefully moving point right after the "t" and
> inserting "-" which gives you a display of "text!after!-" showing that
> the "-" was inserted between the two overlays rather than into the
> first or into the second or into both).
They cannot "not touch", because there's nothing between 'after
"text"' and 'before the following point'. The fact that inserting a
character behaves in some specific way doesn't matter, because the
display engine doesn't (and shouldn't) consider stickiness, it only
considers which display elements follow which.
> I meant "if the last few chars covered by the overlay (or the whole
> text covered by the overlay) is made invisible ...".
And that's what happens: the overlay's end-point is made invisible.
next prev parent reply other threads:[~2018-04-05 18:00 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-04-05 2:28 bug#31067: 27.0.50; After-string hidden by subsequent invisible text Stefan Monnier
2018-04-05 9:49 ` Eli Zaretskii
2018-04-05 12:23 ` Stefan Monnier
2018-04-05 13:38 ` Eli Zaretskii
2018-04-05 15:55 ` Stefan Monnier
2018-04-05 18:00 ` Eli Zaretskii [this message]
2018-04-05 19:15 ` Stefan Monnier
2018-04-06 8:24 ` Eli Zaretskii
2018-04-06 12:28 ` Stefan Monnier
2018-04-06 13:11 ` Eli Zaretskii
[not found] ` <<83k1tk214a.fsf@gnu.org>
2018-04-06 15:39 ` Drew Adams
2018-04-06 17:10 ` Eli Zaretskii
[not found] <<jwvmuyi9yj8.fsf@iro.umontreal.ca>
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=83tvsp1qkj.fsf@gnu.org \
--to=eliz@gnu.org \
--cc=31067@debbugs.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 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).