]> granicus.if.org Git - vim/commitdiff
patch 8.2.1577: Vim9: hasmapto()/mapcheck()/maparg() do nottake "true" arg v8.2.1577
authorBram Moolenaar <Bram@vim.org>
Wed, 2 Sep 2020 20:25:35 +0000 (22:25 +0200)
committerBram Moolenaar <Bram@vim.org>
Wed, 2 Sep 2020 20:25:35 +0000 (22:25 +0200)
Problem:    Vim9: hasmapto(), mapcheck() and maparg() do not take "true" as
            argument.
Solution:   Use tv_get_bool(). (closes #6822, closes #6824)

src/evalfunc.c
src/map.c
src/testdir/test_vim9_func.vim
src/version.c

index 4f0bb5cea56a5dd69cb500399e6bccd19010f98a..91fbc675ce31b6eb0af503bc59a2549efd3730c5 100644 (file)
@@ -4808,7 +4808,7 @@ f_hasmapto(typval_T *argvars, typval_T *rettv)
     {
        mode = tv_get_string_buf(&argvars[1], buf);
        if (argvars[2].v_type != VAR_UNKNOWN)
-           abbr = (int)tv_get_number(&argvars[2]);
+           abbr = (int)tv_get_bool(&argvars[2]);
     }
 
     if (map_to_exists(name, mode, abbr))
index dd3139dcd52ab9952aaca3009f15dbbe70a7d6e6..eed3a55d041ee7a94a044400f69bca86a5d8dbd6 100644 (file)
--- a/src/map.c
+++ b/src/map.c
@@ -2204,9 +2204,9 @@ get_maparg(typval_T *argvars, typval_T *rettv, int exact)
        which = tv_get_string_buf_chk(&argvars[1], buf);
        if (argvars[2].v_type != VAR_UNKNOWN)
        {
-           abbr = (int)tv_get_number(&argvars[2]);
+           abbr = (int)tv_get_bool(&argvars[2]);
            if (argvars[3].v_type != VAR_UNKNOWN)
-               get_dict = (int)tv_get_number(&argvars[3]);
+               get_dict = (int)tv_get_bool(&argvars[3]);
        }
     }
     else
index 04f8d7aa7e1fc535ca5fbecdccb4f28eee003d44..f79c2e0bdb1f8a36258a02a2bd22cad1755136ab 100644 (file)
@@ -1521,6 +1521,45 @@ def Test_globpath()
   assert_equal(['./runtest.vim'], globpath('.', 'runtest.vim', true, true, true))
 enddef
 
+def Test_hasmapto()
+  assert_equal(0, hasmapto('foobar', 'i', true))
+  iabbrev foo foobar
+  assert_equal(1, hasmapto('foobar', 'i', true))
+  iunabbrev foo
+enddef
+
+def SID(): number
+  return expand('<SID>')
+          ->matchstr('<SNR>\zs\d\+\ze_$')
+          ->str2nr()
+enddef
+
+def Test_maparg()
+  let lnum = str2nr(expand('<sflnum>'))
+  map foo bar
+  assert_equal(#{
+        lnum: lnum + 1,
+        script: 0,
+        mode: ' ',
+        silent: 0,
+        noremap: 0,
+        lhs: 'foo',
+        lhsraw: 'foo',
+        nowait: 0,
+        expr: 0,
+        sid: SID(),
+        rhs: 'bar',
+        buffer: 0},
+        maparg('foo', '', false, true))
+  unmap foo
+enddef
+
+def Test_mapcheck()
+  iabbrev foo foobar
+  assert_equal('foobar', mapcheck('foo', 'i', true))
+  iunabbrev foo
+enddef
+
 def Test_recursive_call()
   assert_equal(6765, Fibonacci(20))
 enddef
index 388be57e3e2d88c87b67aa3c3f3000063bf3db89..5232e8485cb2543471e22107e88e30d5d3b26d32 100644 (file)
@@ -754,6 +754,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1577,
 /**/
     1576,
 /**/