From d6e08ff459df4cda9eda0c5c842313d02851ba3d Mon Sep 17 00:00:00 2001 From: Eli Zaretskii <eliz@gnu.org> Date: Wed, 26 Oct 2022 17:21:45 +0300 Subject: Fix rare problems with current-column when text is invisible * src/indent.c (scan_for_column, compute_motion): Don't miss compositions when the position to check for composition happens to be inside invisible text. (Bug#58791) --- src/indent.c | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'src/indent.c') diff --git a/src/indent.c b/src/indent.c index aa905f387bb..4bf597a339f 100644 --- a/src/indent.c +++ b/src/indent.c @@ -637,6 +637,11 @@ scan_for_column (ptrdiff_t *endpos, EMACS_INT *goalcol, scan_byte = CHAR_TO_BYTE (scan); if (scan >= end) goto endloop; + /* We may have over-stepped cmp_it.stop_pos while skipping + the invisible text. If so, update cmp_it.stop_pos. */ + if (scan > cmp_it.stop_pos && cmp_it.id < 0) + composition_reseat_it (&cmp_it, scan, scan_byte, end, + w, -1, NULL, Qnil); } /* Test reaching the goal column. We do this after skipping @@ -1358,6 +1363,9 @@ compute_motion (ptrdiff_t from, ptrdiff_t frombyte, EMACS_INT fromvpos, pos = newpos; pos_byte = CHAR_TO_BYTE (pos); } + if (newpos > cmp_it.stop_pos && cmp_it.id < 0) + composition_reseat_it (&cmp_it, pos, pos_byte, to, + win, -1, NULL, Qnil); rarely_quit (++quit_count); } -- cgit v1.2.3