mi: split move to new screen logic to a helper function
No functional changes. Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net> Reviewed-by: Chase Douglas <chase.douglas@canonical.com>
This commit is contained in:
parent
3b1e2035cc
commit
48547068b1
22
mi/mieq.c
22
mi/mieq.c
|
@ -471,6 +471,19 @@ CopyGetMasterEvent(DeviceIntPtr sdev,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
mieqMoveToNewScreen(DeviceIntPtr dev, ScreenPtr screen, DeviceEvent *event)
|
||||||
|
{
|
||||||
|
if (dev && screen && screen != DequeueScreen(dev))
|
||||||
|
{
|
||||||
|
int x = 0, y = 0;
|
||||||
|
DequeueScreen(dev) = screen;
|
||||||
|
x = event->root_x;
|
||||||
|
y = event->root_y;
|
||||||
|
NewCurrentScreen (dev, DequeueScreen(dev), x, y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Post the given @event through the device hierarchy, as appropriate.
|
* Post the given @event through the device hierarchy, as appropriate.
|
||||||
* Use this function if an event must be posted for a given device during the
|
* Use this function if an event must be posted for a given device during the
|
||||||
|
@ -482,7 +495,6 @@ mieqProcessDeviceEvent(DeviceIntPtr dev,
|
||||||
ScreenPtr screen)
|
ScreenPtr screen)
|
||||||
{
|
{
|
||||||
mieqHandler handler;
|
mieqHandler handler;
|
||||||
int x = 0, y = 0;
|
|
||||||
DeviceIntPtr master;
|
DeviceIntPtr master;
|
||||||
InternalEvent mevent; /* master event */
|
InternalEvent mevent; /* master event */
|
||||||
|
|
||||||
|
@ -499,12 +511,8 @@ mieqProcessDeviceEvent(DeviceIntPtr dev,
|
||||||
case ET_KeyRelease:
|
case ET_KeyRelease:
|
||||||
case ET_ButtonPress:
|
case ET_ButtonPress:
|
||||||
case ET_ButtonRelease:
|
case ET_ButtonRelease:
|
||||||
if (dev && screen && screen != DequeueScreen(dev) && !handler) {
|
if (!handler)
|
||||||
DequeueScreen(dev) = screen;
|
mieqMoveToNewScreen(dev, screen, &event->device_event);
|
||||||
x = event->device_event.root_x;
|
|
||||||
y = event->device_event.root_y;
|
|
||||||
NewCurrentScreen (dev, DequeueScreen(dev), x, y);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue