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:
parent
3c5999e53d
commit
c20e46a4e3
@ -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
|
||||||
|
|
||||||
|
@ -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.
|
||||||
|
28
src/move.c
28
src/move.c
@ -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
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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);
|
||||||
|
@ -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,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user