]> granicus.if.org Git - vim/commitdiff
patch 8.1.1288: search stats don't show for mapped command v8.1.1288
authorBram Moolenaar <Bram@vim.org>
Tue, 7 May 2019 19:29:11 +0000 (21:29 +0200)
committerBram Moolenaar <Bram@vim.org>
Tue, 7 May 2019 19:29:11 +0000 (21:29 +0200)
Problem:    Search stats don't show for mapped command.
Solution:   Remove SEARCH_PEEK from searchit flags.  Add a test. (Christian
            Brabandt)

src/search.c
src/testdir/test_search_stat.vim
src/version.c

index dd5519e79283969a706f55fe0f5b7d4d8c64bcff..2d829b56c269428170f37372f52a65cc30adff49 100644 (file)
@@ -4958,8 +4958,8 @@ search_stat(
        profile_setlimit(20L, &start);
 #endif
        while (!got_int && searchit(curwin, curbuf, &lastpos, NULL,
-                                  FORWARD, NULL, 1, SEARCH_PEEK + SEARCH_KEEP,
-                                    RE_LAST, (linenr_T)0, NULL, NULL) != FAIL)
+                                       FORWARD, NULL, 1, SEARCH_KEEP, RE_LAST,
+                                             (linenr_T)0, NULL, NULL) != FAIL)
        {
 #ifdef FEAT_RELTIME
            // Stop after passing the time limit.
index 57dad81b8162a1f3ddd9b6b917dbe8f6e57904ea..107cd54a0e022633d2eee3cdd5eed7a5980bf5c2 100644 (file)
@@ -8,6 +8,7 @@ source shared.vim
 func! Test_search_stat()
   new
   set shortmess-=S
+  " Append 50 lines with text to search for, "foobar" appears 20 times
   call append(0, repeat(['foobar', 'foo', 'fooooobar', 'foba', 'foobar'], 10))
 
   " 1) match at second line
@@ -105,6 +106,30 @@ func! Test_search_stat()
     call assert_false(1)
   endtry
 
+  " 11) normal, n comes from a mapping
+  "     Need to move over more than 64 lines to trigger char_avail(.
+  nnoremap n nzv
+  call cursor(1,1)
+  call append(50, repeat(['foobar', 'foo', 'fooooobar', 'foba', 'foobar'], 10))
+  call setline(2, 'find this')
+  call setline(70, 'find this')
+  let @/ = 'find this'
+  let pat = '/find this\s\+'
+  let g:a = execute(':unsilent :norm n')
+  " g:a will contain several lines
+  let g:b = split(g:a, "\n")[-1]
+  let stat = '\[1/2\]'
+  call assert_match(pat .. stat, g:b)
+  unmap n
+
+  " 11) normal, but silent
+  call cursor(1,1)
+  let @/ = 'find this'
+  let pat = '/find this\s\+'
+  let g:a = execute(':norm! n')
+  let stat = '\[1/2\]'
+  call assert_notmatch(pat .. stat, g:a)
+
   " close the window
   set shortmess+=S
   bwipe!
index e2ca5b04a1220a61732d0650ed915f2110c8a114..fb1235c4a0a8e1f1483d92fc27549bf96aa7952d 100644 (file)
@@ -767,6 +767,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1288,
 /**/
     1287,
 /**/