From ffa8a602e7ae20c7430090360818d635f13b392d Mon Sep 17 00:00:00 2001 From: Peter Hutterer Date: Wed, 11 Mar 2009 14:20:05 +1000 Subject: Add support for XI2 Enter/Leave events --- include/X11/extensions/XInput2.h | 27 +++++++++++++++++++++ src/XExtInt.c | 51 ++++++++++++++++++++++++++++++++++++++++ src/XIFreeEvent.c | 6 +++++ 3 files changed, 84 insertions(+) diff --git a/include/X11/extensions/XInput2.h b/include/X11/extensions/XInput2.h index 11f335c..cdfd0a5 100644 --- a/include/X11/extensions/XInput2.h +++ b/include/X11/extensions/XInput2.h @@ -234,6 +234,33 @@ typedef struct { double *raw_values; } XIRawDeviceEvent; +typedef struct { + int type; /* GenericEvent */ + unsigned long serial; /* # of last request processed by server */ + Bool send_event; /* true if this came from a SendEvent request */ + Display *display; /* Display the event was read from */ + int extension; /* XI extension offset */ + int evtype; + Time time; + int detail; + Window root; + Window event; + Window child; + int deviceid; + int sourceid; + float root_x; + float root_y; + float event_x; + float event_y; + int mode; + Bool focus; + Bool same_screen; + XIButtonState *buttons; + XIModifierState *mods; + XIGroupState *group; +} XIEnterEvent; + +typedef XIEnterEvent XILeaveEvent; _XFUNCPROTOBEGIN diff --git a/src/XExtInt.c b/src/XExtInt.c index 8022c26..02a4665 100644 --- a/src/XExtInt.c +++ b/src/XExtInt.c @@ -132,6 +132,8 @@ static int wireToHierarchyChangedEvent(xXIDeviceHierarchyEvent *in, XIDeviceHierarchyEvent* out); static int wireToRawEvent(xXIRawDeviceEvent *in, XIRawDeviceEvent *out); +static int +wireToEnterLeave(xXIEnterEvent *in, XIEnterEvent *out); static /* const */ XEvent emptyevent; @@ -829,6 +831,16 @@ XInputWireToEvent( break; } return ENQUEUE_EVENT; + case XI_Enter: + case XI_Leave: + *re = *save; + if (!wireToEnterLeave(event, re)) + { + printf("XInputWireToEvent: CONVERSION FAILURE! evtype=%d\n", + ge->evtype); + break; + } + return ENQUEUE_EVENT; default: printf("XInputWireToEvent: Unknown generic event. type %d\n", ge->evtype); @@ -998,3 +1010,42 @@ wireToRawEvent(xXIRawDeviceEvent *in, XIRawDeviceEvent *out) return 1; } + +static int +wireToEnterLeave(xXIEnterEvent *in, XIEnterEvent *out) +{ + out->type = in->type; + out->extension = in->extension; + out->evtype = in->evtype; + out->time = in->time; + out->detail = in->detail; + out->deviceid = in->deviceid; + out->root = in->root; + out->event = in->event; + out->child = in->child; + out->sourceid = in->sourceid; + out->root_x = in->root_x.integral; + out->root_y = in->root_y.integral; + out->event_x = in->event_x.integral; + out->event_y = in->event_y.integral; + out->mode = in->mode; + out->focus = in->focus; + out->same_screen = in->same_screen; + + out->mods = malloc(sizeof(XIModifierState)); + out->group = malloc(sizeof(XIGroupState)); + + out->mods->base = in->mods.base_mods; + out->mods->locked = in->mods.locked_mods; + out->mods->latched = in->mods.latched_mods; + out->group->base = in->group.base_group; + out->group->locked = in->group.locked_group; + out->group->latched = in->group.latched_group; + + out->buttons = malloc(sizeof(XIButtonState) + in->buttons_len * 4); + out->buttons->mask = (unsigned char*)&out->buttons[1]; + out->buttons->mask_len = in->buttons_len; + memcpy(out->buttons->mask, &in[1], out->buttons->mask_len); + + return 1; +} diff --git a/src/XIFreeEvent.c b/src/XIFreeEvent.c index 0c80602..e7ff229 100644 --- a/src/XIFreeEvent.c +++ b/src/XIFreeEvent.c @@ -60,5 +60,11 @@ XIFreeEventData(XIEvent *event) free(((XIRawDeviceEvent*)event)->valuators); free(((XIRawDeviceEvent*)event)->raw_values); break; + case XI_Enter: + case XI_Leave: + free(((XIEnterEvent*)event)->mods); + free(((XIEnterEvent*)event)->group); + free(((XIEnterEvent*)event)->buttons); + break; } } -- cgit v1.2.3