X-Git-Url: https://diplodocus.org/git/xorg-xinput/blobdiff_plain/39ac9d85f464ca3195e8b3b2d3f6c3188f83e25e..cef07c0c8280d7e7b82c3bcc62a1dfbe8cc43ff8:/src/xinput.c?ds=sidebyside diff --git a/src/xinput.c b/src/xinput.c index e6e468c..7b27ffe 100644 --- a/src/xinput.c +++ b/src/xinput.c @@ -206,10 +206,10 @@ xinput_version(Display *display) int maj = 2, min = 0; -#if HAVE_XI21 - min = 1; -#elif HAVE_XI22 +#if HAVE_XI22 min = 2; +#elif HAVE_XI21 + min = 1; #endif forced_version = getenv("XINPUT_XI2_VERSION"); @@ -273,7 +273,7 @@ find_device_info(Display *display, return found; } -#ifdef HAVE_XI2 +#if HAVE_XI2 Bool is_pointer(int use) { return use == XIMasterPointer || use == XISlavePointer; @@ -361,6 +361,26 @@ usage(void) } } +static Bool +is_xwayland(Display *dpy) +{ + XDeviceInfo *devices; + int n; + Bool is_xwayland = False; + + devices = XListInputDevices(dpy, &n); + while (n-- > 0) { + if (strncmp(devices[n].name, "xwayland-", 9) == 0) { + is_xwayland = True; + break; + } + } + + XFreeDeviceList(devices); + + return is_xwayland; +} + int main(int argc, char * argv[]) { @@ -402,6 +422,9 @@ main(int argc, char * argv[]) goto out; } + if (is_xwayland(display)) + fprintf(stderr, "WARNING: running xinput against an Xwayland server. See the xinput man page for details.\n"); + while(driver->func_name) { if (strcmp(driver->func_name, func) == 0) { int r = (*driver->func)(display, argc-2, argv+2,