X-Git-Url: https://diplodocus.org/git/xorg-xinput/blobdiff_plain/a6feac1e18cdeffc42bc992faa8c95eaec420378..1c7b473b7e64f8b616aba70926f93d37d5269c28:/src/xinput.c diff --git a/src/xinput.c b/src/xinput.c index 0fe8878..ac9c65f 100644 --- a/src/xinput.c +++ b/src/xinput.c @@ -5,15 +5,15 @@ * documentation for any purpose is hereby granted without fee, provided that * the above copyright notice appear in all copies and that both that * copyright notice and this permission notice appear in supporting - * documentation, and that the name of Frederic Lepied not be used in + * documentation, and that the name of the authors not be used in * advertising or publicity pertaining to distribution of the software without - * specific, written prior permission. Frederic Lepied makes no + * specific, written prior permission. The authors make no * representations about the suitability of this software for any purpose. It * is provided "as is" without express or implied warranty. * - * FREDERIC LEPIED DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, + * THE AUTHORS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO - * EVENT SHALL FREDERIC LEPIED BE LIABLE FOR ANY SPECIAL, INDIRECT OR + * EVENT SHALL THE AUTHORS BE LIABLE FOR ANY SPECIAL, INDIRECT OR * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR @@ -81,6 +81,7 @@ static entry drivers[] = "", version }, +#if HAVE_XI2 { "create-master", " [sendCore (dflt:1)] [enable (dflt:1)]", create_master @@ -101,6 +102,19 @@ static entry drivers[] = " ", set_clientpointer }, + { "list-props", + " [ ...]", + list_props + }, + { "set-int-prop", + " [ ...]", + set_int_prop + }, + { "watch-props", + "", + watch_props + }, +#endif {0, 0, 0 } }; @@ -111,7 +125,11 @@ is_xinput_present(Display *display) XExtensionVersion *version; Bool present; +#if HAVE_XI2 + version = XQueryInputVersion(display, XI_2_Major, XI_2_Minor); +#else version = XGetExtensionVersion(display, INAME); +#endif if (version && (version != (XExtensionVersion*) NoSuchExtension)) { present = version->present; @@ -128,6 +146,7 @@ find_device_info(Display *display, Bool only_extended) { XDeviceInfo *devices; + XDeviceInfo *found = NULL; int loop; int num_devices; int len = strlen(name); @@ -151,14 +170,21 @@ find_device_info(Display *display, if ((!only_extended || (devices[loop].use >= IsXExtensionDevice)) && ((!is_id && strcmp(devices[loop].name, name) == 0) || (is_id && devices[loop].id == id))) { - return &devices[loop]; + if (found) { + fprintf(stderr, + "Warning: There are multiple devices named \"%s\".\n" + "To ensure the correct one is selected, please use " + "the device ID instead.\n\n", name); + } else { + found = &devices[loop]; + } } } - return NULL; + return found; } static void -usage() +usage(void) { entry *pdriver = drivers;