Fix a use-after-free when collapsing the tree in choose mode, from

Carl Henrik Lunde.
This commit is contained in:
Nicholas Marriott 2012-10-11 08:53:50 +00:00
parent 0e87430462
commit 6589120667

View File

@ -181,8 +181,8 @@ window_choose_free(struct window_pane *wp)
struct window_choose_mode_item *item; struct window_choose_mode_item *item;
u_int i; u_int i;
for (i = 0; i < ARRAY_LENGTH(&data->list); i++) { for (i = 0; i < ARRAY_LENGTH(&data->old_list); i++) {
item = &ARRAY_ITEM(&data->list, i); item = &ARRAY_ITEM(&data->old_list, i);
if (data->freefn != NULL && item->wcd != NULL) if (data->freefn != NULL && item->wcd != NULL)
data->freefn(item->wcd); data->freefn(item->wcd);
free(item->name); free(item->name);
@ -289,6 +289,7 @@ window_choose_collapse(struct window_pane *wp, struct session *s)
if (!ARRAY_EMPTY(&list_copy)) { if (!ARRAY_EMPTY(&list_copy)) {
ARRAY_FREE(&data->list); ARRAY_FREE(&data->list);
ARRAY_CONCAT(&data->list, &list_copy); ARRAY_CONCAT(&data->list, &list_copy);
ARRAY_FREE(&list_copy);
} }
} }
@ -296,11 +297,11 @@ void
window_choose_collapse_all(struct window_pane *wp) window_choose_collapse_all(struct window_pane *wp)
{ {
struct window_choose_mode_data *data = wp->modedata; struct window_choose_mode_data *data = wp->modedata;
struct window_choose_mode_item *item, *chosen; struct window_choose_mode_item *item;
struct session *s; struct session *s, *chosen;
u_int i; u_int i;
chosen = &ARRAY_ITEM(&data->list, data->selected); chosen = ARRAY_ITEM(&data->list, data->selected).wcd->session;
RB_FOREACH(s, sessions, &sessions) RB_FOREACH(s, sessions, &sessions)
window_choose_collapse(wp, s); window_choose_collapse(wp, s);
@ -309,7 +310,7 @@ window_choose_collapse_all(struct window_pane *wp)
for (i = 0; i < ARRAY_LENGTH(&data->list); i++) { for (i = 0; i < ARRAY_LENGTH(&data->list); i++) {
item = &ARRAY_ITEM(&data->list, i); item = &ARRAY_ITEM(&data->list, i);
if (chosen->wcd->session != item->wcd->tree_session) if (chosen != item->wcd->tree_session)
continue; continue;
if (item->wcd->type & TREE_SESSION) if (item->wcd->type & TREE_SESSION)