Merge branch 'obsd-master'

This commit is contained in:
Thomas Adam
2017-07-03 10:01:14 +01:00
5 changed files with 53 additions and 6 deletions

View File

@ -387,6 +387,19 @@ window_destroy(struct window *w)
free(w);
}
int
window_pane_destroy_ready(struct window_pane *wp)
{
if (wp->pipe_fd != -1 && EVBUFFER_LENGTH(wp->pipe_event->output) != 0)
return (0);
if (~wp->flags & PANE_EXITED)
return (0);
if (~wp->flags & PANE_ERROR)
return (0);
return (1);
}
void
window_add_ref(struct window *w, const char *from)
{
@ -1014,7 +1027,11 @@ window_pane_error_callback(__unused struct bufferevent *bufev,
{
struct window_pane *wp = data;
server_destroy_pane(wp, 1);
log_debug("%%%u error", wp->id);
wp->flags |= PANE_ERROR;
if (window_pane_destroy_ready(wp))
server_destroy_pane(wp, 1);
}
void