summaryrefslogtreecommitdiff
path: root/usr.bin/tmux/screen-write.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2017-11-02 21:29:18 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2017-11-02 21:29:18 +0000
commitf568348413f21ed85b72756035d630767e7d81ab (patch)
treed08cc07f3534f5441cab7d171ca2d488239c16e1 /usr.bin/tmux/screen-write.c
parent45ececc62b3e881ea76a09e9a305a470b5e8dedd (diff)
Add a "fast" version of screen_write_copy for tree mode that doesn't do
all the checks and selection and marking stuff needed for copy mode.
Diffstat (limited to 'usr.bin/tmux/screen-write.c')
-rw-r--r--usr.bin/tmux/screen-write.c57
1 files changed, 44 insertions, 13 deletions
diff --git a/usr.bin/tmux/screen-write.c b/usr.bin/tmux/screen-write.c
index 93489c9b9e3..a566ac40388 100644
--- a/usr.bin/tmux/screen-write.c
+++ b/usr.bin/tmux/screen-write.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: screen-write.c,v 1.131 2017/10/05 08:12:24 nicm Exp $ */
+/* $OpenBSD: screen-write.c,v 1.132 2017/11/02 21:29:17 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com>
@@ -351,11 +351,10 @@ screen_write_cnputs(struct screen_write_ctx *ctx, ssize_t maxlen,
free(msg);
}
-/* Copy from another screen. */
+/* Copy from another screen. Assumes target region is big enough. */
void
screen_write_copy(struct screen_write_ctx *ctx, struct screen *src, u_int px,
- u_int py, u_int nx, u_int ny, bitstr_t *markbs,
- const struct grid_cell *markgc)
+ u_int py, u_int nx, u_int ny, bitstr_t *mbs, const struct grid_cell *mgc)
{
struct screen *s = ctx->s;
struct grid *gd = src->grid;
@@ -371,22 +370,52 @@ screen_write_copy(struct screen_write_ctx *ctx, struct screen *src, u_int px,
for (yy = py; yy < py + ny; yy++) {
for (xx = px; xx < px + nx; xx++) {
grid_get_cell(gd, xx, yy, &gc);
- if (markbs != NULL) {
+ if (mbs != NULL) {
b = (yy * screen_size_x(src)) + xx;
- if (bit_test(markbs, b)) {
- gc.attr = markgc->attr;
- gc.fg = markgc->fg;
- gc.bg = markgc->bg;
+ if (bit_test(mbs, b)) {
+ gc.attr = mgc->attr;
+ gc.fg = mgc->fg;
+ gc.bg = mgc->bg;
}
}
screen_write_cell(ctx, &gc);
}
-
cy++;
screen_write_cursormove(ctx, cx, cy);
}
}
+/*
+ * Copy from another screen but without the selection stuff. Also assumes the
+ * target region is already big enough and already cleared.
+ */
+void
+screen_write_fast_copy(struct screen_write_ctx *ctx, struct screen *src,
+ u_int px, u_int py, u_int nx, u_int ny)
+{
+ struct screen *s = ctx->s;
+ struct grid *gd = src->grid;
+ struct grid_cell gc;
+ u_int xx, yy, cx, cy;
+
+ if (nx == 0 || ny == 0)
+ return;
+
+ cy = s->cy;
+ for (yy = py; yy < py + ny; yy++) {
+ cx = s->cx;
+ for (xx = px; xx < px + nx; xx++) {
+ if (xx >= gd->linedata[yy].cellsize)
+ break;
+ grid_get_cell(gd, xx, yy, &gc);
+ if (!grid_cells_equal(&gc, &grid_default_cell))
+ grid_view_set_cell(ctx->s->grid, cx, cy, &gc);
+ cx++;
+ }
+ cy++;
+ }
+}
+
/* Draw a horizontal line on screen. */
void
screen_write_hline(struct screen_write_ctx *ctx, u_int nx, int left, int right)
@@ -471,7 +500,10 @@ screen_write_box(struct screen_write_ctx *ctx, u_int nx, u_int ny)
screen_write_cursormove(ctx, cx, cy);
}
-/* Write a preview version of a window. */
+/*
+ * Write a preview version of a window. Assumes target area is big enough and
+ * already cleared.
+ */
void
screen_write_preview(struct screen_write_ctx *ctx, struct screen *src, u_int nx,
u_int ny)
@@ -515,8 +547,7 @@ screen_write_preview(struct screen_write_ctx *ctx, struct screen *src, u_int nx,
py = 0;
}
- screen_write_copy(ctx, src, px, src->grid->hsize + py, nx, ny, NULL,
- NULL);
+ screen_write_fast_copy(ctx, src, px, src->grid->hsize + py, nx, ny);
if (src->mode & MODE_CURSOR) {
grid_view_get_cell(src->grid, src->cx, src->cy, &gc);