mirror of
https://github.com/vim/vim.git
synced 2025-09-24 03:44:06 -04:00
patch 8.2.5079: DirChanged autocommand may use freed memory
Problem: DirChanged autocommand may use freed memory. (Shane-XB Qian) Solution: Free the memory later. (closes #10555)
This commit is contained in:
@@ -7525,6 +7525,7 @@ changedir_func(
|
|||||||
int dir_differs;
|
int dir_differs;
|
||||||
char_u *acmd_fname = NULL;
|
char_u *acmd_fname = NULL;
|
||||||
char_u **pp;
|
char_u **pp;
|
||||||
|
char_u *tofree;
|
||||||
|
|
||||||
if (new_dir == NULL || allbuf_locked())
|
if (new_dir == NULL || allbuf_locked())
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@@ -7601,13 +7602,14 @@ changedir_func(
|
|||||||
pp = &curtab->tp_prevdir;
|
pp = &curtab->tp_prevdir;
|
||||||
else
|
else
|
||||||
pp = &prev_dir;
|
pp = &prev_dir;
|
||||||
vim_free(*pp);
|
tofree = *pp; // new_dir may use this
|
||||||
*pp = pdir;
|
*pp = pdir;
|
||||||
|
|
||||||
post_chdir(scope);
|
post_chdir(scope);
|
||||||
|
|
||||||
if (dir_differs)
|
if (dir_differs)
|
||||||
apply_autocmds(EVENT_DIRCHANGED, acmd_fname, new_dir, FALSE, curbuf);
|
apply_autocmds(EVENT_DIRCHANGED, acmd_fname, new_dir, FALSE, curbuf);
|
||||||
|
vim_free(tofree);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -2107,6 +2107,13 @@ function Test_dirchanged_global()
|
|||||||
call assert_equal(expected, s:li)
|
call assert_equal(expected, s:li)
|
||||||
exe 'lcd ' .. fnameescape(s:dir_bar)
|
exe 'lcd ' .. fnameescape(s:dir_bar)
|
||||||
call assert_equal(expected, s:li)
|
call assert_equal(expected, s:li)
|
||||||
|
|
||||||
|
exe 'cd ' .. s:dir_foo
|
||||||
|
exe 'cd ' .. s:dir_bar
|
||||||
|
autocmd! test_dirchanged DirChanged global let g:result = expand("<afile>")
|
||||||
|
cd -
|
||||||
|
call assert_equal(s:dir_foo, g:result)
|
||||||
|
|
||||||
call s:After_test_dirchanged()
|
call s:After_test_dirchanged()
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
@@ -734,6 +734,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 */
|
||||||
|
/**/
|
||||||
|
5079,
|
||||||
/**/
|
/**/
|
||||||
5078,
|
5078,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user