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:
parent
7d394fc9e9
commit
f272ea88db
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user