From b0a88ebeadd56ebcb0cdbe9967a869d361b96c6f Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Wed, 4 May 2011 18:10:28 +0000 Subject: [PATCH] Change window with mouse wheel over status line if mouse-select-window is on, from marcel partap. --- server-client.c | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/server-client.c b/server-client.c index 454859e6..f21f9c36 100644 --- a/server-client.c +++ b/server-client.c @@ -325,11 +325,24 @@ server_client_handle_key(int key, struct mouse_event *mouse, void *data) server_redraw_window_borders(w); wp = w->active; } - if (mouse->y + 1 == c->tty.sy && mouse->b == MOUSE_UP && + if (mouse->y + 1 == c->tty.sy && options_get_number(oo, "mouse-select-window") && options_get_number(oo, "status")) { - status_set_window_at(c, mouse->x); - return; + if (mouse->b == MOUSE_UP) { + status_set_window_at(c, mouse->x); + return; + } + if (mouse->b & MOUSE_45) { + if ((mouse->b & MOUSE_BUTTON) == MOUSE_1) { + session_previous(c->session, 0); + server_redraw_session(s); + } + if ((mouse->b & MOUSE_BUTTON) == MOUSE_2) { + session_next(c->session, 0); + server_redraw_session(s); + } + return; + } } window_pane_mouse(wp, c->session, mouse); return;