]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.1143: illegal memory access when putting a register v9.1.1143
authorChristian Brabandt <cb@256bit.org>
Sun, 23 Feb 2025 19:01:54 +0000 (20:01 +0100)
committerChristian Brabandt <cb@256bit.org>
Sun, 23 Feb 2025 19:01:54 +0000 (20:01 +0100)
Problem:  illegal memory access when putting a register
Solution: make sure cursor column doesn't become negative

Signed-off-by: Christian Brabandt <cb@256bit.org>
src/register.c
src/testdir/test_registers.vim
src/version.c

index a9630f8ef5db93c71115e25c1052111e627c01f8..ea54e202efc58749ddad896d2c9db2d8574a46f8 100644 (file)
@@ -2249,7 +2249,7 @@ error:
            // Put the '] mark on the first byte of the last inserted character.
            // Correct the length for change in indent.
            curbuf->b_op_end.lnum = new_lnum;
-           col = (colnr_T)y_array[y_size - 1].length - lendiff;
+           col = MAX(0, (colnr_T)y_array[y_size - 1].length - lendiff);
            if (col > 1)
            {
                curbuf->b_op_end.col = col - 1;
index ee59ecb3042300047f75989b56e81f87edaa4b56..2524453775cd81cecb7b72cc28690e33527fc7d6 100644 (file)
@@ -1123,4 +1123,21 @@ func Test_register_redir_display()
   call setreg(1, a[0], a[1])
 endfunc
 
+" this caused an illegal memory access and a crash
+func Test_register_cursor_column_negative()
+  CheckRunVimInTerminal
+  let script =<< trim END
+    f XREGISTER
+    call setline(1, 'abcdef a')
+    call setreg("a", "\n", 'c')
+    call cursor(1, 7)
+    call feedkeys("i\<C-R>\<C-P>azyx$#\<esc>", 't')
+  END
+  call writefile(script, 'XRegister123', 'D')
+  let buf = RunVimInTerminal('-S XRegister123', {})
+  call term_sendkeys(buf, "\<c-g>")
+  call WaitForAssert({-> assert_match('XREGISTER', term_getline(buf, 19))})
+  call StopVimInTerminal(buf)
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
index 2dfd4c83ec8e79dad59b6d84a7ac26924d6e310d..07bede551ada6f289ab32fd5892745a04205726c 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1143,
 /**/
     1142,
 /**/