mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 9.0.0047: using freed memory with recursive substitute
Problem: Using freed memory with recursive substitute. Solution: Always make a copy for reg_prev_sub.
This commit is contained in:
parent
baefde1455
commit
32acf1f1a7
@ -3994,7 +3994,16 @@ ex_substitute(exarg_T *eap)
|
|||||||
sub_copy = sub;
|
sub_copy = sub;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
sub = regtilde(sub, magic_isset());
|
{
|
||||||
|
char_u *newsub = regtilde(sub, magic_isset());
|
||||||
|
|
||||||
|
if (newsub != sub)
|
||||||
|
{
|
||||||
|
// newsub was allocated, free it later.
|
||||||
|
sub_copy = newsub;
|
||||||
|
sub = newsub;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check for a match on each line.
|
* Check for a match on each line.
|
||||||
|
@ -1766,11 +1766,11 @@ regtilde(char_u *source, int magic)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Store a copy of newsub in reg_prev_sub. It is always allocated,
|
||||||
|
// because recursive calls may make the returned string invalid.
|
||||||
vim_free(reg_prev_sub);
|
vim_free(reg_prev_sub);
|
||||||
if (newsub != source) // newsub was allocated, just keep it
|
reg_prev_sub = vim_strsave(newsub);
|
||||||
reg_prev_sub = newsub;
|
|
||||||
else // no ~ found, need to save newsub
|
|
||||||
reg_prev_sub = vim_strsave(newsub);
|
|
||||||
return newsub;
|
return newsub;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1114,4 +1114,15 @@ func Test_using_two_engines_pattern()
|
|||||||
bwipe!
|
bwipe!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_recursive_substitute_expr()
|
||||||
|
new
|
||||||
|
func Repl()
|
||||||
|
s
|
||||||
|
endfunc
|
||||||
|
silent! s/\%')/~\=Repl()
|
||||||
|
|
||||||
|
bwipe!
|
||||||
|
delfunc Repl
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@ -735,6 +735,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
47,
|
||||||
/**/
|
/**/
|
||||||
46,
|
46,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user