]> granicus.if.org Git - vim/commitdiff
patch 8.2.2843: Vim9: skip argument to searchpairpos() is not compiled v8.2.2843
authorBram Moolenaar <Bram@vim.org>
Fri, 7 May 2021 17:44:21 +0000 (19:44 +0200)
committerBram Moolenaar <Bram@vim.org>
Fri, 7 May 2021 17:44:21 +0000 (19:44 +0200)
Problem:    Vim9: skip argument to searchpairpos() is not compiled.
Solution:   Handle like searchpair().  Also for search() and searchpos().

src/testdir/test_vim9_builtin.vim
src/version.c
src/vim9compile.c

index 3232d9b3b7e921007da9b46a7963011106a8051f..41063c544446a089e22f3e7571afcb1be9c7a587 100644 (file)
@@ -958,6 +958,20 @@ def Test_search()
   search('bar', 'W', 0, 0, () => 1)->assert_equal(0)
   assert_fails("search('bar', '', 0, 0, () => -1)", 'E1023:')
   assert_fails("search('bar', '', 0, 0, () => -1)", 'E1023:')
+
+  setline(1, "find this word")
+  normal gg
+  var col = 7
+  assert_equal(1, search('this', '', 0, 0, 'col(".") > col'))
+  normal 0
+  assert_equal([1, 6], searchpos('this', '', 0, 0, 'col(".") > col'))
+
+  col = 5
+  normal 0
+  assert_equal(0, search('this', '', 0, 0, 'col(".") > col'))
+  normal 0
+  assert_equal([0, 0], searchpos('this', '', 0, 0, 'col(".") > col'))
+  bwipe!
 enddef
 
 def Test_searchcount()
@@ -977,14 +991,21 @@ enddef
 def Test_searchpair()
   new
   setline(1, "here { and } there")
+
   normal f{
   var col = 15
   assert_equal(1, searchpair('{', '', '}', '', 'col(".") > col'))
   assert_equal(12, col('.'))
+  normal 0f{
+  assert_equal([1, 12], searchpairpos('{', '', '}', '', 'col(".") > col'))
+
   col = 8
   normal 0f{
   assert_equal(0, searchpair('{', '', '}', '', 'col(".") > col'))
   assert_equal(6, col('.'))
+  normal 0f{
+  assert_equal([0, 0], searchpairpos('{', '', '}', '', 'col(".") > col'))
+
   bwipe!
 enddef
 
index 12aace894d70bd2f53449c741fb20d70305a14fe..01c77921cf9c0b1987ef6d01294ad3f2da309031 100644 (file)
@@ -750,6 +750,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    2843,
 /**/
     2842,
 /**/
index 03aca55b8cfd4982b1d4ed9dec6308a674297303..fd32660e07fb89ca48900ee0db6a6ddffa52a99d 100644 (file)
@@ -3285,8 +3285,12 @@ compile_call(
     vim_strncpy(namebuf, *arg, varlen);
     name = fname_trans_sid(namebuf, fname_buf, &tofree, &error);
 
-    // we handle the "skip" argument of searchpair() differently
-    is_searchpair = (varlen == 10 && STRNCMP(*arg, "searchpair", 10) == 0);
+    // We handle the "skip" argument of searchpair() and searchpairpos()
+    // differently.
+    is_searchpair = (varlen == 6 && STRNCMP(*arg, "search", 6) == 0)
+                || (varlen == 9 && STRNCMP(*arg, "searchpos", 9) == 0)
+               || (varlen == 10 && STRNCMP(*arg, "searchpair", 10) == 0)
+               || (varlen == 13 && STRNCMP(*arg, "searchpairpos", 13) == 0);
 
     *arg = skipwhite(*arg + varlen + 1);
     if (compile_arguments(arg, cctx, &argcount, is_searchpair) == FAIL)