diff options
author | zeertzjq <zeertzjq@outlook.com> | 2024-06-19 07:42:56 +0800 |
---|---|---|
committer | zeertzjq <zeertzjq@outlook.com> | 2024-06-19 08:02:29 +0800 |
commit | a2a3e8412e6d4e9a952c57a5298016cae8bf5229 (patch) | |
tree | 4c606a997f28a74b531ab2888e2f59eac5329d70 /src | |
parent | 14aba679670a6485596c60fa5eb1df92ecae8a1b (diff) | |
download | rneovim-a2a3e8412e6d4e9a952c57a5298016cae8bf5229.tar.gz rneovim-a2a3e8412e6d4e9a952c57a5298016cae8bf5229.tar.bz2 rneovim-a2a3e8412e6d4e9a952c57a5298016cae8bf5229.zip |
vim-patch:8.2.5047: CurSearch highlight is often wrong
Problem: CurSearch highlight is often wrong.
Solution: Remember the last highlighted position and redraw when needed.
https://github.com/vim/vim/commit/368137aa525982984beed73940af481ac53a62af
Co-authored-by: Bram Moolenaar <Bram@vim.org>
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/change.c | 4 | ||||
-rw-r--r-- | src/nvim/drawscreen.c | 13 | ||||
-rw-r--r-- | src/nvim/drawscreen.h | 6 | ||||
-rw-r--r-- | src/nvim/match.c | 3 |
4 files changed, 25 insertions, 1 deletions
diff --git a/src/nvim/change.c b/src/nvim/change.c index 6c979df1fe..428a9187c8 100644 --- a/src/nvim/change.c +++ b/src/nvim/change.c @@ -392,6 +392,10 @@ static void changed_common(buf_T *buf, linenr_T lnum, colnr_T col, linenr_T lnum } } } + + if (wp == curwin && xtra != 0 && search_hl_has_cursor_lnum >= lnum) { + search_hl_has_cursor_lnum += xtra; + } } // Call update_screen() later, which checks out what needs to be redrawn, diff --git a/src/nvim/drawscreen.c b/src/nvim/drawscreen.c index 88e1f302da..770f8da6cf 100644 --- a/src/nvim/drawscreen.c +++ b/src/nvim/drawscreen.c @@ -1593,6 +1593,18 @@ static void win_update(win_T *wp) } } } + + if (search_hl_has_cursor_lnum > 0) { + // CurSearch was used last time, need to redraw the line with it to + // avoid having two matches highlighted with CurSearch. + if (mod_top == 0 || mod_top > search_hl_has_cursor_lnum) { + mod_top = search_hl_has_cursor_lnum; + } + if (mod_bot == 0 || mod_bot < search_hl_has_cursor_lnum + 1) { + mod_bot = search_hl_has_cursor_lnum + 1; + } + } + if (mod_top != 0 && hasAnyFolding(wp)) { // A change in a line can cause lines above it to become folded or // unfolded. Find the top most buffer line that may be affected. @@ -1651,6 +1663,7 @@ static void win_update(win_T *wp) wp->w_redraw_top = 0; // reset for next time wp->w_redraw_bot = 0; + search_hl_has_cursor_lnum = 0; // When only displaying the lines at the top, set top_end. Used when // window has scrolled down for msg_scrolled. diff --git a/src/nvim/drawscreen.h b/src/nvim/drawscreen.h index f804345bca..36ba8099fd 100644 --- a/src/nvim/drawscreen.h +++ b/src/nvim/drawscreen.h @@ -25,7 +25,11 @@ EXTERN bool updating_screen INIT( = false); /// must_redraw to be set. EXTERN bool redraw_not_allowed INIT( = false); -EXTERN match_T screen_search_hl INIT( = { 0 }); ///< used for 'hlsearch' highlight matching +/// used for 'hlsearch' highlight matching +EXTERN match_T screen_search_hl INIT( = { 0 }); + +/// last lnum where CurSearch was displayed +EXTERN linenr_T search_hl_has_cursor_lnum INIT( = 0); #define W_ENDCOL(wp) ((wp)->w_wincol + (wp)->w_width) #define W_ENDROW(wp) ((wp)->w_winrow + (wp)->w_height) diff --git a/src/nvim/match.c b/src/nvim/match.c index 6ae4e41147..86cab5221d 100644 --- a/src/nvim/match.c +++ b/src/nvim/match.c @@ -706,6 +706,9 @@ int update_search_hl(win_T *wp, linenr_T lnum, colnr_T col, char **line, match_T // group. if (shl == search_hl && shl->has_cursor) { shl->attr_cur = win_hl_attr(wp, HLF_LC); + if (shl->attr_cur != shl->attr) { + search_hl_has_cursor_lnum = lnum; + } } else { shl->attr_cur = shl->attr; } |