diff options
| author | zeertzjq <zeertzjq@outlook.com> | 2024-02-08 19:37:41 +0800 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-02-08 19:37:41 +0800 |
| commit | 8b21fe83daf5e04afda6a2edf91e9258530124d8 (patch) | |
| tree | 3e3d5ea83be6645989097e75ef3e88cf87c02583 /src/nvim/drawscreen.c | |
| parent | 1f9da3d0835af2cfe937de250c2cde3a59e1677e (diff) | |
| parent | da3facb7eea92bd4082bb6ea12e0947580a63962 (diff) | |
| download | rneovim-8b21fe83daf5e04afda6a2edf91e9258530124d8.tar.gz rneovim-8b21fe83daf5e04afda6a2edf91e9258530124d8.tar.bz2 rneovim-8b21fe83daf5e04afda6a2edf91e9258530124d8.zip | |
Merge pull request #27388 from zeertzjq/vim-9.1.0082
vim-patch:9.1.{0082,0083}: redrawing can be improved
Diffstat (limited to 'src/nvim/drawscreen.c')
| -rw-r--r-- | src/nvim/drawscreen.c | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/src/nvim/drawscreen.c b/src/nvim/drawscreen.c index f23c0a0fd3..3d048d178e 100644 --- a/src/nvim/drawscreen.c +++ b/src/nvim/drawscreen.c @@ -1643,12 +1643,6 @@ static void win_update(win_T *wp) top_end = 1; } } - - // 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 @@ -2326,9 +2320,12 @@ static void win_update(win_T *wp) idx++; lnum += foldinfo.fi_lines + 1; } else { - if (wp->w_p_rnu && wp->w_last_cursor_lnum_rnu != wp->w_cursor.lnum) { - // 'relativenumber' set and cursor moved vertically: The - // text doesn't need to be drawn, but the number column does. + // 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)) { foldinfo_T info = wp->w_p_cul && lnum == wp->w_cursor.lnum ? cursorline_fi : fold_info(wp, lnum); win_line(wp, lnum, srow, wp->w_grid.rows, wp->w_lines[idx].wl_size, &spv, info); |