mirror of
https://github.com/vim/vim.git
synced 2025-09-25 03:54:15 -04:00
patch 9.1.0176: Cursor column wrong with 'virtualedit' and conceal
Problem: Cursor column wrong with 'virtualedit' and conceal. Solution: Correct cursor column at end of line if never reached. (zeertzjq) closes: #14190 Signed-off-by: zeertzjq <zeertzjq@outlook.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
committed by
Christian Brabandt
parent
5866bc3a0f
commit
253ff4dece
@@ -3547,10 +3547,12 @@ win_line(
|
||||
#ifdef FEAT_CONCEAL
|
||||
// In the cursor line and we may be concealing characters: correct
|
||||
// the cursor column when we reach its position.
|
||||
// With 'virtualedit' we may never reach cursor position, but we still
|
||||
// need to correct the cursor column, so do that at end of line.
|
||||
if (!did_wcol && wlv.draw_state == WL_LINE
|
||||
&& wp == curwin && lnum == wp->w_cursor.lnum
|
||||
&& conceal_cursor_line(wp)
|
||||
&& (int)wp->w_virtcol <= wlv.vcol + skip_cells)
|
||||
&& (wlv.vcol + skip_cells >= wp->w_virtcol || c == NUL))
|
||||
{
|
||||
# ifdef FEAT_RIGHTLEFT
|
||||
if (wp->w_p_rl)
|
||||
@@ -3558,6 +3560,9 @@ win_line(
|
||||
else
|
||||
# endif
|
||||
wp->w_wcol = wlv.col - wlv.boguscols;
|
||||
if (wlv.vcol + skip_cells < wp->w_virtcol)
|
||||
// Cursor beyond end of the line with 'virtualedit'.
|
||||
wp->w_wcol += wp->w_virtcol - wlv.vcol - skip_cells;
|
||||
wp->w_wrow = wlv.row;
|
||||
did_wcol = TRUE;
|
||||
curwin->w_valid |= VALID_WCOL|VALID_WROW|VALID_VIRTCOL;
|
||||
|
Reference in New Issue
Block a user