diff options
author | Thomas Adam <thomas@xteddy.org> | 2012-11-27 22:24:00 +0000 |
---|---|---|
committer | Thomas Adam <thomas@xteddy.org> | 2012-11-27 22:24:00 +0000 |
commit | 739a76634c956016c44a89530d8ee9d20c4ed9f0 (patch) | |
tree | cda15fec72c5e350fa188359f6d8325a030d092a /paste.c | |
parent | 39631edb98a542be53fce6f1eeef41880c9a76b4 (diff) | |
parent | 47c097cb51da9622180963af5391d142e7d4ade3 (diff) | |
download | rtmux-739a76634c956016c44a89530d8ee9d20c4ed9f0.tar.gz rtmux-739a76634c956016c44a89530d8ee9d20c4ed9f0.tar.bz2 rtmux-739a76634c956016c44a89530d8ee9d20c4ed9f0.zip |
Merge branch 'obsd-master'
Sync from OpenBSD.
Diffstat (limited to 'paste.c')
-rw-r--r-- | paste.c | 26 |
1 files changed, 26 insertions, 0 deletions
@@ -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); +} |