patch 9.1.0438: Wrong Ex command executed when :g uses '?' as delimiter Commit: https://github.com/vim/vim/commit/3074137542961ce7b3b65c14ebde75f13f5e6147 Author: zeertzjq <zeert...@outlook.com> Date: Fri May 24 07:37:36 2024 +0200
patch 9.1.0438: Wrong Ex command executed when :g uses '?' as delimiter Problem: Wrong Ex command executed when :g uses '?' as delimiter and pattern contains escaped '?'. Solution: Don't use "*newp" when it's not allocated (zeertzjq). closes: #14837 Signed-off-by: zeertzjq <zeert...@outlook.com> Signed-off-by: Christian Brabandt <c...@256bit.org> diff --git a/src/regexp.c b/src/regexp.c index 147452aae..ff201d9ff 100644 --- a/src/regexp.c +++ b/src/regexp.c @@ -620,7 +620,7 @@ skip_regexp_ex( { magic_T mymagic; char_u *p = startp; - size_t startplen = STRLEN(startp); + size_t startplen = 0; if (magic) mymagic = MAGIC_ON; @@ -644,16 +644,21 @@ skip_regexp_ex( if (dirc == '?' && newp != NULL && p[1] == '?') { // change "\?" to "?", make a copy first. + if (startplen == 0) + startplen = STRLEN(startp); if (*newp == NULL) { *newp = vim_strnsave(startp, startplen); if (*newp != NULL) + { p = *newp + (p - startp); + startp = *newp; + } } if (dropped != NULL) ++*dropped; if (*newp != NULL) - mch_memmove(p, p + 1, (startplen - ((p + 1) - *newp)) + 1); + mch_memmove(p, p + 1, startplen - ((p + 1) - startp) + 1); else ++p; } diff --git a/src/testdir/test_global.vim b/src/testdir/test_global.vim index 34857b255..0f72c3cf8 100644 --- a/src/testdir/test_global.vim +++ b/src/testdir/test_global.vim @@ -116,7 +116,16 @@ func Test_global_newline() close! endfunc -func Test_wrong_delimiter() +" Test :g with ? as delimiter. +func Test_global_question_delimiter() + new + call setline(1, ['aaaaa', 'b?bbb', 'ccccc', 'ddd?d', 'eeeee']) + g?\??delete + call assert_equal(['aaaaa', 'ccccc', 'eeeee'], getline(1, '$')) + bwipe! +endfunc + +func Test_global_wrong_delimiter() call assert_fails('g x^bxd', 'E146:') endfunc diff --git a/src/testdir/test_substitute.vim b/src/testdir/test_substitute.vim index a2367cd23..afdc104d7 100644 --- a/src/testdir/test_substitute.vim +++ b/src/testdir/test_substitute.vim @@ -174,8 +174,8 @@ func Test_substitute_repeat() bwipe! endfunc -" Test :s with ? as separator. -func Test_substitute_question_separator() +" Test :s with ? as delimiter. +func Test_substitute_question_delimiter() new call setline(1, '??:??') %s?\?\??!!?g diff --git a/src/version.c b/src/version.c index 7188cbd88..ac1a1f4f3 100644 --- a/src/version.c +++ b/src/version.c @@ -704,6 +704,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 438, /**/ 437, /**/ -- -- You received this message from the "vim_dev" maillist. Do not top-post! Type your reply below the text you are replying to. For more information, visit http://www.vim.org/maillist.php --- You received this message because you are subscribed to the Google Groups "vim_dev" group. To unsubscribe from this group and stop receiving emails from it, send an email to vim_dev+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/vim_dev/E1sANjt-003n8R-BY%40256bit.org.