1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 01:48:00 +00:00

Enable xterm mouse reporting of wheel actions in GTK.

I had somehow missed this completely out of the GTK mouse-button
handling and never noticed until now!

Of course, like any other mouse action, if you want it to be handled
locally rather than passed through then you can hold down Shift.

[originally from svn r10139]
This commit is contained in:
Simon Tatham 2014-02-16 16:40:46 +00:00
parent 7d394fc9e9
commit f272ea88db

View File

@ -1234,26 +1234,32 @@ gboolean button_internal(struct gui_data *inst, guint32 timestamp,
GdkEventType type, guint ebutton, guint state, GdkEventType type, guint ebutton, guint state,
gdouble ex, gdouble ey) gdouble ex, gdouble ey)
{ {
int shift, ctrl, alt, x, y, button, act; int shift, ctrl, alt, x, y, button, act, raw_mouse_mode;
/* Remember the timestamp. */ /* Remember the timestamp. */
inst->input_event_time = timestamp; inst->input_event_time = timestamp;
show_mouseptr(inst, 1); show_mouseptr(inst, 1);
if (ebutton == 4 && type == GDK_BUTTON_PRESS) {
term_scroll(inst->term, 0, -5);
return TRUE;
}
if (ebutton == 5 && type == GDK_BUTTON_PRESS) {
term_scroll(inst->term, 0, +5);
return TRUE;
}
shift = state & GDK_SHIFT_MASK; shift = state & GDK_SHIFT_MASK;
ctrl = state & GDK_CONTROL_MASK; ctrl = state & GDK_CONTROL_MASK;
alt = state & GDK_MOD1_MASK; alt = state & GDK_MOD1_MASK;
raw_mouse_mode =
send_raw_mouse && !(shift && conf_get_int(inst->conf,
CONF_mouse_override));
if (!raw_mouse_mode) {
if (ebutton == 4 && type == GDK_BUTTON_PRESS) {
term_scroll(inst->term, 0, -5);
return TRUE;
}
if (ebutton == 5 && type == GDK_BUTTON_PRESS) {
term_scroll(inst->term, 0, +5);
return TRUE;
}
}
if (ebutton == 3 && ctrl) { if (ebutton == 3 && ctrl) {
gtk_menu_popup(GTK_MENU(inst->menu), NULL, NULL, NULL, NULL, gtk_menu_popup(GTK_MENU(inst->menu), NULL, NULL, NULL, NULL,
ebutton, timestamp); ebutton, timestamp);
@ -1266,6 +1272,10 @@ gboolean button_internal(struct gui_data *inst, guint32 timestamp,
button = MBT_MIDDLE; button = MBT_MIDDLE;
else if (ebutton == 3) else if (ebutton == 3)
button = MBT_RIGHT; button = MBT_RIGHT;
else if (ebutton == 4)
button = MBT_WHEEL_UP;
else if (ebutton == 5)
button = MBT_WHEEL_DOWN;
else else
return FALSE; /* don't even know what button! */ return FALSE; /* don't even know what button! */
@ -1277,9 +1287,7 @@ gboolean button_internal(struct gui_data *inst, guint32 timestamp,
default: return FALSE; /* don't know this event type */ default: return FALSE; /* don't know this event type */
} }
if (send_raw_mouse && !(shift && conf_get_int(inst->conf, if (raw_mouse_mode && act != MA_CLICK && act != MA_RELEASE)
CONF_mouse_override)) &&
act != MA_CLICK && act != MA_RELEASE)
return TRUE; /* we ignore these in raw mouse mode */ return TRUE; /* we ignore these in raw mouse mode */
x = (ex - inst->window_border) / inst->font_width; x = (ex - inst->window_border) / inst->font_width;