mirror of
https://github.com/tmux/tmux.git
synced 2025-01-05 23:38:48 +00:00
Cache selected state so that cells going from selected to unselected are not
skipped, reported by Omar Sandoval.
This commit is contained in:
parent
00cf5fbde6
commit
aba4438013
@ -989,8 +989,19 @@ screen_write_cell(struct screen_write_ctx *ctx, const struct grid_cell *gc)
|
||||
if (skip)
|
||||
skip = (memcmp(&now_gc, gc, sizeof now_gc) == 0);
|
||||
|
||||
/* Set the cell. */
|
||||
if (!skip)
|
||||
/* Update the selection the flag and set the cell. */
|
||||
selected = screen_check_selection(s, s->cx, s->cy);
|
||||
if (selected && ~gc->flags & GRID_FLAG_SELECTED) {
|
||||
skip = 0;
|
||||
memcpy(&tmp_gc, gc, sizeof tmp_gc);
|
||||
tmp_gc.flags |= GRID_FLAG_SELECTED;
|
||||
grid_view_set_cell(gd, s->cx, s->cy, &tmp_gc);
|
||||
} else if (!selected && gc->flags & GRID_FLAG_SELECTED) {
|
||||
skip = 0;
|
||||
memcpy(&tmp_gc, gc, sizeof tmp_gc);
|
||||
tmp_gc.flags &= ~GRID_FLAG_SELECTED;
|
||||
grid_view_set_cell(gd, s->cx, s->cy, &tmp_gc);
|
||||
} else if (!skip)
|
||||
grid_view_set_cell(gd, s->cx, s->cy, gc);
|
||||
|
||||
/*
|
||||
@ -1009,11 +1020,6 @@ screen_write_cell(struct screen_write_ctx *ctx, const struct grid_cell *gc)
|
||||
tty_write(tty_cmd_insertcharacter, &ttyctx);
|
||||
}
|
||||
|
||||
/* Check if this is selected. */
|
||||
selected = screen_check_selection(s, s->cx - width, s->cy);
|
||||
if (selected)
|
||||
skip = 0;
|
||||
|
||||
/* Save last cell if it will be needed. */
|
||||
if (!skip && ctx->wp != NULL && ttyctx.ocx > ctx->wp->sx - width)
|
||||
screen_write_save_last(ctx, &ttyctx);
|
||||
|
Loading…
Reference in New Issue
Block a user