summaryrefslogtreecommitdiffstats
path: root/window-choose.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@openbsd.org>2012-10-11 08:53:50 +0000
committerNicholas Marriott <nicm@openbsd.org>2012-10-11 08:53:50 +0000
commit6589120667587f2d5c6f59f9faf4bda584a9f602 (patch)
tree770a8c173e580822ee9db8d6b2329bdd3fa85e01 /window-choose.c
parent0e87430462fad1276545bd53c789977e33c7c090 (diff)
Fix a use-after-free when collapsing the tree in choose mode, from
Carl Henrik Lunde.
Diffstat (limited to 'window-choose.c')
-rw-r--r--window-choose.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/window-choose.c b/window-choose.c
index 55f95de7..019f4125 100644
--- a/window-choose.c
+++ b/window-choose.c
@@ -181,8 +181,8 @@ window_choose_free(struct window_pane *wp)
struct window_choose_mode_item *item;
u_int i;
- for (i = 0; i < ARRAY_LENGTH(&data->list); i++) {
- item = &ARRAY_ITEM(&data->list, i);
+ for (i = 0; i < ARRAY_LENGTH(&data->old_list); i++) {
+ item = &ARRAY_ITEM(&data->old_list, i);
if (data->freefn != NULL && item->wcd != NULL)
data->freefn(item->wcd);
free(item->name);
@@ -289,6 +289,7 @@ window_choose_collapse(struct window_pane *wp, struct session *s)
if (!ARRAY_EMPTY(&list_copy)) {
ARRAY_FREE(&data->list);
ARRAY_CONCAT(&data->list, &list_copy);
+ ARRAY_FREE(&list_copy);
}
}
@@ -296,11 +297,11 @@ void
window_choose_collapse_all(struct window_pane *wp)
{
struct window_choose_mode_data *data = wp->modedata;
- struct window_choose_mode_item *item, *chosen;
- struct session *s;
+ struct window_choose_mode_item *item;
+ struct session *s, *chosen;
u_int i;
- chosen = &ARRAY_ITEM(&data->list, data->selected);
+ chosen = ARRAY_ITEM(&data->list, data->selected).wcd->session;
RB_FOREACH(s, sessions, &sessions)
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++) {
item = &ARRAY_ITEM(&data->list, i);
- if (chosen->wcd->session != item->wcd->tree_session)
+ if (chosen != item->wcd->tree_session)
continue;
if (item->wcd->type & TREE_SESSION)