diff options
author | Tiago Cunha <tcunha@gmx.com> | 2009-11-08 22:59:53 +0000 |
---|---|---|
committer | Tiago Cunha <tcunha@gmx.com> | 2009-11-08 22:59:53 +0000 |
commit | cb0bf6a043377974bb40ace3c9782822c63b7ded (patch) | |
tree | 508fe5da78811706ddb354c946d7c703bced4e4a | |
parent | 971a7b2fe0d86c9e41bd0802997d20c61eeed2a3 (diff) | |
download | rtmux-cb0bf6a043377974bb40ace3c9782822c63b7ded.tar.gz rtmux-cb0bf6a043377974bb40ace3c9782822c63b7ded.tar.bz2 rtmux-cb0bf6a043377974bb40ace3c9782822c63b7ded.zip |
Sync OpenBSD patchset 496:
Switch window pane pipe redirect fd over to a bufferevent.
-rw-r--r-- | cmd-pipe-pane.c | 27 | ||||
-rw-r--r-- | server-window.c | 20 | ||||
-rw-r--r-- | tmux.h | 5 | ||||
-rw-r--r-- | window.c | 9 |
4 files changed, 29 insertions, 32 deletions
diff --git a/cmd-pipe-pane.c b/cmd-pipe-pane.c index 3492d083..b33086d3 100644 --- a/cmd-pipe-pane.c +++ b/cmd-pipe-pane.c @@ -1,4 +1,4 @@ -/* $Id: cmd-pipe-pane.c,v 1.4 2009-11-08 22:40:36 tcunha Exp $ */ +/* $Id: cmd-pipe-pane.c,v 1.5 2009-11-08 22:59:53 tcunha Exp $ */ /* * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net> @@ -17,6 +17,7 @@ */ #include <sys/types.h> +#include <sys/socket.h> #include <errno.h> #include <fcntl.h> @@ -31,6 +32,8 @@ int cmd_pipe_pane_exec(struct cmd *, struct cmd_ctx *); +void cmd_pipe_pane_error_callback(struct bufferevent *, short, void *); + const struct cmd_entry cmd_pipe_pane_entry = { "pipe-pane", "pipep", CMD_TARGET_PANE_USAGE "[-o] [command]", @@ -55,7 +58,7 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmd_ctx *ctx) /* Destroy the old pipe. */ old_fd = wp->pipe_fd; if (wp->pipe_fd != -1) { - buffer_destroy(wp->pipe_buf); + bufferevent_free(wp->pipe_event); close(wp->pipe_fd); wp->pipe_fd = -1; } @@ -74,8 +77,8 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmd_ctx *ctx) return (0); /* Open the new pipe. */ - if (pipe(pipe_fd) != 0) { - ctx->error(ctx, "pipe error: %s", strerror(errno)); + if (socketpair(AF_UNIX, SOCK_STREAM, PF_UNSPEC, pipe_fd) != 0) { + ctx->error(ctx, "socketpair error: %s", strerror(errno)); return (-1); } @@ -109,9 +112,12 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmd_ctx *ctx) close(pipe_fd[1]); wp->pipe_fd = pipe_fd[0]; - wp->pipe_buf = buffer_create(BUFSIZ); wp->pipe_off = BUFFER_USED(wp->in); + wp->pipe_event = bufferevent_new(wp->pipe_fd, + NULL, NULL, cmd_pipe_pane_error_callback, wp); + bufferevent_enable(wp->pipe_event, EV_WRITE); + if ((mode = fcntl(wp->pipe_fd, F_GETFL)) == -1) fatal("fcntl failed"); if (fcntl(wp->pipe_fd, F_SETFL, mode|O_NONBLOCK) == -1) @@ -123,3 +129,14 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmd_ctx *ctx) return (0); } + +void +cmd_pipe_pane_error_callback( + unused struct bufferevent *bufev, unused short what, void *data) +{ + struct window_pane *wp = data; + + bufferevent_free(wp->pipe_event); + close(wp->pipe_fd); + wp->pipe_fd = -1; +} diff --git a/server-window.c b/server-window.c index b4ebcf0a..6e2be037 100644 --- a/server-window.c +++ b/server-window.c @@ -1,4 +1,4 @@ -/* $Id: server-window.c,v 1.7 2009-11-08 22:58:37 tcunha Exp $ */ +/* $Id: server-window.c,v 1.8 2009-11-08 22:59:53 tcunha Exp $ */ /* * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net> @@ -55,16 +55,6 @@ server_window_prepare(void) event_set(&wp->event, wp->fd, events, server_window_callback, wp); event_add(&wp->event, NULL); - - if (wp->pipe_fd == -1) - continue; - events = 0; - if (BUFFER_USED(wp->pipe_buf) > 0) - events |= EV_WRITE; - event_del(&wp->pipe_event); - event_set(&wp->pipe_event, - wp->pipe_fd, events, server_window_callback, wp); - event_add(&wp->pipe_event, NULL); } } } @@ -110,14 +100,6 @@ server_window_callback(int fd, short events, void *data) } else window_pane_parse(wp); } - - if (fd == wp->pipe_fd) { - if (buffer_poll(fd, events, NULL, wp->pipe_buf) != 0) { - buffer_destroy(wp->pipe_buf); - close(wp->pipe_fd); - wp->pipe_fd = -1; - } - } } /* Window functions that need to happen every loop. */ @@ -1,4 +1,4 @@ -/* $Id: tmux.h,v 1.499 2009-11-08 22:58:37 tcunha Exp $ */ +/* $Id: tmux.h,v 1.500 2009-11-08 22:59:53 tcunha Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> @@ -804,8 +804,7 @@ struct window_pane { struct input_ctx ictx; int pipe_fd; - struct event pipe_event; - struct buffer *pipe_buf; + struct bufferevent *pipe_event; size_t pipe_off; struct screen *screen; @@ -1,4 +1,4 @@ -/* $Id: window.c,v 1.118 2009-11-08 22:40:36 tcunha Exp $ */ +/* $Id: window.c,v 1.119 2009-11-08 22:59:53 tcunha Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> @@ -424,8 +424,8 @@ window_pane_create(struct window *w, u_int sx, u_int sy, u_int hlimit) wp->sy = sy; wp->pipe_fd = -1; - wp->pipe_buf = NULL; wp->pipe_off = 0; + wp->pipe_event = NULL; wp->saved_grid = NULL; @@ -451,9 +451,8 @@ window_pane_destroy(struct window_pane *wp) grid_destroy(wp->saved_grid); if (wp->pipe_fd != -1) { - buffer_destroy(wp->pipe_buf); close(wp->pipe_fd); - event_del(&wp->pipe_event); + bufferevent_free(wp->pipe_event); } buffer_destroy(wp->in); @@ -646,7 +645,7 @@ window_pane_parse(struct window_pane *wp) new_size = BUFFER_USED(wp->in) - wp->pipe_off; if (wp->pipe_fd != -1 && new_size > 0) - buffer_write(wp->pipe_buf, BUFFER_OUT(wp->in), new_size); + bufferevent_write(wp->pipe_event, BUFFER_OUT(wp->in), new_size); input_parse(wp); |