mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.2.4638: superfluous check if a redraw is needed for 'cursorline'
Problem: Superfluous check if a redraw is needed for 'cursorline'. Solution: Remove check_redraw_cursorline(). (closes #10030, closes #10029)
This commit is contained in:
parent
565d1278cb
commit
3e559cd884
@ -3032,23 +3032,6 @@ redraw_asap(int type)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(FEAT_SYN_HL) || defined(PROTO)
|
|
||||||
/*
|
|
||||||
* Check if the cursor moved and 'cursorline' is set. Mark for a VALID redraw
|
|
||||||
* if needed.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
check_redraw_cursorline(void)
|
|
||||||
{
|
|
||||||
// When 'cursorlineopt' is "screenline" need to redraw always.
|
|
||||||
if (curwin->w_p_cul
|
|
||||||
&& (curwin->w_last_cursorline != curwin->w_cursor.lnum
|
|
||||||
|| (curwin->w_p_culopt_flags & CULOPT_SCRLINE))
|
|
||||||
&& !char_avail())
|
|
||||||
redraw_later(VALID);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Invoked after an asynchronous callback is called.
|
* Invoked after an asynchronous callback is called.
|
||||||
* If an echo command was used the cursor needs to be put back where
|
* If an echo command was used the cursor needs to be put back where
|
||||||
@ -3093,10 +3076,9 @@ redraw_after_callback(int call_update_screen, int do_message)
|
|||||||
}
|
}
|
||||||
else if (State & (NORMAL | INSERT | TERMINAL))
|
else if (State & (NORMAL | INSERT | TERMINAL))
|
||||||
{
|
{
|
||||||
#ifdef FEAT_SYN_HL
|
update_topline();
|
||||||
// might need to update for 'cursorline'
|
validate_cursor();
|
||||||
check_redraw_cursorline();
|
|
||||||
#endif
|
|
||||||
// keep the command line if possible
|
// keep the command line if possible
|
||||||
update_screen(VALID_NO_UPDATE);
|
update_screen(VALID_NO_UPDATE);
|
||||||
setcursor();
|
setcursor();
|
||||||
|
@ -1058,10 +1058,6 @@ doESCkey:
|
|||||||
case K_COMMAND: // <Cmd>command<CR>
|
case K_COMMAND: // <Cmd>command<CR>
|
||||||
case K_SCRIPT_COMMAND: // <ScriptCmd>command<CR>
|
case K_SCRIPT_COMMAND: // <ScriptCmd>command<CR>
|
||||||
do_cmdkey_command(c, 0);
|
do_cmdkey_command(c, 0);
|
||||||
#ifdef FEAT_SYN_HL
|
|
||||||
// Might need to update for 'cursorline'.
|
|
||||||
check_redraw_cursorline();
|
|
||||||
#endif
|
|
||||||
#ifdef FEAT_TERMINAL
|
#ifdef FEAT_TERMINAL
|
||||||
if (term_use_loop())
|
if (term_use_loop())
|
||||||
// Started a terminal that gets the input, exit Insert mode.
|
// Started a terminal that gets the input, exit Insert mode.
|
||||||
|
@ -1384,10 +1384,6 @@ main_loop(
|
|||||||
update_topline();
|
update_topline();
|
||||||
validate_cursor();
|
validate_cursor();
|
||||||
|
|
||||||
#ifdef FEAT_SYN_HL
|
|
||||||
// Might need to update for 'cursorline'.
|
|
||||||
check_redraw_cursorline();
|
|
||||||
#endif
|
|
||||||
if (VIsual_active)
|
if (VIsual_active)
|
||||||
update_curbuf(INVERTED); // update inverted part
|
update_curbuf(INVERTED); // update inverted part
|
||||||
else if (must_redraw)
|
else if (must_redraw)
|
||||||
|
30
src/move.c
30
src/move.c
@ -135,6 +135,26 @@ redraw_for_cursorline(win_T *wp)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef FEAT_SYN_HL
|
||||||
|
/*
|
||||||
|
* Redraw when w_virtcol changes and 'cursorcolumn' is set or 'cursorlineopt'
|
||||||
|
* contains "screenline".
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
redraw_for_cursorcolumn(win_T *wp)
|
||||||
|
{
|
||||||
|
if ((wp->w_valid & VALID_VIRTCOL) == 0 && !pum_visible())
|
||||||
|
{
|
||||||
|
// When 'cursorcolumn' is set need to redraw with SOME_VALID.
|
||||||
|
if (wp->w_p_cuc)
|
||||||
|
redraw_later(SOME_VALID);
|
||||||
|
// When 'cursorlineopt' contains "screenline" need to redraw with VALID.
|
||||||
|
else if (wp->w_p_cul && (wp->w_p_culopt_flags & CULOPT_SCRLINE))
|
||||||
|
redraw_later(VALID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Update curwin->w_topline and redraw if necessary.
|
* Update curwin->w_topline and redraw if necessary.
|
||||||
* Used to update the screen before printing a message.
|
* Used to update the screen before printing a message.
|
||||||
@ -798,11 +818,10 @@ validate_virtcol_win(win_T *wp)
|
|||||||
if (!(wp->w_valid & VALID_VIRTCOL))
|
if (!(wp->w_valid & VALID_VIRTCOL))
|
||||||
{
|
{
|
||||||
getvvcol(wp, &wp->w_cursor, NULL, &(wp->w_virtcol), NULL);
|
getvvcol(wp, &wp->w_cursor, NULL, &(wp->w_virtcol), NULL);
|
||||||
wp->w_valid |= VALID_VIRTCOL;
|
|
||||||
#ifdef FEAT_SYN_HL
|
#ifdef FEAT_SYN_HL
|
||||||
if (wp->w_p_cuc && !pum_visible())
|
redraw_for_cursorcolumn(wp);
|
||||||
redraw_win_later(wp, SOME_VALID);
|
|
||||||
#endif
|
#endif
|
||||||
|
wp->w_valid |= VALID_VIRTCOL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1169,10 +1188,7 @@ curs_columns(
|
|||||||
redraw_later(NOT_VALID);
|
redraw_later(NOT_VALID);
|
||||||
|
|
||||||
#ifdef FEAT_SYN_HL
|
#ifdef FEAT_SYN_HL
|
||||||
// Redraw when w_virtcol changes and 'cursorcolumn' is set
|
redraw_for_cursorcolumn(curwin);
|
||||||
if (curwin->w_p_cuc && (curwin->w_valid & VALID_VIRTCOL) == 0
|
|
||||||
&& !pum_visible())
|
|
||||||
redraw_later(SOME_VALID);
|
|
||||||
#endif
|
#endif
|
||||||
#if defined(FEAT_PROP_POPUP) && defined(FEAT_TERMINAL)
|
#if defined(FEAT_PROP_POPUP) && defined(FEAT_TERMINAL)
|
||||||
if (popup_is_popup(curwin) && curbuf->b_term != NULL)
|
if (popup_is_popup(curwin) && curbuf->b_term != NULL)
|
||||||
|
@ -6971,10 +6971,6 @@ nv_edit(cmdarg_T *cap)
|
|||||||
coladvance(getviscol());
|
coladvance(getviscol());
|
||||||
State = save_State;
|
State = save_State;
|
||||||
}
|
}
|
||||||
#ifdef FEAT_SYN_HL
|
|
||||||
// Might need to update for 'cursorline'.
|
|
||||||
check_redraw_cursorline();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
invoke_edit(cap, FALSE, cap->cmdchar, FALSE);
|
invoke_edit(cap, FALSE, cap->cmdchar, FALSE);
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,6 @@ void update_curbuf(int type);
|
|||||||
void update_debug_sign(buf_T *buf, linenr_T lnum);
|
void update_debug_sign(buf_T *buf, linenr_T lnum);
|
||||||
void updateWindow(win_T *wp);
|
void updateWindow(win_T *wp);
|
||||||
int redraw_asap(int type);
|
int redraw_asap(int type);
|
||||||
void check_redraw_cursorline(void);
|
|
||||||
void redraw_after_callback(int call_update_screen, int do_message);
|
void redraw_after_callback(int call_update_screen, int do_message);
|
||||||
void redraw_later(int type);
|
void redraw_later(int type);
|
||||||
void redraw_win_later(win_T *wp, int type);
|
void redraw_win_later(win_T *wp, int type);
|
||||||
|
8
src/testdir/dumps/Test_cursorcolumn_callback_1.dump
Normal file
8
src/testdir/dumps/Test_cursorcolumn_callback_1.dump
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
>a+0&#ffffff0@4| @69
|
||||||
|
|b+0&#e0e0e08|b+0&#ffffff0@3| @69
|
||||||
|
|c+0&#e0e0e08|c+0&#ffffff0@3| @69
|
||||||
|
|d+0&#e0e0e08|d+0&#ffffff0@3| @69
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|~| @73
|
||||||
|
|~| @73
|
||||||
|
| +0#0000000&@56|4|,|5| @10|A|l@1|
|
8
src/testdir/dumps/Test_relativenumber_callback_1.dump
Normal file
8
src/testdir/dumps/Test_relativenumber_callback_1.dump
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
| +0#af5f00255#ffffff0@1|0| >a+0#0000000&@4| @65
|
||||||
|
| +0#af5f00255&@1|1| |b+0#0000000&@4| @65
|
||||||
|
| +0#af5f00255&@1|2| |c+0#0000000&@4| @65
|
||||||
|
| +0#af5f00255&@1|3| |d+0#0000000&@4| @65
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|~| @73
|
||||||
|
|~| @73
|
||||||
|
| +0#0000000&@56|4|,|1| @10|A|l@1|
|
@ -592,6 +592,31 @@ func Test_cursorline_with_visualmode()
|
|||||||
call delete('Xtest_cursorline_with_visualmode')
|
call delete('Xtest_cursorline_with_visualmode')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_cursorcolumn_callback()
|
||||||
|
CheckScreendump
|
||||||
|
CheckFeature timers
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
call setline(1, ['aaaaa', 'bbbbb', 'ccccc', 'ddddd'])
|
||||||
|
set cursorcolumn
|
||||||
|
call cursor(4, 5)
|
||||||
|
|
||||||
|
func Func(timer)
|
||||||
|
call cursor(1, 1)
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
call timer_start(300, 'Func')
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xcuc_timer')
|
||||||
|
|
||||||
|
let buf = RunVimInTerminal('-S Xcuc_timer', #{rows: 8})
|
||||||
|
call TermWait(buf, 310)
|
||||||
|
call VerifyScreenDump(buf, 'Test_cursorcolumn_callback_1', {})
|
||||||
|
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
call delete('Xcuc_timer')
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_wincolor()
|
func Test_wincolor()
|
||||||
CheckScreendump
|
CheckScreendump
|
||||||
" make sure the width is enough for the test
|
" make sure the width is enough for the test
|
||||||
|
@ -298,6 +298,31 @@ func Test_relativenumber_colors()
|
|||||||
call delete('XTest_relnr')
|
call delete('XTest_relnr')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_relativenumber_callback()
|
||||||
|
CheckScreendump
|
||||||
|
CheckFeature timers
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
call setline(1, ['aaaaa', 'bbbbb', 'ccccc', 'ddddd'])
|
||||||
|
set relativenumber
|
||||||
|
call cursor(4, 1)
|
||||||
|
|
||||||
|
func Func(timer)
|
||||||
|
call cursor(1, 1)
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
call timer_start(300, 'Func')
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xrnu_timer')
|
||||||
|
|
||||||
|
let buf = RunVimInTerminal('-S Xrnu_timer', #{rows: 8})
|
||||||
|
call TermWait(buf, 310)
|
||||||
|
call VerifyScreenDump(buf, 'Test_relativenumber_callback_1', {})
|
||||||
|
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
call delete('Xrnu_timer')
|
||||||
|
endfunc
|
||||||
|
|
||||||
" Test for displaying line numbers with 'rightleft'
|
" Test for displaying line numbers with 'rightleft'
|
||||||
func Test_number_rightleft()
|
func Test_number_rightleft()
|
||||||
CheckFeature rightleft
|
CheckFeature rightleft
|
||||||
|
@ -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 */
|
||||||
|
/**/
|
||||||
|
4638,
|
||||||
/**/
|
/**/
|
||||||
4637,
|
4637,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user