set_mode
},
{"list",
- "[<device name>...]",
+ "[--short || <device name>...]",
list
},
{"query-state",
int len = strlen(name);
Bool is_id = True;
XID id;
-
+
for(loop=0; loop<len; loop++) {
if (!isdigit(name[loop])) {
is_id = False;
if (is_id) {
id = atoi(name);
}
-
+
devices = XListInputDevices(display, &num_devices);
for(loop=0; loop<num_devices; loop++) {
- if ((!only_extended || (devices[loop].use == IsXExtensionDevice)) &&
+ if ((!only_extended || (devices[loop].use >= IsXExtensionDevice)) &&
((!is_id && strcmp(devices[loop].name, name) == 0) ||
(is_id && devices[loop].id == id))) {
return &devices[loop];
}
static void
-usage()
+usage()
{
entry *pdriver = drivers;
-
+
fprintf(stderr, "usage :\n");
-
+
while(pdriver->func_name) {
fprintf(stderr, "\txinput %s %s\n", pdriver->func_name,
pdriver->arg_desc);
{
Display *display;
entry *driver = drivers;
-
+ char *func;
+
if (argc < 2) {
usage();
return EXIT_FAILURE;
}
-
+
display = XOpenDisplay(NULL);
-
+
if (display == NULL) {
fprintf(stderr, "Unable to connect to X server\n");
return EXIT_FAILURE;
}
+ func = argv[1];
+ while((*func) == '-') func++;
+
if (!is_xinput_present(display)) {
fprintf(stderr, "%s extension not available\n", INAME);
return EXIT_FAILURE;
}
-
+
while(driver->func_name) {
- if (strcmp(driver->func_name, argv[1]) == 0) {
+ if (strcmp(driver->func_name, func) == 0) {
int r = (*driver->func)(display, argc-2, argv+2,
driver->func_name, driver->arg_desc);
XFlush(display);
}
driver++;
}
-
+
usage();
-
+
return EXIT_FAILURE;
}