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 /cmd-pipe-pane.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 'cmd-pipe-pane.c')
-rw-r--r-- | cmd-pipe-pane.c | 26 |
1 files changed, 24 insertions, 2 deletions
diff --git a/cmd-pipe-pane.c b/cmd-pipe-pane.c index 75feb109..ba89ab00 100644 --- a/cmd-pipe-pane.c +++ b/cmd-pipe-pane.c @@ -34,6 +34,7 @@ static enum cmd_retval cmd_pipe_pane_exec(struct cmd *, struct cmdq_item *); +static void cmd_pipe_pane_write_callback(struct bufferevent *, void *); static void cmd_pipe_pane_error_callback(struct bufferevent *, short, void *); const struct cmd_entry cmd_pipe_pane_entry = { @@ -67,6 +68,11 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmdq_item *item) bufferevent_free(wp->pipe_event); close(wp->pipe_fd); wp->pipe_fd = -1; + + if (window_pane_destroy_ready(wp)) { + server_destroy_pane(wp, 1); + return (CMD_RETURN_NORMAL); + } } /* If no pipe command, that is enough. */ @@ -130,8 +136,9 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmdq_item *item) wp->pipe_fd = pipe_fd[0]; wp->pipe_off = EVBUFFER_LENGTH(wp->event->input); - wp->pipe_event = bufferevent_new(wp->pipe_fd, - NULL, NULL, cmd_pipe_pane_error_callback, wp); + wp->pipe_event = bufferevent_new(wp->pipe_fd, NULL, + cmd_pipe_pane_write_callback, cmd_pipe_pane_error_callback, + wp); bufferevent_enable(wp->pipe_event, EV_WRITE); setblocking(wp->pipe_fd, 0); @@ -142,12 +149,27 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmdq_item *item) } static void +cmd_pipe_pane_write_callback(__unused struct bufferevent *bufev, void *data) +{ + struct window_pane *wp = data; + + log_debug("%%%u pipe empty", wp->id); + if (window_pane_destroy_ready(wp)) + server_destroy_pane(wp, 1); +} + +static void cmd_pipe_pane_error_callback(__unused struct bufferevent *bufev, __unused short what, void *data) { struct window_pane *wp = data; + log_debug("%%%u pipe error", wp->id); + bufferevent_free(wp->pipe_event); close(wp->pipe_fd); wp->pipe_fd = -1; + + if (window_pane_destroy_ready(wp)) + server_destroy_pane(wp, 1); } |