mirror of
https://github.com/swaywm/sway.git
synced 2024-11-14 06:24:20 +01:00
Add left_handed support for input devices
Some users may want to switch buttons on their input devices, turns out libinput already supports it. Let's add a support for it in our config. Signed-off-by: Michał Winiarski <knr@hardline.pl>
This commit is contained in:
parent
47fd53812b
commit
e8d8abfbb5
@ -173,6 +173,7 @@ sway_cmd input_cmd_click_method;
|
|||||||
sway_cmd input_cmd_drag_lock;
|
sway_cmd input_cmd_drag_lock;
|
||||||
sway_cmd input_cmd_dwt;
|
sway_cmd input_cmd_dwt;
|
||||||
sway_cmd input_cmd_events;
|
sway_cmd input_cmd_events;
|
||||||
|
sway_cmd input_cmd_left_handed;
|
||||||
sway_cmd input_cmd_middle_emulation;
|
sway_cmd input_cmd_middle_emulation;
|
||||||
sway_cmd input_cmd_natural_scroll;
|
sway_cmd input_cmd_natural_scroll;
|
||||||
sway_cmd input_cmd_pointer_accel;
|
sway_cmd input_cmd_pointer_accel;
|
||||||
|
@ -60,6 +60,7 @@ struct input_config {
|
|||||||
int click_method;
|
int click_method;
|
||||||
int drag_lock;
|
int drag_lock;
|
||||||
int dwt;
|
int dwt;
|
||||||
|
int left_handed;
|
||||||
int middle_emulation;
|
int middle_emulation;
|
||||||
int natural_scroll;
|
int natural_scroll;
|
||||||
float pointer_accel;
|
float pointer_accel;
|
||||||
|
@ -265,6 +265,7 @@ static struct cmd_handler input_handlers[] = {
|
|||||||
{ "drag_lock", input_cmd_drag_lock },
|
{ "drag_lock", input_cmd_drag_lock },
|
||||||
{ "dwt", input_cmd_dwt },
|
{ "dwt", input_cmd_dwt },
|
||||||
{ "events", input_cmd_events },
|
{ "events", input_cmd_events },
|
||||||
|
{ "left_handed", input_cmd_left_handed },
|
||||||
{ "middle_emulation", input_cmd_middle_emulation },
|
{ "middle_emulation", input_cmd_middle_emulation },
|
||||||
{ "natural_scroll", input_cmd_natural_scroll },
|
{ "natural_scroll", input_cmd_natural_scroll },
|
||||||
{ "pointer_accel", input_cmd_pointer_accel },
|
{ "pointer_accel", input_cmd_pointer_accel },
|
||||||
|
@ -31,6 +31,8 @@ struct cmd_results *cmd_input(int argc, char **argv) {
|
|||||||
res = input_cmd_dwt(argc_new, argv_new);
|
res = input_cmd_dwt(argc_new, argv_new);
|
||||||
} else if (strcasecmp("events", argv[1]) == 0) {
|
} else if (strcasecmp("events", argv[1]) == 0) {
|
||||||
res = input_cmd_events(argc_new, argv_new);
|
res = input_cmd_events(argc_new, argv_new);
|
||||||
|
} else if (strcasecmp("left_handed", argv[1]) == 0) {
|
||||||
|
res = input_cmd_left_handed(argc_new, argv_new);
|
||||||
} else if (strcasecmp("middle_emulation", argv[1]) == 0) {
|
} else if (strcasecmp("middle_emulation", argv[1]) == 0) {
|
||||||
res = input_cmd_middle_emulation(argc_new, argv_new);
|
res = input_cmd_middle_emulation(argc_new, argv_new);
|
||||||
} else if (strcasecmp("natural_scroll", argv[1]) == 0) {
|
} else if (strcasecmp("natural_scroll", argv[1]) == 0) {
|
||||||
|
25
sway/commands/input/left_handed.c
Normal file
25
sway/commands/input/left_handed.c
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
#include <string.h>
|
||||||
|
#include "sway/commands.h"
|
||||||
|
#include "sway/input.h"
|
||||||
|
|
||||||
|
struct cmd_results *input_cmd_left_handed(int argc, char **argv) {
|
||||||
|
struct cmd_results *error = NULL;
|
||||||
|
if ((error = checkarg(argc, "left_handed", EXPECTED_AT_LEAST, 1))) {
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
if (!current_input_config) {
|
||||||
|
return cmd_results_new(CMD_FAILURE, "left_handed", "No input device defined.");
|
||||||
|
}
|
||||||
|
struct input_config *new_config = new_input_config(current_input_config->identifier);
|
||||||
|
|
||||||
|
if (strcasecmp(argv[0], "enabled") == 0) {
|
||||||
|
new_config->left_handed = 1;
|
||||||
|
} else if (strcasecmp(argv[0], "disabled") == 0) {
|
||||||
|
new_config->left_handed = 0;
|
||||||
|
} else {
|
||||||
|
return cmd_results_new(CMD_INVALID, "left_handed", "Expected 'left_handed <enabled|disabled>'");
|
||||||
|
}
|
||||||
|
|
||||||
|
input_cmd_apply(new_config);
|
||||||
|
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
||||||
|
}
|
@ -832,6 +832,10 @@ void apply_input_config(struct input_config *ic, struct libinput_device *dev) {
|
|||||||
sway_log(L_DEBUG, "apply_input_config(%s) dwt_set_enabled(%d)", ic->identifier, ic->dwt);
|
sway_log(L_DEBUG, "apply_input_config(%s) dwt_set_enabled(%d)", ic->identifier, ic->dwt);
|
||||||
libinput_device_config_dwt_set_enabled(dev, ic->dwt);
|
libinput_device_config_dwt_set_enabled(dev, ic->dwt);
|
||||||
}
|
}
|
||||||
|
if (ic->left_handed != INT_MIN) {
|
||||||
|
sway_log(L_DEBUG, "apply_input_config(%s) left_handed_set_enabled(%d)", ic->identifier, ic->left_handed);
|
||||||
|
libinput_device_config_left_handed_set(dev, ic->left_handed);
|
||||||
|
}
|
||||||
if (ic->middle_emulation != INT_MIN) {
|
if (ic->middle_emulation != INT_MIN) {
|
||||||
sway_log(L_DEBUG, "apply_input_config(%s) middle_emulation_set_enabled(%d)", ic->identifier, ic->middle_emulation);
|
sway_log(L_DEBUG, "apply_input_config(%s) middle_emulation_set_enabled(%d)", ic->identifier, ic->middle_emulation);
|
||||||
libinput_device_config_middle_emulation_set_enabled(dev, ic->middle_emulation);
|
libinput_device_config_middle_emulation_set_enabled(dev, ic->middle_emulation);
|
||||||
|
@ -24,6 +24,7 @@ struct input_config *new_input_config(const char* identifier) {
|
|||||||
input->accel_profile = INT_MIN;
|
input->accel_profile = INT_MIN;
|
||||||
input->pointer_accel = FLT_MIN;
|
input->pointer_accel = FLT_MIN;
|
||||||
input->scroll_method = INT_MIN;
|
input->scroll_method = INT_MIN;
|
||||||
|
input->left_handed = INT_MIN;
|
||||||
|
|
||||||
return input;
|
return input;
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,9 @@ Commands
|
|||||||
Enables or disables send_events for specified input device.
|
Enables or disables send_events for specified input device.
|
||||||
(Disabling send_events disables the input device)
|
(Disabling send_events disables the input device)
|
||||||
|
|
||||||
|
**input** <identifier> left_handed <enabled|disabled>::
|
||||||
|
Enables or disables left handed mode for specified input device.
|
||||||
|
|
||||||
**input** <identifier> middle_emulation <enabled|disabled>::
|
**input** <identifier> middle_emulation <enabled|disabled>::
|
||||||
Enables or disables middle click emulation.
|
Enables or disables middle click emulation.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user