0
0
mirror of https://github.com/vim/vim.git synced 2025-07-24 10:45:12 -04:00

patch 8.2.4614: redrawing too much when 'cursorline' is set

Problem:    Redrawing too much when 'cursorline' is set and jumping around.
Solution:   Rely on win_update() to redraw the current and previous cursor
            line, do not mark lines as modified. (closes #9996)
This commit is contained in:
zeertzjq 2022-03-23 14:55:23 +00:00 committed by Bram Moolenaar
parent 3c5999e53d
commit c20e46a4e3
6 changed files with 13 additions and 43 deletions

View File

@ -945,8 +945,7 @@ win_line(
if (wp->w_p_cul && lnum == wp->w_cursor.lnum) if (wp->w_p_cul && lnum == wp->w_cursor.lnum)
{ {
// Do not show the cursor line in the text when Visual mode is active, // Do not show the cursor line in the text when Visual mode is active,
// because it's not clear what is selected then. Do update // because it's not clear what is selected then.
// w_last_cursorline.
if (!(wp == curwin && VIsual_active) if (!(wp == curwin && VIsual_active)
&& wp->w_p_culopt_flags != CULOPT_NBR) && wp->w_p_culopt_flags != CULOPT_NBR)
{ {
@ -971,18 +970,14 @@ win_line(
else else
# endif # endif
line_attr = cul_attr; line_attr = cul_attr;
wp->w_last_cursorline = wp->w_cursor.lnum;
} }
else else
{ {
line_attr_save = line_attr; line_attr_save = line_attr;
wp->w_last_cursorline = 0;
margin_columns_win(wp, &left_curline_col, &right_curline_col); margin_columns_win(wp, &left_curline_col, &right_curline_col);
} }
area_highlighting = TRUE; area_highlighting = TRUE;
} }
else
wp->w_last_cursorline = wp->w_cursor.lnum;
} }
#endif #endif

View File

@ -1468,9 +1468,6 @@ win_update(win_T *wp)
# define DID_FOLD 3 // updated a folded line # define DID_FOLD 3 // updated a folded line
int did_update = DID_NONE; int did_update = DID_NONE;
linenr_T syntax_last_parsed = 0; // last parsed text line linenr_T syntax_last_parsed = 0; // last parsed text line
// remember the current w_last_cursorline, it changes when drawing the new
// cursor line
linenr_T last_cursorline = wp->w_last_cursorline;
#endif #endif
linenr_T mod_top = 0; linenr_T mod_top = 0;
linenr_T mod_bot = 0; linenr_T mod_bot = 0;
@ -2245,8 +2242,8 @@ win_update(win_T *wp)
#endif #endif
)))) ))))
#ifdef FEAT_SYN_HL #ifdef FEAT_SYN_HL
|| (wp->w_p_cul && (lnum == wp->w_cursor.lnum || (wp->w_p_cul && lnum == wp->w_cursor.lnum)
|| lnum == last_cursorline)) || lnum == wp->w_last_cursorline
#endif #endif
) )
{ {
@ -2551,6 +2548,12 @@ win_update(win_T *wp)
// End of loop over all window lines. // End of loop over all window lines.
#ifdef FEAT_SYN_HL
// Now that the window has been redrawn with the old and new cursor line,
// update w_last_cursorline.
wp->w_last_cursorline = wp->w_p_cul ? wp->w_cursor.lnum : 0;
#endif
#ifdef FEAT_VTP #ifdef FEAT_VTP
// Rewrite the character at the end of the screen line. // Rewrite the character at the end of the screen line.
// See the version that was fixed. // See the version that was fixed.

View File

@ -115,14 +115,6 @@ comp_botline(win_T *wp)
set_empty_rows(wp, done); set_empty_rows(wp, done);
} }
#ifdef FEAT_SYN_HL
void
reset_cursorline(void)
{
curwin->w_last_cursorline = 0;
}
#endif
/* /*
* Redraw when w_cline_row changes and 'relativenumber' or 'cursorline' is * Redraw when w_cline_row changes and 'relativenumber' or 'cursorline' is
* set. * set.
@ -138,24 +130,8 @@ redraw_for_cursorline(win_T *wp)
&& (wp->w_valid & VALID_CROW) == 0 && (wp->w_valid & VALID_CROW) == 0
&& !pum_visible()) && !pum_visible())
{ {
if (wp->w_p_rnu) // win_line() will redraw the number column and cursorline only.
// win_line() will redraw the number column only. redraw_win_later(wp, VALID);
redraw_win_later(wp, VALID);
#ifdef FEAT_SYN_HL
if (wp->w_p_cul)
{
if (wp->w_redr_type <= VALID && wp->w_last_cursorline != 0)
{
// "w_last_cursorline" may be outdated, worst case we redraw
// too much. This is optimized for moving the cursor around in
// the current window.
redrawWinline(wp, wp->w_last_cursorline);
redrawWinline(wp, wp->w_cursor.lnum);
}
else
redraw_win_later(wp, SOME_VALID);
}
#endif
} }
} }

View File

@ -2782,11 +2782,6 @@ set_bool_option(
p_lrm = !p_lnr; p_lrm = !p_lnr;
#endif #endif
#ifdef FEAT_SYN_HL
else if ((int *)varp == &curwin->w_p_cul && !value && old_value)
reset_cursorline();
#endif
#ifdef FEAT_PERSISTENT_UNDO #ifdef FEAT_PERSISTENT_UNDO
// 'undofile' // 'undofile'
else if ((int *)varp == &curbuf->b_p_udf || (int *)varp == &p_udf) else if ((int *)varp == &curbuf->b_p_udf || (int *)varp == &p_udf)

View File

@ -1,5 +1,4 @@
/* move.c */ /* move.c */
void reset_cursorline(void);
void redraw_for_cursorline(win_T *wp); void redraw_for_cursorline(win_T *wp);
void update_topline_redraw(void); void update_topline_redraw(void);
void update_topline(void); void update_topline(void);

View File

@ -750,6 +750,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
4614,
/**/ /**/
4613, 4613,
/**/ /**/