Skip to content

Commit

Permalink
wl: Fix mouse button indices
Browse files Browse the repository at this point in the history
Handle the first five pointer buttons by checking their exact
button codes. Their values are used directly to avoid the need
for <linux/input-event-codes.h> to be present at build time.
  • Loading branch information
aperezdc committed Apr 2, 2024
1 parent 95cf333 commit 0666394
Showing 1 changed file with 26 additions and 10 deletions.
36 changes: 26 additions & 10 deletions platform/wayland/cog-platform-wl.c
Original file line number Diff line number Diff line change
Expand Up @@ -345,18 +345,33 @@ pointer_on_button(void *data,
return;
}

CogWlPlatform *platform = (CogWlPlatform *) cog_platform_get();
/*
* Button codes taken from <linux/input-event-codes.h>.
*/
switch (button) {
case /* BTN_LEFT */ 0x110:
seat->pointer.button = 0;
break;
case /* BTN_MIDDLE */ 0x112:
seat->pointer.button = 1;
break;
case /* BTN_RIGHT */ 0x111:
seat->pointer.button = 2;
break;
case /* BTN_BACK */ 0x116:
case /* BTN_EXTRA */ 0x113:
seat->pointer.button = 3;
break;
case /* BTN_FORWARD */ 0x115:
case /* BTN_SIDE */ 0x114:
seat->pointer.button = 4;
break;
default:
g_debug("%s: Unhandled button %#" PRIx32 " in pointer %p, ignored.", G_STRFUNC, button, pointer);
return;
}

seat->pointer.serial = serial;

/* @FIXME: what is this for?
if (button >= BTN_MOUSE)
button = button - BTN_MOUSE + 1;
else
button = 0;
*/

seat->pointer.button = !!state ? button : 0;
seat->pointer.state = state;

struct wpe_input_pointer_event event = {
Expand All @@ -368,6 +383,7 @@ pointer_on_button(void *data,
seat->pointer.state,
};

CogWlPlatform *platform = (CogWlPlatform *) cog_platform_get();
CogWlPopup *popup = platform->popup;
if (popup && popup->wl_surface) {
if (seat->pointer.surface == popup->wl_surface) {
Expand Down

0 comments on commit 0666394

Please sign in to comment.