X-Git-Url: https://diplodocus.org/git/xorg-xinput/blobdiff_plain/d15a6c0c4cbf2b7d3feec0c829145e3036d84e4d..22fdd63f4521c89ae43bbfc6741e872b4a74d18f:/src/xinput.c?ds=sidebyside diff --git a/src/xinput.c b/src/xinput.c index b0a2858..8340211 100644 --- a/src/xinput.c +++ b/src/xinput.c @@ -25,6 +25,8 @@ #include #include +int xi_opcode; + typedef int (*prog)(Display* display, int argc, char *argv[], char *prog_name, char *prog_desc); @@ -83,11 +85,11 @@ static entry drivers[] = }, #if HAVE_XI2 { "create-master", - " [sendCore (dflt:1)] [enable (dflt:1)]", + " [] []", create_master }, { "remove-master", - " [returnMode (dflt:Floating)] [returnPointer] [returnKeyboard]", + " [Floating|AttachToMaster (dflt:Floating)] [] []", remove_master }, { "reattach", @@ -102,6 +104,10 @@ static entry drivers[] = " ", set_clientpointer }, + { "test-xi2", + "", + test_xi2, + }, #endif { "list-props", " [ ...]", @@ -135,25 +141,23 @@ static entry drivers[] = } }; -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* @@ -200,6 +204,41 @@ find_device_info(Display *display, return found; } +#ifdef HAVE_XI2 +XIDeviceInfo* +xi2_find_device_info(Display *display, char *name) +{ + XIDeviceInfo *info; + int ndevices; + Bool is_id = True; + int i, id = -1; + + for(i = 0; i < strlen(name); i++) { + if (!isdigit(name[i])) { + is_id = False; + break; + } + } + + if (is_id) { + id = atoi(name); + } + + info = XIQueryDevice(display, XIAllDevices, &ndevices); + for(i = 0; i < ndevices; i++) + { + if ((is_id && info[i].deviceid == id) || + (!is_id && strcmp(info[i].name, name) == 0)) + { + return &info[i]; + } + } + + XIFreeDeviceInfo(info); + return NULL; +} +#endif + static void usage(void) { @@ -220,6 +259,7 @@ main(int argc, char * argv[]) Display *display; entry *driver = drivers; char *func; + int event, error; if (argc < 2) { usage(); @@ -233,10 +273,15 @@ main(int argc, char * argv[]) return EXIT_FAILURE; } + if (!XQueryExtension(display, "XInputExtension", &xi_opcode, &event, &error)) { + printf("X Input extension not available.\n"); + return EXIT_FAILURE; + } + func = argv[1]; while((*func) == '-') func++; - if (!is_xinput_present(display)) { + if (!xinput_version(display)) { fprintf(stderr, "%s extension not available\n", INAME); return EXIT_FAILURE; } @@ -246,6 +291,7 @@ main(int argc, char * argv[]) int r = (*driver->func)(display, argc-2, argv+2, driver->func_name, driver->arg_desc); XSync(display, False); + XCloseDisplay(display); return r; } driver++;