Do not check for mouse events on pane borders when zoomed, based on a

fix from Avi Halachmi.
This commit is contained in:
nicm 2018-09-11 06:37:54 +00:00
parent 1b92afa799
commit bd9133b31d

View File

@ -523,27 +523,34 @@ have_event:
else if (m->statusat > 0 && y >= (u_int)m->statusat) else if (m->statusat > 0 && y >= (u_int)m->statusat)
y = m->statusat - 1; y = m->statusat - 1;
TAILQ_FOREACH(wp, &s->curw->window->panes, entry) { /* Try the pane borders if not zoomed. */
if ((wp->xoff + wp->sx == x && if (~s->curw->window->flags & WINDOW_ZOOMED) {
wp->yoff <= 1 + y && TAILQ_FOREACH(wp, &s->curw->window->panes, entry) {
wp->yoff + wp->sy >= y) || if ((wp->xoff + wp->sx == x &&
(wp->yoff + wp->sy == y && wp->yoff <= 1 + y &&
wp->xoff <= 1 + x && wp->yoff + wp->sy >= y) ||
wp->xoff + wp->sx >= x)) (wp->yoff + wp->sy == y &&
break; wp->xoff <= 1 + x &&
} wp->xoff + wp->sx >= x))
if (wp != NULL) break;
where = BORDER;
else {
wp = window_get_active_at(s->curw->window, x, y);
if (wp != NULL) {
where = PANE;
log_debug("mouse at %u,%u is on pane %%%u",
x, y, wp->id);
} }
if (wp != NULL)
where = BORDER;
} }
/* Otherwise try inside the pane. */
if (where == NOWHERE) {
wp = window_get_active_at(s->curw->window, x, y);
if (wp != NULL)
where = PANE;
}
if (where == NOWHERE) if (where == NOWHERE)
return (KEYC_UNKNOWN); return (KEYC_UNKNOWN);
if (where == PANE)
log_debug("mouse %u,%u on pane %%%u", x, y, wp->id);
else if (where == BORDER)
log_debug("mouse on pane %%%u border", wp->id);
m->wp = wp->id; m->wp = wp->id;
m->w = wp->window->id; m->w = wp->window->id;
} else } else