summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2012-09-25 17:05:36 +0100
committerThomas Adam <thomas@xteddy.org>2012-09-25 17:05:36 +0100
commit48750022c092396e1b9259119fcb9772d6e125f1 (patch)
tree4008645b8d49985039c27316106aa9fed3c36ee9
parentce0b285aad74bae8b7e4d8fff1b63749cf6ddf84 (diff)
parent17bbf90393a5599cfe82becdc5c29a7ad48012c4 (diff)
Merge branch 'obsd-master'
Sync from OpenBSD.
-rw-r--r--control-notify.c29
-rw-r--r--input.c1
-rw-r--r--notify.c20
-rw-r--r--tmux.h3
-rw-r--r--window-copy.c2
5 files changed, 54 insertions, 1 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;
diff --git a/input.c b/input.c
index f4e138be..960a0e6b 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 a173a9f9..bd5c7d83 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)
{
notify_add(NOTIFY_WINDOW_LAYOUT_CHANGED, NULL, NULL, w);
diff --git a/tmux.h b/tmux.h
index 4bfde70e..c18499b1 100644
--- a/tmux.h
+++ b/tmux.h
@@ -1527,6 +1527,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 *);
@@ -2220,6 +2221,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 *);
diff --git a/window-copy.c b/window-copy.c
index 6d18dd42..1284913b 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;