X-Git-Url: https://diplodocus.org/git/xorg-xinput/blobdiff_plain/6ebdca422d12e3326f9ab59767e05eefd24ff85f..82d338548e22ae271f50592e759794dd7536a207:/src/xinput.c diff --git a/src/xinput.c b/src/xinput.c index ac9c65f..007fe2c 100644 --- a/src/xinput.c +++ b/src/xinput.c @@ -25,12 +25,8 @@ #include #include -typedef int (*prog)( -#if NeedFunctionPrototypes - Display* display, int argc, char *argv[], - char *prog_name, char *prog_desc -#endif -); +typedef int (*prog)(Display* display, int argc, char *argv[], + char *prog_name, char *prog_desc); typedef struct { @@ -53,6 +49,10 @@ static entry drivers[] = " ", set_integer_feedback }, + {"get-button-map", + "", + get_button_map + }, {"set-button-map", " [ [...]]", set_button_map @@ -102,6 +102,11 @@ static entry drivers[] = " ", set_clientpointer }, + { "test-xi2", + "", + test_xi2, + }, +#endif { "list-props", " [ ...]", list_props @@ -110,34 +115,47 @@ static entry drivers[] = " [ ...]", set_int_prop }, + { "set-float-prop", + " [ ...]", + set_float_prop + }, + { "set-atom-prop", + " [ ...]", + set_atom_prop + }, { "watch-props", "", watch_props }, -#endif - {0, 0, 0 + { "delete-prop", + " ", + delete_prop + }, + { "set-prop", + " [ ...]", + set_prop + }, + {NULL, NULL, NULL } }; -static Bool -is_xinput_present(Display *display) +int +xinput_version(Display *display) { XExtensionVersion *version; - Bool present; + static int vers = -1; + + if (vers != -1) + return vers; -#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; + vers = version->major_version; XFree(version); - return present; - } else { - return False; } + + return vers; } XDeviceInfo* @@ -151,7 +169,7 @@ find_device_info(Display *display, int num_devices; int len = strlen(name); Bool is_id = True; - XID id; + XID id = (XID)-1; for(loop=0; loopfunc_name, func) == 0) { int r = (*driver->func)(display, argc-2, argv+2, driver->func_name, driver->arg_desc); - XFlush(display); + XSync(display, False); + XCloseDisplay(display); return r; } driver++;