From 0d0b3cf9a42f7d9cae2a1c150698a6ed9d9634cf Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Tue, 25 Sep 2012 07:39:28 +0000 Subject: [PATCH 1/2] Fix search forward so it can match strings on the last line, SF bug 3571114 from "LiJunLe". --- window-copy.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/window-copy.c b/window-copy.c index 2c10861a..bed645f0 100644 --- a/window-copy.c +++ b/window-copy.c @@ -1068,7 +1068,7 @@ window_copy_search_down(struct window_pane *wp, const char *searchstr) retry: sgd = ss.grid; - for (i = fy + 1; i < gd->hsize + gd->sy; i++) { + for (i = fy + 1; i < gd->hsize + gd->sy + 1; i++) { first = 0; if (i == fy + 1) first = fx; From 17bbf90393a5599cfe82becdc5c29a7ad48012c4 Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Tue, 25 Sep 2012 07:41:22 +0000 Subject: [PATCH 2/2] Add notification for input from a pane, from George Nachman. --- control-notify.c | 29 +++++++++++++++++++++++++++++ input.c | 1 + notify.c | 20 ++++++++++++++++++++ tmux.h | 3 +++ 4 files changed, 53 insertions(+) diff --git a/control-notify.c b/control-notify.c index 254f1f58..87a25bb1 100644 --- a/control-notify.c +++ b/control-notify.c @@ -24,6 +24,35 @@ #define CONTROL_SHOULD_NOTIFY_CLIENT(c) \ ((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) { diff --git a/input.c b/input.c index 7a9f0e48..bc4af1f7 100644 --- a/input.c +++ b/input.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. */ diff --git a/notify.c b/notify.c index 8fe792c1..75a16de9 100644 --- a/notify.c +++ b/notify.c @@ -132,6 +132,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) { diff --git a/tmux.h b/tmux.h index b1e1eeeb..1fbad94b 100644 --- a/tmux.h +++ b/tmux.h @@ -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 *);