]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 8.2.4956: reading past end of line with "gf" in Visual block mode v8.2.4956
authorBram Moolenaar <Bram@vim.org>
Sat, 14 May 2022 20:29:44 +0000 (21:29 +0100)
committerBram Moolenaar <Bram@vim.org>
Sat, 14 May 2022 20:29:44 +0000 (21:29 +0100)
Problem:    Reading past end of line with "gf" in Visual block mode.
Solution:   Do not include the NUL in the length.

src/normal.c
src/testdir/test_gf.vim
src/version.c

index 1baf68a1453aee41c98451039ae114a5350a4a57..bc3e29e1abaa13a179f5344c0faf6b702412058a 100644 (file)
@@ -3671,9 +3671,16 @@ get_visual_text(
        }
        if (**pp == NUL)
            *lenp = 0;
-       if (has_mbyte && *lenp > 0)
-           // Correct the length to include all bytes of the last character.
-           *lenp += (*mb_ptr2len)(*pp + (*lenp - 1)) - 1;
+       if (*lenp > 0)
+       {
+           if (has_mbyte)
+               // Correct the length to include all bytes of the last
+               // character.
+               *lenp += (*mb_ptr2len)(*pp + (*lenp - 1)) - 1;
+           else if ((*pp)[*lenp - 1] == NUL)
+               // Do not include a trailing NUL.
+               *lenp -= 1;
+       }
     }
     reset_VIsual_and_resel();
     return OK;
index 3602ba010e8c421c43a415feb5017cfd97c63e40..1b3b139810eca88e0b21620167742dbe79b0645a 100644 (file)
@@ -138,6 +138,21 @@ func Test_gf_visual()
   call assert_equal('Xtest_gf_visual', bufname('%'))
   call assert_equal(3, getcurpos()[1])
 
+  " do not include the NUL at the end 
+  call writefile(['x'], 'X')
+  let save_enc = &enc
+  for enc in ['latin1', 'utf-8']
+    exe "set enc=" .. enc
+    new
+    call setline(1, 'X')
+    set nomodified
+    exe "normal \<C-V>$gf"
+    call assert_equal('X', bufname())
+    bwipe!
+  endfor
+  let &enc = save_enc
+  call delete('X')
+
   " line number in visual area is used for file name
   if has('unix')
     bwipe!
index 62e2b0af69411f8eb7602245686290b1653db8a9..821f3680e2fb5d2d2a8d813cd33f0c31d3298557 100644 (file)
@@ -746,6 +746,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    4956,
 /**/
     4955,
 /**/