summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2023-01-04 17:17:54 +0000
committerBram Moolenaar <Bram@vim.org>2023-01-04 17:17:54 +0000
commit3ac1d97a1d9353490493d30088256360435f7731 (patch)
treeabb98762b33578fd248937ad21d1099e19a3e081
parentc32949b0779106ed5710ae3bffc5053e49083ab4 (diff)
patch 9.0.1145: invalid memory access with recursive substitute expressionv9.0.1145
Problem: Invalid memory access with recursive substitute expression. Solution: Check the return value of vim_regsub().
-rw-r--r--src/eval.c5
-rw-r--r--src/testdir/test_substitute.vim16
-rw-r--r--src/version.c2
3 files changed, 23 insertions, 0 deletions
diff --git a/src/eval.c b/src/eval.c
index 2fbd867aba..9ca805061d 100644
--- a/src/eval.c
+++ b/src/eval.c
@@ -7312,6 +7312,11 @@ do_string_sub(
* - The text after the match.
*/
sublen = vim_regsub(&regmatch, sub, expr, tail, 0, REGSUB_MAGIC);
+ if (sublen <= 0)
+ {
+ ga_clear(&ga);
+ break;
+ }
if (ga_grow(&ga, (int)((end - tail) + sublen -
(regmatch.endp[0] - regmatch.startp[0]))) == FAIL)
{
diff --git a/src/testdir/test_substitute.vim b/src/testdir/test_substitute.vim
index 2513223372..4268aab03f 100644
--- a/src/testdir/test_substitute.vim
+++ b/src/testdir/test_substitute.vim
@@ -1115,6 +1115,22 @@ func Test_sub_expr_goto_other_file()
bwipe!
endfunc
+func Test_recursive_expr_substitute()
+ " this was reading invalid memory
+ let lines =<< trim END
+ func Repl(g, n)
+ s
+ r%:s000
+ endfunc
+ next 0
+ let caught = 0
+ s/\%')/\=Repl(0, 0)
+ qall!
+ END
+ call writefile(lines, 'XexprSubst', 'D')
+ call RunVim([], [], '--clean -S XexprSubst')
+endfunc
+
" Test for the 2-letter and 3-letter :substitute commands
func Test_substitute_short_cmd()
new
diff --git a/src/version.c b/src/version.c
index 6e652c697c..9c38fd91cf 100644
--- a/src/version.c
+++ b/src/version.c
@@ -696,6 +696,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1145,
+/**/
1144,
/**/
1143,