Fix two copy/paste bugs: forbid zero-length buffers to prevent a fatal error

when trying to paste them, found by me, and miscalculation of the start/end
causing random fatal errors when copying in copy-mode, reported by sthen.

ok sthen "put it in" deraadt
This commit is contained in:
Nicholas Marriott 2009-07-02 16:15:43 +00:00
parent 4c5c125173
commit fe5edad1fc
3 changed files with 5 additions and 2 deletions

View File

@ -63,7 +63,7 @@ cmd_paste_buffer_exec(struct cmd *self, struct cmd_ctx *ctx)
} }
} }
if (pb != NULL) if (pb != NULL && *pb->data != '\0')
buffer_write(w->active->out, pb->data, strlen(pb->data)); buffer_write(w->active->out, pb->data, strlen(pb->data));
/* Delete the buffer if -d. */ /* Delete the buffer if -d. */

View File

@ -101,6 +101,9 @@ paste_add(struct paste_stack *ps, char *data, u_int limit)
{ {
struct paste_buffer *pb; struct paste_buffer *pb;
if (*data == '\0')
return;
while (ARRAY_LENGTH(ps) >= limit) while (ARRAY_LENGTH(ps) >= limit)
ARRAY_TRUNC(ps, 1); ARRAY_TRUNC(ps, 1);

View File

@ -423,7 +423,7 @@ window_copy_copy_selection(struct window_pane *wp, struct client *c)
/* Find start and end. */ /* Find start and end. */
xx = data->cx + data->ox; xx = data->cx + data->ox;
yy = screen_hsize(&wp->base) + data->cy - data->oy; yy = screen_hsize(&wp->base) + data->cy - data->oy;
if (xx < data->selx || (yy == data->sely && xx < data->selx)) { if (yy < data->sely || (yy == data->sely && xx < data->selx)) {
sx = xx; sy = yy; sx = xx; sy = yy;
ex = data->selx; ey = data->sely; ex = data->selx; ey = data->sely;
} else { } else {