summaryrefslogtreecommitdiffstats
path: root/cmd-paste-buffer.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 /cmd-paste-buffer.c
parent39631edb98a542be53fce6f1eeef41880c9a76b4 (diff)
parent47c097cb51da9622180963af5391d142e7d4ade3 (diff)
Merge branch 'obsd-master'
Sync from OpenBSD.
Diffstat (limited to 'cmd-paste-buffer.c')
-rw-r--r--cmd-paste-buffer.c34
1 files changed, 3 insertions, 31 deletions
diff --git a/cmd-paste-buffer.c b/cmd-paste-buffer.c
index ff92783f..4718d85a 100644
--- a/cmd-paste-buffer.c
+++ b/cmd-paste-buffer.c
@@ -30,7 +30,7 @@
enum cmd_retval cmd_paste_buffer_exec(struct cmd *, struct cmd_ctx *);
void cmd_paste_buffer_filter(struct window_pane *,
- const char *, size_t, const char *, int bracket);
+ const char *, size_t, const char *, int);
const struct cmd_entry cmd_paste_buffer_entry = {
"paste-buffer", "pasteb",
@@ -86,9 +86,8 @@ cmd_paste_buffer_exec(struct cmd *self, struct cmd_ctx *ctx)
else
sepstr = "\r";
}
- pflag = args_has(args, 'p') &&
- (wp->screen->mode & MODE_BRACKETPASTE);
- cmd_paste_buffer_filter(wp, pb->data, pb->size, sepstr, pflag);
+ pflag = (wp->screen->mode & MODE_BRACKETPASTE);
+ paste_send_pane(pb, wp, sepstr, args_has(args, 'p') && pflag);
}
/* Delete the buffer if -d. */
@@ -101,30 +100,3 @@ cmd_paste_buffer_exec(struct cmd *self, struct cmd_ctx *ctx)
return (CMD_RETURN_NORMAL);
}
-
-/* Add bytes to a buffer and filter '\n' according to separator. */
-void
-cmd_paste_buffer_filter(struct window_pane *wp,
- const char *data, size_t size, const char *sep, int bracket)
-{
- const char *end = data + size;
- const char *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);
-}