diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2012-09-25 07:41:22 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2012-09-25 07:41:22 +0000 |
commit | 17bbf90393a5599cfe82becdc5c29a7ad48012c4 (patch) | |
tree | 717f98054941d6ab55195c37db5ffe96ae636fdb | |
parent | 0d0b3cf9a42f7d9cae2a1c150698a6ed9d9634cf (diff) | |
download | rtmux-17bbf90393a5599cfe82becdc5c29a7ad48012c4.tar.gz rtmux-17bbf90393a5599cfe82becdc5c29a7ad48012c4.tar.bz2 rtmux-17bbf90393a5599cfe82becdc5c29a7ad48012c4.zip |
Add notification for input from a pane, from George Nachman.
-rw-r--r-- | control-notify.c | 29 | ||||
-rw-r--r-- | input.c | 1 | ||||
-rw-r--r-- | notify.c | 20 | ||||
-rw-r--r-- | tmux.h | 3 |
4 files changed, 53 insertions, 0 deletions
diff --git a/control-notify.c b/control-notify.c index 254f1f58..87a25bb1 100644 --- a/control-notify.c +++ b/control-notify.c @@ -25,6 +25,35 @@ ((c) != NULL && ((c)->flags & CLIENT_CONTROL)) void +control_notify_input(struct client *c, struct window_pane *wp, + struct evbuffer *input) +{ + u_char *buf; + size_t len; + struct evbuffer *message; + u_int i; + + if (c->session == NULL) + return; + + buf = EVBUFFER_DATA(input); + len = EVBUFFER_LENGTH(input); + + /* + * Only write input if the window pane is linked to a window belonging + * to the client's session. + */ + if (winlink_find_by_window(&c->session->windows, wp->window) != NULL) { + message = evbuffer_new(); + evbuffer_add_printf(message, "%%output %%%u ", wp->id); + for (i = 0; i < len; i++) + evbuffer_add_printf(message, "%02hhx", buf[i]); + control_write_buffer(c, message); + evbuffer_free(message); + } +} + +void control_notify_window_layout_changed(struct window *w) { struct client *c; @@ -752,6 +752,7 @@ input_parse(struct window_pane *wp) buf = EVBUFFER_DATA(evb); len = EVBUFFER_LENGTH(evb); + notify_input(wp, evb); off = 0; /* Parse the input. */ @@ -133,6 +133,26 @@ notify_drain(void) } void +notify_input(struct window_pane *wp, struct evbuffer *input) +{ + struct client *c; + u_int i; + + /* + * notify_input() is not queued and only does anything when + * notifications are enabled. + */ + if (!notify_enabled) + return; + + for (i = 0; i < ARRAY_LENGTH(&clients); i++) { + c = ARRAY_ITEM(&clients, i); + if (c != NULL && (c->flags & CLIENT_CONTROL)) + control_notify_input(c, wp, input); + } +} + +void notify_window_layout_changed(struct window *w) { notify_add(NOTIFY_WINDOW_LAYOUT_CHANGED, NULL, NULL, w); @@ -1531,6 +1531,7 @@ enum mode_key_cmd mode_key_lookup(struct mode_key_data *, int); /* notify.c */ void notify_enable(void); void notify_disable(void); +void notify_input(struct window_pane *, struct evbuffer *); void notify_window_layout_changed(struct window *); void notify_window_unlinked(struct session *, struct window *); void notify_window_linked(struct session *, struct window *); @@ -2224,6 +2225,8 @@ void printflike2 control_write(struct client *, const char *, ...); void control_write_buffer(struct client *, struct evbuffer *); /* control-notify.c */ +void control_notify_input(struct client *, struct window_pane *, + struct evbuffer *); void control_notify_window_layout_changed(struct window *); void control_notify_window_unlinked(struct session *, struct window *); void control_notify_window_linked(struct session *, struct window *); |