aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2023-02-20 23:02:05 +0800
committerGitHub <noreply@github.com>2023-02-20 23:02:05 +0800
commit93c627b90b4955967943b7a47fe63b094a0c50e6 (patch)
tree8a937e5e3e15a839dbdd28495730657ce33f1331
parentf1816f9ee2a8b811fd6ce4e60a843087f855f97d (diff)
downloadrneovim-93c627b90b4955967943b7a47fe63b094a0c50e6.tar.gz
rneovim-93c627b90b4955967943b7a47fe63b094a0c50e6.tar.bz2
rneovim-93c627b90b4955967943b7a47fe63b094a0c50e6.zip
vim-patch:9.0.1331: illegal memory access when using :ball in Visual mode (#22343)
Problem: Illegal memory access when using :ball in Visual mode. Solution: Stop Visual mode when using :ball. (Pavel Mayorov, closes vim/vim#11923) https://github.com/vim/vim/commit/e1121b139480f53d1b06f84f3e4574048108fa0b Co-authored-by: Pavel Mayorov <pmayorov@cloudlinux.com>
-rw-r--r--src/nvim/buffer.c4
-rw-r--r--src/nvim/testdir/test_visual.vim21
2 files changed, 25 insertions, 0 deletions
diff --git a/src/nvim/buffer.c b/src/nvim/buffer.c
index 98832a98c9..7a4e5d3eeb 100644
--- a/src/nvim/buffer.c
+++ b/src/nvim/buffer.c
@@ -3600,6 +3600,10 @@ void ex_buffer_all(exarg_T *eap)
all = true;
}
+ // Stop Visual mode, the cursor and "VIsual" may very well be invalid after
+ // switching to another buffer.
+ reset_VIsual_and_resel();
+
setpcmark();
// Close superfluous windows (two windows for the same buffer).
diff --git a/src/nvim/testdir/test_visual.vim b/src/nvim/testdir/test_visual.vim
index 1e9629c2c4..350c69fe4e 100644
--- a/src/nvim/testdir/test_visual.vim
+++ b/src/nvim/testdir/test_visual.vim
@@ -1536,4 +1536,25 @@ func Test_switch_buffer_ends_visual_mode()
exe 'bwipe!' buf2
endfunc
+" Check fix for the heap-based buffer overflow bug found in the function
+" utfc_ptr2len and reported at
+" https://huntr.dev/bounties/ae933869-a1ec-402a-bbea-d51764c6618e
+func Test_heap_buffer_overflow()
+ enew
+ set updatecount=0
+
+ norm R0
+ split other
+ norm R000
+ exe "norm \<C-V>l"
+ ball
+ call assert_equal(getpos("."), getpos("v"))
+ call assert_equal('n', mode())
+ norm zW
+
+ %bwipe!
+ set updatecount&
+endfunc
+
+
" vim: shiftwidth=2 sts=2 expandtab