If remain-on-exit is set, both the error callback and a SIGCHLD could

destroy the same pane (because the first one doesn't remove it from the
list of panes), causing the pane bufferevent to be freed twice. So don't
free it if the fd has already been set to -1, from Romain Francoise.
This commit is contained in:
Nicholas Marriott 2010-04-17 23:25:16 +00:00
parent 842bc2b855
commit a6d52405a8

View File

@ -325,9 +325,11 @@ server_destroy_pane(struct window_pane *wp)
{ {
struct window *w = wp->window; struct window *w = wp->window;
close(wp->fd); if (wp->fd != -1) {
bufferevent_free(wp->event); close(wp->fd);
wp->fd = -1; bufferevent_free(wp->event);
wp->fd = -1;
}
if (options_get_number(&w->options, "remain-on-exit")) if (options_get_number(&w->options, "remain-on-exit"))
return; return;