Do not store the mouse position we calculate as the start of a drag back

into the mouse event that later code uses, it has been adjusted and they
should use the original position. GitHub issue 1710.
This commit is contained in:
nicm 2019-05-03 18:42:40 +00:00
parent 84e4652513
commit 4097257bef
4 changed files with 7 additions and 5 deletions

View File

@ -143,7 +143,7 @@ cmd_resize_pane_mouse_update(struct client *c, struct mouse_event *m)
} }
w = wl->window; w = wl->window;
y = m->y; x = m->x; y = m->y + m->oy; x = m->x + m->ox;
if (m->statusat == 0 && y > 0) if (m->statusat == 0 && y > 0)
y--; y--;
else if (m->statusat > 0 && y >= (u_int)m->statusat) else if (m->statusat > 0 && y >= (u_int)m->statusat)

4
cmd.c
View File

@ -484,8 +484,8 @@ cmd_mouse_at(struct window_pane *wp, struct mouse_event *m, u_int *xp,
x = m->lx + m->ox; x = m->lx + m->ox;
y = m->ly + m->oy; y = m->ly + m->oy;
} else { } else {
x = m->x; x = m->x + m->ox;
y = m->y; y = m->y + m->oy;
} }
log_debug("%s: x=%u, y=%u%s", __func__, x, y, last ? " (last)" : ""); log_debug("%s: x=%u, y=%u%s", __func__, x, y, last ? " (last)" : "");

View File

@ -448,6 +448,8 @@ server_client_check_mouse(struct client *c, struct key_event *event)
type = DRAG; type = DRAG;
if (c->tty.mouse_drag_flag) { if (c->tty.mouse_drag_flag) {
x = m->x, y = m->y, b = m->b; x = m->x, y = m->y, b = m->b;
if (x == m->lx && y == m->ly)
return (KEYC_UNKNOWN);
log_debug("drag update at %u,%u", x, y); log_debug("drag update at %u,%u", x, y);
} else { } else {
x = m->lx, y = m->ly, b = m->lb; x = m->lx, y = m->ly, b = m->lb;
@ -555,8 +557,6 @@ have_event:
return (KEYC_UNKNOWN); return (KEYC_UNKNOWN);
px = px + m->ox; px = px + m->ox;
py = py + m->oy; py = py + m->oy;
m->x = x + m->ox;
m->y = y + m->oy;
/* Try the pane borders if not zoomed. */ /* Try the pane borders if not zoomed. */
if (~s->curw->window->flags & WINDOW_ZOOMED) { if (~s->curw->window->flags & WINDOW_ZOOMED) {

View File

@ -3505,6 +3505,8 @@ window_copy_start_drag(struct client *c, struct mouse_event *m)
window_copy_update_cursor(wme, x, y); window_copy_update_cursor(wme, x, y);
window_copy_start_selection(wme); window_copy_start_selection(wme);
window_copy_redraw_screen(wme); window_copy_redraw_screen(wme);
window_copy_drag_update(c, m);
} }
static void static void