From: Bram Moolenaar Date: Wed, 29 Dec 2021 19:22:44 +0000 (+0000) Subject: patch 8.2.3940: match highlight disappears when doing incsearch for ":s/pat" X-Git-Tag: v8.2.3940 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=94fb8274ca8c93a10102d41c8bcc848f75cb7334;p=vim patch 8.2.3940: match highlight disappears when doing incsearch for ":s/pat" Problem: Match highlight disappears when doing incsearch for ":s/pat". Solution: Only use line limit for incsearch highlighting. (closes #9425) --- diff --git a/src/match.c b/src/match.c index 40f426ec6..3b5c18e42 100644 --- a/src/match.c +++ b/src/match.c @@ -427,7 +427,7 @@ next_search_hl( int called_emsg_before = called_emsg; // for :{range}s/pat only highlight inside the range - if (lnum < search_first_line || lnum > search_last_line) + if ((lnum < search_first_line || lnum > search_last_line) && cur == NULL) { shl->lnum = 0; return; diff --git a/src/testdir/dumps/Test_match_with_incsearch_1.dump b/src/testdir/dumps/Test_match_with_incsearch_1.dump new file mode 100644 index 000000000..8a9d30c27 --- /dev/null +++ b/src/testdir/dumps/Test_match_with_incsearch_1.dump @@ -0,0 +1,6 @@ +>0+0&#ffffff0| @73 +|1| @73 +|2+0#ffffff16#e000002| +0#0000000#ffffff0@73 +|3| @73 +|4| @73 +@57|1|,|1| @10|T|o|p| diff --git a/src/testdir/dumps/Test_match_with_incsearch_2.dump b/src/testdir/dumps/Test_match_with_incsearch_2.dump new file mode 100644 index 000000000..9e9868b0f --- /dev/null +++ b/src/testdir/dumps/Test_match_with_incsearch_2.dump @@ -0,0 +1,6 @@ +|0+1&#ffffff0| +0&&@73 +|1| @73 +|2+0#ffffff16#e000002| +0#0000000#ffffff0@73 +|3| @73 +|4| @73 +|:|s|/|0> @70 diff --git a/src/testdir/test_match.vim b/src/testdir/test_match.vim index 6ca163b36..0af45a49a 100644 --- a/src/testdir/test_match.vim +++ b/src/testdir/test_match.vim @@ -366,6 +366,27 @@ func Test_match_in_linebreak() call delete('XscriptMatchLinebreak') endfunc +func Test_match_with_incsearch() + CheckRunVimInTerminal + + let lines =<< trim END + set incsearch + call setline(1, range(20)) + call matchaddpos('ErrorMsg', [3]) + END + call writefile(lines, 'XmatchWithIncsearch') + let buf = RunVimInTerminal('-S XmatchWithIncsearch', #{rows: 6}) + call TermWait(buf) + call VerifyScreenDump(buf, 'Test_match_with_incsearch_1', {}) + + call term_sendkeys(buf, ":s/0") + call VerifyScreenDump(buf, 'Test_match_with_incsearch_2', {}) + + call term_sendkeys(buf, "\") + call StopVimInTerminal(buf) + call delete('XmatchWithIncsearch') +endfunc + " Test for deleting matches outside of the screen redraw top/bottom lines " This should cause a redraw of those lines. func Test_matchdelete_redraw() diff --git a/src/version.c b/src/version.c index 0f0414e92..ee3a29f51 100644 --- a/src/version.c +++ b/src/version.c @@ -749,6 +749,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 3940, /**/ 3939, /**/