diff options
Diffstat (limited to 'sway/commands')
| -rw-r--r-- | sway/commands/input.c | 1 | ||||
| -rw-r--r-- | sway/commands/input/drag.c | 26 | 
2 files changed, 27 insertions, 0 deletions
| diff --git a/sway/commands/input.c b/sway/commands/input.c index 9091da2a..2889d47d 100644 --- a/sway/commands/input.c +++ b/sway/commands/input.c @@ -9,6 +9,7 @@  static struct cmd_handler input_handlers[] = {  	{ "accel_profile", input_cmd_accel_profile },  	{ "click_method", input_cmd_click_method }, +	{ "drag", input_cmd_drag },  	{ "drag_lock", input_cmd_drag_lock },  	{ "dwt", input_cmd_dwt },  	{ "events", input_cmd_events }, diff --git a/sway/commands/input/drag.c b/sway/commands/input/drag.c new file mode 100644 index 00000000..e325df29 --- /dev/null +++ b/sway/commands/input/drag.c @@ -0,0 +1,26 @@ +#include <string.h> +#include <strings.h> +#include "sway/config.h" +#include "sway/commands.h" +#include "sway/input/input-manager.h" +#include "util.h" + +struct cmd_results *input_cmd_drag(int argc, char **argv) { +	struct cmd_results *error = NULL; +	if ((error = checkarg(argc, "drag", EXPECTED_AT_LEAST, 1))) { +		return error; +	} +	struct input_config *ic = config->handler_context.input_config; +	if (!ic) { +		return cmd_results_new(CMD_FAILURE, +			"drag", "No input device defined."); +	} + +	if (parse_boolean(argv[0], true)) { +		ic->drag = LIBINPUT_CONFIG_DRAG_ENABLED; +	} else { +		ic->drag = LIBINPUT_CONFIG_DRAG_DISABLED; +	} + +	return cmd_results_new(CMD_SUCCESS, NULL, NULL); +} | 
