summaryrefslogtreecommitdiffstats
path: root/paste.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2012-11-27 22:24:00 +0000
committerThomas Adam <thomas@xteddy.org>2012-11-27 22:24:00 +0000
commit739a76634c956016c44a89530d8ee9d20c4ed9f0 (patch)
treecda15fec72c5e350fa188359f6d8325a030d092a /paste.c
parent39631edb98a542be53fce6f1eeef41880c9a76b4 (diff)
parent47c097cb51da9622180963af5391d142e7d4ade3 (diff)
Merge branch 'obsd-master'
Sync from OpenBSD.
Diffstat (limited to 'paste.c')
-rw-r--r--paste.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/paste.c b/paste.c
index 78e7d8fa..7cbbbfb3 100644
--- a/paste.c
+++ b/paste.c
@@ -166,3 +166,29 @@ paste_print(struct paste_buffer *pb, size_t width)
return (buf);
}
+
+/* Paste into a window pane, filtering '\n' according to separator. */
+void
+paste_send_pane (struct paste_buffer *pb, struct window_pane *wp,
+ const char *sep, int bracket)
+{
+ const char *data = pb->data, *end = data + pb->size, *lf;
+ size_t seplen;
+
+ if (bracket)
+ bufferevent_write(wp->event, "\033[200~", 6);
+
+ seplen = strlen(sep);
+ while ((lf = memchr(data, '\n', end - data)) != NULL) {
+ if (lf != data)
+ bufferevent_write(wp->event, data, lf - data);
+ bufferevent_write(wp->event, sep, seplen);
+ data = lf + 1;
+ }
+
+ if (end != data)
+ bufferevent_write(wp->event, data, end - data);
+
+ if (bracket)
+ bufferevent_write(wp->event, "\033[201~", 6);
+}