0
0
mirror of https://github.com/vim/vim.git synced 2025-07-26 11:04:33 -04:00

patch 8.2.3675: using freed memory when vim_strsave() fails

Problem:    Using freed memory when vim_strsave() fails.
Solution:   Clear "last_sourcing_name".  Check for msg_source() called
            recursively. (closes #8217)
This commit is contained in:
Bram Moolenaar 2021-11-25 14:43:18 +00:00
parent 96e7a5928e
commit ba8c92687d
2 changed files with 12 additions and 4 deletions

View File

@ -522,6 +522,12 @@ get_emsg_lnum(void)
msg_source(int attr)
{
char_u *p;
static int recursive = FALSE;
// Bail out if something called here causes an error.
if (recursive)
return;
recursive = TRUE;
++no_wait_return;
p = get_emsg_source();
@ -541,13 +547,13 @@ msg_source(int attr)
// remember the last sourcing name printed, also when it's empty
if (SOURCING_NAME == NULL || other_sourcing_name())
{
vim_free(last_sourcing_name);
if (SOURCING_NAME == NULL)
last_sourcing_name = NULL;
else
VIM_CLEAR(last_sourcing_name);
if (SOURCING_NAME != NULL)
last_sourcing_name = vim_strsave(SOURCING_NAME);
}
--no_wait_return;
recursive = FALSE;
}
/*

View File

@ -757,6 +757,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
3675,
/**/
3674,
/**/