diff options
author | Thomas Adam <thomas@xteddy.org> | 2017-07-03 10:01:14 +0100 |
---|---|---|
committer | Thomas Adam <thomas@xteddy.org> | 2017-07-03 10:01:14 +0100 |
commit | 4e01036cb67e4c9297f7e220e575b52b13252352 (patch) | |
tree | ffda1cb385ecedb360a737858a4788506d5e945b /window.c | |
parent | 6fba9a39b7c747dcbd83ef0e50c84b7cd3b547c9 (diff) | |
parent | 28687f2d55fb30654a7164bf1445f47b052ea115 (diff) | |
download | rtmux-4e01036cb67e4c9297f7e220e575b52b13252352.tar.gz rtmux-4e01036cb67e4c9297f7e220e575b52b13252352.tar.bz2 rtmux-4e01036cb67e4c9297f7e220e575b52b13252352.zip |
Merge branch 'obsd-master'
Diffstat (limited to 'window.c')
-rw-r--r-- | window.c | 19 |
1 files changed, 18 insertions, 1 deletions
@@ -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 |