From: Bram Moolenaar Date: Tue, 25 Jan 2022 20:45:16 +0000 (+0000) Subject: patch 8.2.4218: illegal memory access with bracketed paste in Ex mode X-Git-Tag: v8.2.4218 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=806d037671e133bd28a7864248763f643967973a;p=vim patch 8.2.4218: illegal memory access with bracketed paste in Ex mode Problem: Illegal memory access with bracketed paste in Ex mode. Solution: Reserve space for the trailing NUL. --- diff --git a/src/edit.c b/src/edit.c index ee3caf0da..2b5301100 100644 --- a/src/edit.c +++ b/src/edit.c @@ -4452,7 +4452,8 @@ bracketed_paste(paste_mode_T mode, int drop, garray_T *gap) break; case PASTE_EX: - if (gap != NULL && ga_grow(gap, idx) == OK) + // add one for the NUL that is going to be appended + if (gap != NULL && ga_grow(gap, idx + 1) == OK) { mch_memmove((char *)gap->ga_data + gap->ga_len, buf, (size_t)idx); diff --git a/src/testdir/test_paste.vim b/src/testdir/test_paste.vim index c94fe7c35..5b8d8a0e3 100644 --- a/src/testdir/test_paste.vim +++ b/src/testdir/test_paste.vim @@ -90,6 +90,9 @@ func Test_paste_ex_mode() unlet! foo call feedkeys("Qlet foo=\"\[200~foo\bar\[201~\"\vi\", 'xt') call assert_equal("foo\rbar", foo) + + " pasting more than 40 bytes + exe "norm Q\0000000000000000000000000000000000000000000000000000000000000000000000\" endfunc func Test_paste_onechar() diff --git a/src/version.c b/src/version.c index 6685b554f..9dcf34928 100644 --- a/src/version.c +++ b/src/version.c @@ -750,6 +750,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 4218, /**/ 4217, /**/