aboutsummaryrefslogtreecommitdiff
path: root/window.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2017-07-03 10:01:14 +0100
committerThomas Adam <thomas@xteddy.org>2017-07-03 10:01:14 +0100
commit4e01036cb67e4c9297f7e220e575b52b13252352 (patch)
treeffda1cb385ecedb360a737858a4788506d5e945b /window.c
parent6fba9a39b7c747dcbd83ef0e50c84b7cd3b547c9 (diff)
parent28687f2d55fb30654a7164bf1445f47b052ea115 (diff)
downloadrtmux-4e01036cb67e4c9297f7e220e575b52b13252352.tar.gz
rtmux-4e01036cb67e4c9297f7e220e575b52b13252352.tar.bz2
rtmux-4e01036cb67e4c9297f7e220e575b52b13252352.zip
Merge branch 'obsd-master'
Diffstat (limited to 'window.c')
-rw-r--r--window.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/window.c b/window.c
index 16797dfd..a9ea0970 100644
--- a/window.c
+++ b/window.c
@@ -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