X-Git-Url: https://diplodocus.org/git/xorg-xinput/blobdiff_plain/57940c7995a3779792213468cafe7d982d009035..82d338548e22ae271f50592e759794dd7536a207:/src/xinput.c diff --git a/src/xinput.c b/src/xinput.c index cc85aff..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 { @@ -135,6 +131,10 @@ static entry drivers[] = " ", delete_prop }, + { "set-prop", + " [ ...]", + set_prop + }, {NULL, NULL, NULL } }; @@ -193,7 +193,7 @@ find_device_info(Display *display, "Warning: There are multiple devices named \"%s\".\n" "To ensure the correct one is selected, please use " "the device ID instead.\n\n", name); - return NULL; + return NULL; } else { found = &devices[loop]; } @@ -203,8 +203,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 +220,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 @@ -285,6 +283,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++;