aboutsummaryrefslogtreecommitdiff
path: root/sway/commands/input
diff options
context:
space:
mode:
Diffstat (limited to 'sway/commands/input')
-rw-r--r--sway/commands/input/events.c59
1 files changed, 31 insertions, 28 deletions
diff --git a/sway/commands/input/events.c b/sway/commands/input/events.c
index cd2985ee..9405181a 100644
--- a/sway/commands/input/events.c
+++ b/sway/commands/input/events.c
@@ -74,34 +74,36 @@ static void toggle_select_send_events_for_device(struct input_config *ic,
ic->send_events = mode_for_name(argv[index % argc]);
}
-static void toggle_send_events(struct input_config *ic, int argc, char **argv) {
- struct sway_input_device *input_device = NULL;
- wl_list_for_each(input_device, &server.input->devices, link) {
- if (strcmp(input_device->identifier, ic->identifier) == 0) {
- if (argc) {
- toggle_select_send_events_for_device(ic, input_device,
- argc, argv);
- } else {
- toggle_supported_send_events_for_device(ic, input_device);
+static void toggle_send_events(int argc, char **argv) {
+ struct input_config *ic = config->handler_context.input_config;
+ bool wildcard = strcmp(ic->identifier, "*") == 0;
+ const char *type = strncmp(ic->identifier, "type:", strlen("type:")) == 0
+ ? ic->identifier + strlen("type:") : NULL;
+ struct sway_input_device *device = NULL;
+ wl_list_for_each(device, &server.input->devices, link) {
+ if (wildcard || type) {
+ ic = new_input_config(device->identifier);
+ if (!ic) {
+ continue;
}
- return;
+ if (type && strcmp(input_device_get_type(device), type) != 0) {
+ continue;
+ }
+ } else if (strcmp(ic->identifier, device->identifier) != 0) {
+ continue;
}
- }
-}
-static void toggle_wildcard_send_events(int argc, char **argv) {
- struct sway_input_device *input_device = NULL;
- wl_list_for_each(input_device, &server.input->devices, link) {
- struct input_config *ic = new_input_config(input_device->identifier);
- if (!ic) {
- break;
- }
if (argc) {
- toggle_select_send_events_for_device(ic, input_device, argc, argv);
+ toggle_select_send_events_for_device(ic, device, argc, argv);
} else {
- toggle_supported_send_events_for_device(ic, input_device);
+ toggle_supported_send_events_for_device(ic, device);
+ }
+
+ if (wildcard || type) {
+ store_input_config(ic, NULL);
+ } else {
+ return;
}
- store_input_config(ic, NULL);
}
}
@@ -132,15 +134,16 @@ struct cmd_results *input_cmd_events(int argc, char **argv) {
"Invalid toggle mode %s", argv[i]);
}
}
- if (strcmp(ic->identifier, "*") == 0) {
- // Update the device input configs and then reset the wildcard
+
+ toggle_send_events(argc - 1, argv + 1);
+
+ if (strcmp(ic->identifier, "*") == 0 ||
+ strncmp(ic->identifier, "type:", strlen("type:")) == 0) {
+ // Update the device input configs and then reset the type/wildcard
// config send events mode so that is does not override the device
// ones. The device ones will be applied when attempting to apply
- // the wildcard config
- toggle_wildcard_send_events(argc - 1, argv + 1);
+ // the type/wildcard config
ic->send_events = INT_MIN;
- } else {
- toggle_send_events(ic, argc - 1, argv + 1);
}
} else {
return cmd_results_new(CMD_INVALID,