From 75595ba4aa9c3823ffe3b3388ce088929824816f Mon Sep 17 00:00:00 2001 From: Peter Hutterer Date: Fri, 30 Jan 2009 15:14:46 +1000 Subject: [PATCH] Xi: make ProcessOtherEvents more InternalEvent aware. Get rid of the deviceValuator processing and a few other things, but still drop back into XI before checking device grabs or doing anything else. NoticeEventTime now needs to take InternalEvents, and while we're at it, change NoticeTime from a macro to a function. Signed-off-by: Peter Hutterer --- Xi/exevents.c | 105 ++++++++++++++++++++++++++------------------------ dix/events.c | 29 +++++++------- include/dix.h | 2 +- 3 files changed, 72 insertions(+), 64 deletions(-) diff --git a/Xi/exevents.c b/Xi/exevents.c index bedafe362..9996a04be 100644 --- a/Xi/exevents.c +++ b/Xi/exevents.c @@ -890,14 +890,12 @@ UpdateDeviceState(DeviceIntPtr device, DeviceEvent* event) void ProcessOtherEvent(xEventPtr ev, DeviceIntPtr device, int count) { - int i; GrabPtr grab = device->deviceGrab.grab; Bool deactivateDeviceGrab = FALSE; int key = 0, rootX, rootY; ButtonClassPtr b; KeyClassPtr k; ValuatorClassPtr v; - deviceValuator *xV; int ret = 0; int state; DeviceIntPtr mouse = NULL, kbd = NULL; @@ -938,18 +936,27 @@ ProcessOtherEvent(xEventPtr ev, DeviceIntPtr device, int count) if (device->isMaster || !device->u.master) CheckMotion(event, device); + + switch (event->type) + { + case ET_Motion: + case ET_ButtonPress: + case ET_ButtonRelease: + case ET_KeyPress: + case ET_KeyRelease: + case ET_ProximityIn: + case ET_ProximityOut: + GetSpritePosition(device, &rootX, &rootY); + event->root_x = rootX; + event->root_y = rootY; + NoticeEventTime((InternalEvent*)event); + event->corestate = state; + key = event->detail.key; + break; + } + nevents = ConvertBackToXI((InternalEvent*)ev, xE); - if (xE->u.u.type != DeviceValuator && xE->u.u.type != GenericEvent) { - GetSpritePosition(device, &rootX, &rootY); - xE->u.keyButtonPointer.rootX = rootX; - xE->u.keyButtonPointer.rootY = rootY; - NoticeEventTime(xE); - - xE->u.keyButtonPointer.state = state; - - key = xE->u.u.detail; - } if (DeviceEventCallback) { DeviceEventInfoRec eventinfo; @@ -958,43 +965,41 @@ ProcessOtherEvent(xEventPtr ev, DeviceIntPtr device, int count) CallCallbacks(&DeviceEventCallback, (pointer) & eventinfo); } - /* Valuator event handling */ - xV = (deviceValuator*)xE; - for (i = 1; i < count; i++) { - if ((++xV)->type == DeviceValuator) - xV->device_state = state; - } - - if (xE->u.u.type == DeviceKeyPress) { - if (!grab && CheckDeviceGrabs(device, xE, 0, count)) { - device->deviceGrab.activatingKey = key; - return; - } - } else if (xE->u.u.type == DeviceKeyRelease) { - if (device->deviceGrab.fromPassiveGrab && - (key == device->deviceGrab.activatingKey)) - deactivateDeviceGrab = TRUE; - } else if (xE->u.u.type == DeviceButtonPress) { - xE->u.u.detail = b->map[key]; - if (xE->u.u.detail == 0) { - xE->u.u.detail = key; - return; - } - if (!grab && CheckDeviceGrabs(device, xE, 0, count)) - { - /* if a passive grab was activated, the event has been sent - * already */ - return; - } - - } else if (xE->u.u.type == DeviceButtonRelease) { - xE->u.u.detail = b->map[key]; - if (xE->u.u.detail == 0) { - xE->u.u.detail = key; - return; - } - if (!b->buttonsDown && device->deviceGrab.fromPassiveGrab) - deactivateDeviceGrab = TRUE; + switch(event->type) + { + case ET_KeyPress: + if (!grab && CheckDeviceGrabs(device, xE, 0, nevents)) { + device->deviceGrab.activatingKey = key; + return; + } + break; + case ET_KeyRelease: + if (device->deviceGrab.fromPassiveGrab && + (key == device->deviceGrab.activatingKey)) + deactivateDeviceGrab = TRUE; + break; + case ET_ButtonPress: + event->detail.button = b->map[key]; + if (!event->detail.button) { /* there's no button 0 */ + event->detail.button = key; + xE->u.u.detail = key; /* XXX: temporary */ + return; + } + if (!grab && CheckDeviceGrabs(device, xE, 0, nevents)) + { + /* if a passive grab was activated, the event has been sent + * already */ + return; + } + case ET_ButtonRelease: + event->detail.button = b->map[key]; + if (!event->detail.button) { /* there's no button 0 */ + event->detail.button = key; + xE->u.u.detail = key; /* XXX: temporary */ + return; + } + if (!b->buttonsDown && device->deviceGrab.fromPassiveGrab) + deactivateDeviceGrab = TRUE; } if (grab) @@ -1007,7 +1012,7 @@ ProcessOtherEvent(xEventPtr ev, DeviceIntPtr device, int count) if (deactivateDeviceGrab == TRUE) (*device->deviceGrab.DeactivateGrab) (device); - xE->u.u.detail = key; + event->detail.key = key; } int diff --git a/dix/events.c b/dix/events.c index 8d5349050..a09085b7b 100644 --- a/dix/events.c +++ b/dix/events.c @@ -974,29 +974,32 @@ XineramaGetCursorScreen(DeviceIntPtr pDev) #define TIMESLOP (5 * 60 * 1000) /* 5 minutes */ static void -MonthChangedOrBadTime(xEvent *xE) +MonthChangedOrBadTime(InternalEvent *ev) { /* If the ddx/OS is careless about not processing timestamped events from * different sources in sorted order, then it's possible for time to go * backwards when it should not. Here we ensure a decent time. */ - if ((currentTime.milliseconds - XE_KBPTR.time) > TIMESLOP) + if ((currentTime.milliseconds - ev->u.any.time) > TIMESLOP) currentTime.months++; else - XE_KBPTR.time = currentTime.milliseconds; + ev->u.any.time = currentTime.milliseconds; } -#define NoticeTime(xE) { \ - if ((xE)->u.keyButtonPointer.time < currentTime.milliseconds) \ - MonthChangedOrBadTime(xE); \ - currentTime.milliseconds = (xE)->u.keyButtonPointer.time; \ - lastDeviceEventTime = currentTime; } +static void +NoticeTime(InternalEvent *ev) +{ + if (ev->u.any.time < currentTime.milliseconds) + MonthChangedOrBadTime(ev); + currentTime.milliseconds = ev->u.any.time; + lastDeviceEventTime = currentTime; +} void -NoticeEventTime(xEvent *xE) +NoticeEventTime(InternalEvent *ev) { if (!syncEvents.playingEvents) - NoticeTime(xE); + NoticeTime(ev); } /************************************************************************** @@ -1022,11 +1025,11 @@ EnqueueEvent(xEvent *ev, DeviceIntPtr device, int count) static xEvent xi[1000]; /* enough bytes for the events we have atm */ xEvent *xE = xi; + + NoticeTime((InternalEvent*)event); + nevents = ConvertBackToXI((InternalEvent*)ev, xE); - NoticeTime(xE); - - /* Fix for key repeating bug. */ if (device->key != NULL && device->key->xkbInfo != NULL && xE->u.u.type == KeyRelease) diff --git a/include/dix.h b/include/dix.h index 2aaa4fa0d..700fe9bf9 100644 --- a/include/dix.h +++ b/include/dix.h @@ -325,7 +325,7 @@ extern _X_EXPORT WindowPtr GetCurrentRootWindow(DeviceIntPtr pDev); extern _X_EXPORT WindowPtr GetSpriteWindow(DeviceIntPtr pDev); -extern _X_EXPORT void NoticeEventTime(xEventPtr /* xE */); +extern _X_EXPORT void NoticeEventTime(InternalEvent *ev); extern _X_EXPORT void EnqueueEvent( xEventPtr /* xE */,