diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2009-11-04 20:50:11 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2009-11-04 20:50:11 +0000 |
commit | abf3a5d50ec4003f58f460cc9ab3c00671c920f8 (patch) | |
tree | 214252ffd3ea45a0998d965b5e2736e80100a9a9 /server-window.c | |
parent | f575e39b0a367ae9b8a7cf54ceead865b8885eed (diff) | |
download | rtmux-abf3a5d50ec4003f58f460cc9ab3c00671c920f8.tar.gz rtmux-abf3a5d50ec4003f58f460cc9ab3c00671c920f8.tar.bz2 rtmux-abf3a5d50ec4003f58f460cc9ab3c00671c920f8.zip |
Initial changes to move tmux to libevent.
This moves the client-side loops are pretty much fully over to event-based only
(tmux.c and client.c) but server-side (server.c and friends) treats libevent as
a sort of clever poll, waking up after every event to run various things.
Moving the server stuff over to bufferevents and timers and so on will come
later.
Diffstat (limited to 'server-window.c')
-rw-r--r-- | server-window.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/server-window.c b/server-window.c index 3a74ead8..a6f2bba5 100644 --- a/server-window.c +++ b/server-window.c @@ -18,6 +18,7 @@ #include <sys/types.h> +#include <event.h> #include <unistd.h> #include "tmux.h" @@ -47,19 +48,23 @@ server_window_prepare(void) continue; events = 0; if (!server_window_backoff(wp)) - events |= POLLIN; + events = EV_READ; if (BUFFER_USED(wp->out) > 0) - events |= POLLOUT; - server_poll_add( + events |= EV_WRITE; + event_del(&wp->event); + 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 |= POLLOUT; - server_poll_add( + 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); } } } @@ -90,7 +95,7 @@ server_window_backoff(struct window_pane *wp) /* Process a single window pane event. */ void -server_window_callback(int fd, int events, void *data) +server_window_callback(int fd, short events, void *data) { struct window_pane *wp = data; |