]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.0.1011: ml_get error when using screenpos() v9.0.1011
authorBram Moolenaar <Bram@vim.org>
Mon, 5 Dec 2022 16:23:24 +0000 (16:23 +0000)
committerBram Moolenaar <Bram@vim.org>
Mon, 5 Dec 2022 16:23:24 +0000 (16:23 +0000)
Problem:    ml_get error when using screenpos().
Solution:   Give an error for the line number. (closes #11661)

src/move.c
src/testdir/test_cursor_func.vim
src/version.c

index 7a9ae3ea60d4319ba3564877d1ccd9913f1a9016..954a13714d6fffca75015925e52f2214b235f400 100644 (file)
@@ -1500,6 +1500,11 @@ f_screenpos(typval_T *argvars UNUSED, typval_T *rettv)
        return;
 
     pos.lnum = tv_get_number(&argvars[1]);
+    if (pos.lnum > wp->w_buffer->b_ml.ml_line_count)
+    {
+       semsg(_(e_invalid_line_number_nr), pos.lnum);
+       return;
+    }
     pos.col = tv_get_number(&argvars[2]) - 1;
     pos.coladd = 0;
     textpos2screenpos(wp, &pos, &row, &scol, &ccol, &ecol);
index a48db15e66b7082f2a699eb87ea8524c2bc25f5c..8bdc956e269842a63aaf92dbc16dc2a117f622a9 100644 (file)
@@ -167,6 +167,9 @@ func Test_screenpos_number()
   let pos = screenpos(winid, 1, 66)
   call assert_equal(winrow, pos.row)
   call assert_equal(wincol + 66 + 3, pos.col)
+
+  call assert_fails('echo screenpos(0, 2, 1)', 'E966:')
+
   close
   bwipe!
 endfunc
index b8b346071abb624b72ab266c23f6a4fb3254637a..48bec3d9a99d0aa9bf70bbaf68cb7a71925c3120 100644 (file)
@@ -695,6 +695,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1011,
 /**/
     1010,
 /**/