aboutsummaryrefslogtreecommitdiff
path: root/window-copy.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2014-12-19 19:20:09 +0000
committerThomas Adam <thomas@xteddy.org>2014-12-19 19:22:19 +0000
commit5f8138faf551c3678de3c92c5764e2e7edfc4602 (patch)
tree6646056b5b2bab330ec6ec62400004548dc0aa18 /window-copy.c
parentccbe2545d9857e03731eddb9757989b9f52dc785 (diff)
parent160e3e2be3543377925551146403933a7c631f51 (diff)
downloadrtmux-5f8138faf551c3678de3c92c5764e2e7edfc4602.tar.gz
rtmux-5f8138faf551c3678de3c92c5764e2e7edfc4602.tar.bz2
rtmux-5f8138faf551c3678de3c92c5764e2e7edfc4602.zip
Merge branch 'obsd-master'
Conflicts: format.c
Diffstat (limited to 'window-copy.c')
-rw-r--r--window-copy.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/window-copy.c b/window-copy.c
index f5973322..8aae09be 100644
--- a/window-copy.c
+++ b/window-copy.c
@@ -33,6 +33,7 @@ int window_copy_key_numeric_prefix(struct window_pane *, int);
void window_copy_mouse(struct window_pane *, struct session *,
struct mouse_event *);
+void window_copy_redraw_selection(struct window_pane *, u_int);
void window_copy_redraw_lines(struct window_pane *, u_int, u_int);
void window_copy_redraw_screen(struct window_pane *);
void window_copy_write_line(struct window_pane *, struct screen_write_ctx *,
@@ -874,7 +875,7 @@ window_copy_mouse(struct window_pane *wp, struct session *sess,
{
struct window_copy_mode_data *data = wp->modedata;
struct screen *s = &data->screen;
- u_int i;
+ u_int i, old_cy;
if (m->x >= screen_size_x(s))
return;
@@ -907,9 +908,10 @@ window_copy_mouse(struct window_pane *wp, struct session *sess,
*/
if (s->mode & MODE_MOUSE_BUTTON) {
if (~m->event & MOUSE_EVENT_UP) {
+ old_cy = data->cy;
window_copy_update_cursor(wp, m->x, m->y);
if (window_copy_update_selection(wp, 1))
- window_copy_redraw_screen(wp);
+ window_copy_redraw_selection(wp, old_cy);
return;
}
goto reset_mode;
@@ -1246,6 +1248,23 @@ window_copy_write_lines(struct window_pane *wp, struct screen_write_ctx *ctx,
}
void
+window_copy_redraw_selection(struct window_pane *wp, u_int old_y)
+{
+ struct window_copy_mode_data *data = wp->modedata;
+ u_int new_y, start, end;
+
+ new_y = data->cy;
+ if (old_y <= new_y) {
+ start = old_y;
+ end = new_y;
+ } else {
+ start = new_y;
+ end = old_y;
+ }
+ window_copy_redraw_lines(wp, start, end - start + 1);
+}
+
+void
window_copy_redraw_lines(struct window_pane *wp, u_int py, u_int ny)
{
struct window_copy_mode_data *data = wp->modedata;