mirror of
https://github.com/vim/vim.git
synced 2025-07-24 10:45:12 -04:00
patch 9.1.0083: Redrawing can be improved when deleting lines with 'number'
Problem: Redrawing can be improved when inserting/deleting lines with 'number'. Solution: Only redraw the number column of lines below changed lines. Add a test as this wasn't previously tested. (zeertzjq) closes: #13985 Signed-off-by: zeertzjq <zeertzjq@outlook.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
parent
7ce34c9a94
commit
ae07ebc04b
@ -1699,11 +1699,6 @@ win_update(win_T *wp)
|
||||
top_end = 1;
|
||||
#endif
|
||||
}
|
||||
|
||||
// When line numbers are displayed need to redraw all lines below
|
||||
// inserted/deleted lines.
|
||||
if (mod_top != 0 && buf->b_mod_xlines != 0 && wp->w_p_nu)
|
||||
mod_bot = MAXLNUM;
|
||||
}
|
||||
wp->w_redraw_top = 0; // reset for next time
|
||||
wp->w_redraw_bot = 0;
|
||||
@ -2540,11 +2535,16 @@ win_update(win_T *wp)
|
||||
}
|
||||
else
|
||||
{
|
||||
if (wp->w_p_rnu && wp->w_last_cursor_lnum_rnu != wp->w_cursor.lnum)
|
||||
// If:
|
||||
// - 'number' is set and below inserted/deleted lines, or
|
||||
// - 'relativenumber' is set and cursor moved vertically,
|
||||
// the text doesn't need to be redrawn, but the number column does.
|
||||
if ((wp->w_p_nu && mod_top != 0
|
||||
&& lnum >= mod_bot && buf->b_mod_xlines != 0)
|
||||
|| (wp->w_p_rnu
|
||||
&& wp->w_last_cursor_lnum_rnu != wp->w_cursor.lnum))
|
||||
{
|
||||
#ifdef FEAT_FOLDING
|
||||
// 'relativenumber' set and the cursor moved vertically: The
|
||||
// text doesn't need to be drawn, but the number column does.
|
||||
fold_count = foldedCount(wp, lnum, &win_foldinfo);
|
||||
if (fold_count != 0)
|
||||
fold_line(wp, fold_count, &win_foldinfo, lnum, row);
|
||||
|
8
src/testdir/dumps/Test_number_insert_delete_lines_1.dump
Normal file
8
src/testdir/dumps/Test_number_insert_delete_lines_1.dump
Normal file
@ -0,0 +1,8 @@
|
||||
| +0#af5f00255#ffffff0@1|1| |1+0#0000000&| @69
|
||||
| +0#af5f00255&@1|2| >2+0#0000000&| @69
|
||||
| +0#af5f00255&@1|3| |3+0#0000000&| @69
|
||||
| +0#af5f00255&@1|4| |4+0#0000000&| @69
|
||||
| +0#af5f00255&@1|5| |5+0#0000000&| @69
|
||||
| +0#af5f00255&@1|6| |6+0#0000000&| @69
|
||||
| +0#af5f00255&@1|7| |7+0#0000000&| @69
|
||||
@57|2|,|1| @10|A|l@1|
|
8
src/testdir/dumps/Test_number_insert_delete_lines_2.dump
Normal file
8
src/testdir/dumps/Test_number_insert_delete_lines_2.dump
Normal file
@ -0,0 +1,8 @@
|
||||
| +0#af5f00255#ffffff0@1|1| |1+0#0000000&| @69
|
||||
| +0#af5f00255&@1|2| >3+0#0000000&| @69
|
||||
| +0#af5f00255&@1|3| |4+0#0000000&| @69
|
||||
| +0#af5f00255&@1|4| |5+0#0000000&| @69
|
||||
| +0#af5f00255&@1|5| |6+0#0000000&| @69
|
||||
| +0#af5f00255&@1|6| |7+0#0000000&| @69
|
||||
|~+0#4040ff13&| @73
|
||||
| +0#0000000&@56|2|,|1| @10|A|l@1|
|
8
src/testdir/dumps/Test_number_insert_delete_lines_3.dump
Normal file
8
src/testdir/dumps/Test_number_insert_delete_lines_3.dump
Normal file
@ -0,0 +1,8 @@
|
||||
| +0#af5f00255#ffffff0@1|1| |1+0#0000000&| @69
|
||||
| +0#af5f00255&@1|2| >4+0#0000000&| @69
|
||||
| +0#af5f00255&@1|3| |5+0#0000000&| @69
|
||||
| +0#af5f00255&@1|4| |6+0#0000000&| @69
|
||||
| +0#af5f00255&@1|5| |7+0#0000000&| @69
|
||||
|~+0#4040ff13&| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|2|,|1| @10|A|l@1|
|
@ -146,8 +146,7 @@ func Test_number_with_linewrap1()
|
||||
call s:close_windows()
|
||||
endfunc
|
||||
|
||||
" Pending: https://groups.google.com/forum/#!topic/vim_dev/tzNKP7EDWYI
|
||||
func XTest_number_with_linewrap2()
|
||||
func Test_number_with_linewrap2()
|
||||
call s:test_windows(3, 20)
|
||||
normal! 61ia
|
||||
setl number wrap
|
||||
@ -164,8 +163,7 @@ func XTest_number_with_linewrap2()
|
||||
call s:close_windows()
|
||||
endfunc
|
||||
|
||||
" Pending: https://groups.google.com/forum/#!topic/vim_dev/tzNKP7EDWYI
|
||||
func XTest_number_with_linewrap3()
|
||||
func Test_number_with_linewrap3()
|
||||
call s:test_windows(4, 20)
|
||||
normal! 81ia
|
||||
setl number wrap
|
||||
@ -174,7 +172,7 @@ func XTest_number_with_linewrap3()
|
||||
call s:validate_cursor()
|
||||
let lines = s:screen_lines(1, 4)
|
||||
let expect = [
|
||||
\ "aaaaaaaa",
|
||||
\ "<<<aaaaa",
|
||||
\ "aaaaaaaa",
|
||||
\ "aaaaaaaa",
|
||||
\ "a ",
|
||||
@ -349,6 +347,31 @@ func Test_relativenumber_callback()
|
||||
call StopVimInTerminal(buf)
|
||||
endfunc
|
||||
|
||||
" Test that line numbers below inserted/deleted lines are updated.
|
||||
func Test_number_insert_delete_lines()
|
||||
CheckScreendump
|
||||
|
||||
let lines =<< trim END
|
||||
call setline(1, range(1, 7))
|
||||
set number
|
||||
call cursor(2, 1)
|
||||
END
|
||||
call writefile(lines, 'Xnumber_insert_delete_lines', 'D')
|
||||
|
||||
let buf = RunVimInTerminal('-S Xnumber_insert_delete_lines', #{rows: 8})
|
||||
call VerifyScreenDump(buf, 'Test_number_insert_delete_lines_1', {})
|
||||
call term_sendkeys(buf, "dd")
|
||||
call VerifyScreenDump(buf, 'Test_number_insert_delete_lines_2', {})
|
||||
call term_sendkeys(buf, "P")
|
||||
call VerifyScreenDump(buf, 'Test_number_insert_delete_lines_1', {})
|
||||
call term_sendkeys(buf, "2dd")
|
||||
call VerifyScreenDump(buf, 'Test_number_insert_delete_lines_3', {})
|
||||
call term_sendkeys(buf, "P")
|
||||
call VerifyScreenDump(buf, 'Test_number_insert_delete_lines_1', {})
|
||||
|
||||
call StopVimInTerminal(buf)
|
||||
endfunc
|
||||
|
||||
" Test for displaying line numbers with 'rightleft'
|
||||
func Test_number_rightleft()
|
||||
CheckFeature rightleft
|
||||
|
@ -704,6 +704,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
83,
|
||||
/**/
|
||||
82,
|
||||
/**/
|
||||
|
Loading…
x
Reference in New Issue
Block a user