]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 8.2.2184: Vim9: no error when using "2" for a line number v8.2.2184
authorBram Moolenaar <Bram@vim.org>
Mon, 21 Dec 2020 20:58:46 +0000 (21:58 +0100)
committerBram Moolenaar <Bram@vim.org>
Mon, 21 Dec 2020 20:58:46 +0000 (21:58 +0100)
Problem:    Vim9: no error when using "2" for a line number.
Solution:   Give an error message if the line number is invalid. (closes #7492)

src/evalfunc.c
src/testdir/test_cursor_func.vim
src/testdir/test_vim9_builtin.vim
src/typval.c
src/version.c

index d40f89f086576296d7057511387117f40b23310f..cf9c2c45ca54576de737ca16f978b521570e8085 100644 (file)
@@ -2615,6 +2615,8 @@ f_cursor(typval_T *argvars, typval_T *rettv)
     else
     {
        line = tv_get_lnum(argvars);
+       if (line < 0)
+           semsg(_(e_invarg2), tv_get_string(&argvars[0]));
        col = (long)tv_get_number_chk(&argvars[1], NULL);
        if (argvars[2].v_type != VAR_UNKNOWN)
            coladd = (long)tv_get_number_chk(&argvars[2], NULL);
index d914067b26d284893b086d06f54c94e439c88780..cbaad24187bae8f062b82b5dcc0c683a0bec2442 100644 (file)
@@ -30,7 +30,7 @@ func Test_move_cursor()
   call cursor(1, 1, 1)
   call assert_equal([1, 1, 1], getcurpos()[1:3])
 
-  call assert_equal(-1, cursor(-1, -1))
+  call assert_fails('call cursor(-1, -1)', 'E475:')
 
   quit!
 endfunc
index a0504672d3ec641829db5dd8dcd63b98d43e5d28..0f03d1f5c58727a47cd94fe611de06c4b1d5c57c 100644 (file)
@@ -185,6 +185,20 @@ def Test_count()
   count('ABC ABC ABC', 'b', false)->assert_equal(0)
 enddef
 
+def Test_cursor()
+  new
+  setline(1, range(4))
+  cursor(2, 1)
+  assert_equal(2, getcurpos()[1])
+  cursor('$', 1)
+  assert_equal(4, getcurpos()[1])
+
+  var lines =<< trim END
+    cursor('2', 1)
+  END
+  CheckDefExecAndScriptFailure(lines, 'E475:')
+enddef
+
 def Test_executable()
   assert_false(executable(""))
   assert_false(executable(test_null_string()))
index affd668e927e8f7d86b0748b18dfa8a35a19fabf..df3bc92a4ca919f1514cc4d8e856ecb81ab995bc 100644 (file)
@@ -1536,11 +1536,11 @@ eval_env_var(char_u **arg, typval_T *rettv, int evaluate)
     linenr_T
 tv_get_lnum(typval_T *argvars)
 {
-    linenr_T   lnum = 0;
+    linenr_T   lnum = -1;
 
     if (argvars[0].v_type != VAR_STRING || !in_vim9script())
        lnum = (linenr_T)tv_get_number_chk(&argvars[0], NULL);
-    if (lnum == 0)  // no valid number, try using arg like line()
+    if (lnum <= 0)  // no valid number, try using arg like line()
     {
        int     fnum;
        pos_T   *fp = var2fpos(&argvars[0], TRUE, &fnum);
index bebfa115ee2a1be73003405e6d52e81fbd013cc5..05757634d09bc0205b2a32f1c051cfbee60a1cb7 100644 (file)
@@ -750,6 +750,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    2184,
 /**/
     2183,
 /**/