mirror of
https://github.com/neovim/neovim.git
synced 2025-11-05 18:24:22 +00:00
Fix warnings: window.c: close_last_window_tabpage(): Use after free: RI.
Problem : Use after free @ 1795.
Diagnostic : Real issue.
Rationale : prev_curtab can in fact be freed as a result of call
`win_close_othertab(win, free_buf, prev_curtab);`, but it's
later used at
`sprintf(..., tabpage_index(prev_curtab));`.
This was introduced at
3ffc5d81c3.
Resolution : Move prev_idx calculation before the call freeing
prev_curtab.
This commit is contained in:
@@ -1779,6 +1779,10 @@ static int close_last_window_tabpage(win_T *win, int free_buf, tabpage_T *prev_c
|
|||||||
goto_tabpage_tp(alt_tabpage(), FALSE, TRUE);
|
goto_tabpage_tp(alt_tabpage(), FALSE, TRUE);
|
||||||
redraw_tabline = TRUE;
|
redraw_tabline = TRUE;
|
||||||
|
|
||||||
|
// save index for tabclosed event
|
||||||
|
char_u prev_idx[NUMBUFLEN];
|
||||||
|
sprintf((char *)prev_idx, "%i", tabpage_index(prev_curtab));
|
||||||
|
|
||||||
/* Safety check: Autocommands may have closed the window when jumping
|
/* Safety check: Autocommands may have closed the window when jumping
|
||||||
* to the other tab page. */
|
* to the other tab page. */
|
||||||
if (valid_tabpage(prev_curtab) && prev_curtab->tp_firstwin == win) {
|
if (valid_tabpage(prev_curtab) && prev_curtab->tp_firstwin == win) {
|
||||||
@@ -1790,8 +1794,6 @@ static int close_last_window_tabpage(win_T *win, int free_buf, tabpage_T *prev_c
|
|||||||
}
|
}
|
||||||
/* Since goto_tabpage_tp above did not trigger *Enter autocommands, do
|
/* Since goto_tabpage_tp above did not trigger *Enter autocommands, do
|
||||||
* that now. */
|
* that now. */
|
||||||
char_u prev_idx[NUMBUFLEN];
|
|
||||||
sprintf((char *)prev_idx, "%i", tabpage_index(prev_curtab));
|
|
||||||
apply_autocmds(EVENT_TABCLOSED, prev_idx, prev_idx, FALSE, curbuf);
|
apply_autocmds(EVENT_TABCLOSED, prev_idx, prev_idx, FALSE, curbuf);
|
||||||
apply_autocmds(EVENT_WINENTER, NULL, NULL, FALSE, curbuf);
|
apply_autocmds(EVENT_WINENTER, NULL, NULL, FALSE, curbuf);
|
||||||
apply_autocmds(EVENT_TABENTER, NULL, NULL, FALSE, curbuf);
|
apply_autocmds(EVENT_TABENTER, NULL, NULL, FALSE, curbuf);
|
||||||
|
|||||||
Reference in New Issue
Block a user