Commit 1627124f authored by Sam Lantinga's avatar Sam Lantinga

The core pointer is comprised of merging the inputs of all mice.

If there are other mice, they should show up in the device list, and
we want to report events from those devices instead of the core events.
However, if XInput isn't supported or we can't find other mice in the
device list, we'll add the core pointer and interpret normal mouse events.

--HG--
extra : convert_revision : svn%3Ac70aab31-4412-0410-b14c-859654838e24/trunk%403454
parent 4307faf9
...@@ -280,6 +280,16 @@ X11_DispatchEvent(_THIS) ...@@ -280,6 +280,16 @@ X11_DispatchEvent(_THIS)
} }
break; break;
default:{
#if SDL_VIDEO_DRIVER_X11_XINPUT
for (i = 0; i < SDL_GetNumMice(); ++i) {
SDL_Mouse *mouse;
X11_MouseData *data;
mouse = SDL_GetMouse(i);
data = (X11_MouseData *) mouse->driverdata;
if (!data) {
switch (xevent.type) {
case MotionNotify: case MotionNotify:
#ifdef DEBUG_MOTION #ifdef DEBUG_MOTION
printf("X11 motion: %d,%d\n", xevent.xmotion.x, xevent.xmotion.y); printf("X11 motion: %d,%d\n", xevent.xmotion.x, xevent.xmotion.y);
...@@ -294,16 +304,7 @@ X11_DispatchEvent(_THIS) ...@@ -294,16 +304,7 @@ X11_DispatchEvent(_THIS)
case ButtonRelease: case ButtonRelease:
SDL_SendMouseButton(0, SDL_RELEASED, xevent.xbutton.button); SDL_SendMouseButton(0, SDL_RELEASED, xevent.xbutton.button);
break; break;
}
default:{
#if SDL_VIDEO_DRIVER_X11_XINPUT
for (i = 0; i < SDL_GetNumMice(); ++i) {
SDL_Mouse *mouse;
X11_MouseData *data;
mouse = SDL_GetMouse(i);
data = (X11_MouseData *) mouse->driverdata;
if (!data) {
continue; continue;
} }
......
...@@ -50,19 +50,14 @@ X11_InitMouse(_THIS) ...@@ -50,19 +50,14 @@ X11_InitMouse(_THIS)
int event_code; int event_code;
XEventClass xEvent; XEventClass xEvent;
#endif #endif
int num_mice = 0;
SDL_zero(mouse);
SDL_AddMouse(&mouse, "CorePointer", 0, 0, 1);
#if SDL_VIDEO_DRIVER_X11_XINPUT #if SDL_VIDEO_DRIVER_X11_XINPUT
if (!SDL_X11_HAVE_XINPUT) {
/* should have dynamically loaded, but wasn't available. */
return;
}
/* we're getting the list of input devices */ /* we're getting the list of input devices */
n = 0; n = 0;
if (SDL_X11_HAVE_XINPUT) {
DevList = XListInputDevices(display, &n); DevList = XListInputDevices(display, &n);
}
/* we're aquiring valuators: mice, tablets, etc. */ /* we're aquiring valuators: mice, tablets, etc. */
for (i = 0; i < n; ++i) { for (i = 0; i < n; ++i) {
...@@ -127,6 +122,9 @@ X11_InitMouse(_THIS) ...@@ -127,6 +122,9 @@ X11_InitMouse(_THIS)
} else { } else {
SDL_AddMouse(&mouse, DevList[i].name, 0, 0, 1); SDL_AddMouse(&mouse, DevList[i].name, 0, 0, 1);
} }
if (DevList[i].use == IsXExtensionPointer) {
++num_mice;
}
break; break;
} }
/* if it's not class we're interested in, lets go further */ /* if it's not class we're interested in, lets go further */
...@@ -138,6 +136,11 @@ X11_InitMouse(_THIS) ...@@ -138,6 +136,11 @@ X11_InitMouse(_THIS)
} }
XFreeDeviceList(DevList); XFreeDeviceList(DevList);
#endif #endif
if (num_mice == 0) {
SDL_zero(mouse);
SDL_AddMouse(&mouse, "CorePointer", 0, 0, 1);
}
} }
void void
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment