GNU bug report logs -
#75291
Redisplay not updating fringe when face filter changes
Previous Next
Reported by: Daniel Colascione <dancol <at> dancol.org>
Date: Thu, 2 Jan 2025 17:31:02 UTC
Severity: normal
Merged with 74876
Found in version 31.0.50
Done: Eli Zaretskii <eliz <at> gnu.org>
Bug is archived. No further changes may be made.
Full log
Message #17 received at 75291 <at> debbugs.gnu.org (full text, mbox):
merge 75291 74876
thanks
> From: Daniel Colascione <dancol <at> dancol.org>
> Cc: 75291 <at> debbugs.gnu.org, Michal Nazarewicz <mina86 <at> mina86.com>
> Date: Thu, 02 Jan 2025 13:36:34 -0500
>
> Eli Zaretskii <eliz <at> gnu.org> writes:
>
> > I think this is bug#74876 again. I tried to explain there why the way
> > the fringe drawing is implemented doesn't work well with
> > face-remapping (or with changes in the fringe face in general).
> >
> > Maybe I'm missing something, but supporting what this and that bug
> > want would need a rewrite of update_window_fringes (and possibly also
> > the way we record fringes' attributes in the glyph row).
>
> That's amazing. Seven years ago, I implemented
> https://github.com/dcolascione/emacs-window-highlight/blob/master/window-highlight.el.
> I worked around the bug we're discussing using redraw-display. I see
> that Michal (++) implemented the same feature independently and reported
> the same bug just a few weeks before I got around to reporting the same
> bug from seven years ago! Pure serendipity.
Yes, redrawing everything will work, but will also cause flicker, and
is generally expensive, thus undesirable.
> Anyway, given that the feature has been implemented twice now, maybe we
> can find some way to make it work efficiently? I haven't looked into
> how exactly we do fringe invalidation, but isn't there a way we can
> limit the blast radius of the redraw by providing a lisp-level function
> to invalidate extra GUI parts of specific windows rather than forcing a
> redraw-frame? It's not clear to me why we couldn't skip redrawing every
> row's content but redraw every row's fringe anyway.
>
> Ideally, a change to a face in which the change couldn't possibly affect
> layout (e.g. changing a background color) would be pretty efficient from
> a redisplay POV, since we wouldn't have to even try to reflow any text.
AFAIR, the current implementation is the other way around: when some
glyph row changes, we consider redrawing its fringes. E.g.,
draw_window_fringes only considers glyph rows that are enabled in the
glyph matrix, which means redisplay found that glyph row has changed.
Clearly, someone didn't think the fringe face will change during a
session!
Regarding your idea about Lisp function that would invalidate GUI
parts: it is not very easy, since a Lisp program cannot easily know
where on the screen a given region of buffer positions will be.
There is posn-at-point, of course, but (a) it is quite expensive, and
(b) when Lisp runs, display could be outdated, so what posn-at-point
returns could be inaccurate.
In any case, I don't think this will be needed in the case in point,
because when the fringe face changes, we'd want to redraw the fringes
of the entire window, right? So redisplay_window would need to notice
the change in the face, and invoke update_window_fringes in a special
way, such that update_window_fringes marks fringes to be redrawn not
only when the glyph row is enabled. Maybe that would work.
The way to "notice the change in the face" is not a simple problem to
solve, btw. We currently don't know which faces change when some face
is modified. So we have a frame-global flag that is set when any face
changes its attributes. If we use that flag for detecting potential
changes in the fringe face, we'd start redrawing fringes
unnecessarily. We could add a special flag for the fringe face, but
then we'd need to add a special mechanism in xfaces.c which would
analyze each change in some face's attribute and determine whether it
could possibly affect the fringe face. Or maybe I'm missing some more
elegant/easier solution.
This bug report was last modified 124 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.