]> granicus.if.org Git - vim/commitdiff
patch 8.2.1573: Vim9: getreg() does not take "true" as argument v8.2.1573
authorBram Moolenaar <Bram@vim.org>
Wed, 2 Sep 2020 19:45:54 +0000 (21:45 +0200)
committerBram Moolenaar <Bram@vim.org>
Wed, 2 Sep 2020 19:45:54 +0000 (21:45 +0200)
Problem:    Vim9: getreg() does not take "true" as argument.
Solution:   Use tv_get_bool_chk().  (closes #6820)

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

index 69f781632991529731f9b87cd4de50bec75a23d4..340ecf09582062065ee351dbe12cd7f3ec69af1f 100644 (file)
@@ -3336,9 +3336,9 @@ f_getreg(typval_T *argvars, typval_T *rettv)
        error = strregname == NULL;
        if (argvars[1].v_type != VAR_UNKNOWN)
        {
-           arg2 = (int)tv_get_number_chk(&argvars[1], &error);
+           arg2 = (int)tv_get_bool_chk(&argvars[1], &error);
            if (!error && argvars[2].v_type != VAR_UNKNOWN)
-               return_list = (int)tv_get_number_chk(&argvars[2], &error);
+               return_list = (int)tv_get_bool_chk(&argvars[2], &error);
        }
     }
     else
index cf48ba8660e0695cac25a7991cb84c3be0e3d629..8d8e0d48eac7dfbd55bc8d4e88a902668915af6f 100644 (file)
@@ -1503,6 +1503,12 @@ def Test_expand()
   close
 enddef
 
+def Test_getreg()
+  let lines = ['aaa', 'bbb', 'ccc']
+  setreg('a', lines)
+  assert_equal(lines, getreg('a', true, true))
+enddef
+
 def Test_recursive_call()
   assert_equal(6765, Fibonacci(20))
 enddef
index c674148ee1646b22a9b7a35736fb52eab60b288f..886cd4ef410870c298528512b86a848764bdbd37 100644 (file)
@@ -754,6 +754,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1573,
 /**/
     1572,
 /**/