X-Git-Url: https://diplodocus.org/git/xorg-xinput/blobdiff_plain/ea87f587e4090d2881ce8957476411b6de1c260b..09b075863708e43b9c1202dd052f36d5f865f571:/src/xinput.c?ds=inline diff --git a/src/xinput.c b/src/xinput.c index 9751045..149662d 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); @@ -66,7 +68,7 @@ static entry drivers[] = set_mode }, {"list", - "[--loop || --short || ...]", + "[--short || --long] [...]", list }, {"query-state", @@ -77,17 +79,13 @@ static entry drivers[] = "[-proximity] ", test }, - {"version", - "", - version - }, #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", @@ -132,13 +130,44 @@ static entry drivers[] = delete_prop }, { "set-prop", - " [ ...]", + " [--type=atom|float|int] [--format=8|16|32] [ ...]", set_prop }, {NULL, NULL, NULL } }; +static const char version_id[] = VERSION; + +int +print_version() +{ + XExtensionVersion *version; + Display *display; + + printf("xinput version %s\n", version_id); + + display = XOpenDisplay(NULL); + + printf("XI version on server: "); + + if (display == NULL) + printf("Failed to open display.\n"); + else { + version = XGetExtensionVersion(display, INAME); + if (!version || (version == (XExtensionVersion*) NoSuchExtension)) + printf(" Extension not supported.\n"); + else { + printf("%d.%d\n", version->major_version, + version->minor_version); + XFree(version); + return 0; + } + } + + return 1; +} + int xinput_version(Display *display) { @@ -203,8 +232,8 @@ find_device_info(Display *display, } #ifdef HAVE_XI2 -int -xi2_find_device_id(Display *display, char *name) +XIDeviceInfo* +xi2_find_device_info(Display *display, char *name) { XIDeviceInfo *info; int ndevices; @@ -220,22 +249,20 @@ xi2_find_device_id(Display *display, char *name) if (is_id) { id = atoi(name); - } else + } + + info = XIQueryDevice(display, XIAllDevices, &ndevices); + for(i = 0; i < ndevices; i++) { - info = XIQueryDevice(display, AllDevices, &ndevices); - for(i = 0; i < ndevices; i++) + if ((is_id && info[i].deviceid == id) || + (!is_id && strcmp(info[i].name, name) == 0)) { - if ((is_id && info[i].deviceid == id) || - (!is_id && strcmp(info[i].name, name) == 0)) - { - id = info[i].deviceid; - break; - } + return &info[i]; } - - XIFreeDeviceInfo(info); } - return id;; + + XIFreeDeviceInfo(info); + return NULL; } #endif @@ -259,12 +286,20 @@ main(int argc, char * argv[]) Display *display; entry *driver = drivers; char *func; + int event, error; if (argc < 2) { usage(); return EXIT_FAILURE; } + func = argv[1]; + while((*func) == '-') func++; + + if (strcmp("version", func) == 0) { + return print_version(argv[0]); + } + display = XOpenDisplay(NULL); if (display == NULL) { @@ -272,8 +307,10 @@ main(int argc, char * argv[]) return EXIT_FAILURE; } - func = argv[1]; - while((*func) == '-') func++; + if (!XQueryExtension(display, "XInputExtension", &xi_opcode, &event, &error)) { + printf("X Input extension not available.\n"); + return EXIT_FAILURE; + } if (!xinput_version(display)) { fprintf(stderr, "%s extension not available\n", INAME); @@ -285,6 +322,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++;