aboutsummaryrefslogtreecommitdiff
path: root/sway/commands
diff options
context:
space:
mode:
authoremersion <contact@emersion.fr>2018-04-08 15:11:31 -0400
committerGitHub <noreply@github.com>2018-04-08 15:11:31 -0400
commit4493761716a37a0ecba596b33cfb7a6dba2d84ba (patch)
tree0174edd442d4cf11d44cd404bf8b9c0f8aa9768a /sway/commands
parent3679323ce558f15a319d3ace6dc1c2618b816566 (diff)
parent0e3ddf255ef56b7fe2b868232b80d04ea961120b (diff)
downloadsway-4493761716a37a0ecba596b33cfb7a6dba2d84ba.tar.xz
Merge pull request #1781 from swaywm/map-to-output
Add input "identifier" map_to_output "identifier"
Diffstat (limited to 'sway/commands')
-rw-r--r--sway/commands/input/map_to_output.c27
1 files changed, 27 insertions, 0 deletions
diff --git a/sway/commands/input/map_to_output.c b/sway/commands/input/map_to_output.c
new file mode 100644
index 00000000..60e4608e
--- /dev/null
+++ b/sway/commands/input/map_to_output.c
@@ -0,0 +1,27 @@
+#define _POSIX_C_SOURCE 200809L
+#include <string.h>
+#include <strings.h>
+#include "sway/config.h"
+#include "sway/commands.h"
+#include "sway/input/input-manager.h"
+#include "log.h"
+
+struct cmd_results *input_cmd_map_to_output(int argc, char **argv) {
+ struct cmd_results *error = NULL;
+ if ((error = checkarg(argc, "map_to_output", EXPECTED_EQUAL_TO, 1))) {
+ return error;
+ }
+ struct input_config *current_input_config =
+ config->handler_context.input_config;
+ if (!current_input_config) {
+ return cmd_results_new(CMD_FAILURE, "map_to_output",
+ "No input device defined.");
+ }
+ struct input_config *new_config =
+ new_input_config(current_input_config->identifier);
+
+ new_config->mapped_output = strdup(argv[0]);
+ apply_input_config(new_config);
+
+ return cmd_results_new(CMD_SUCCESS, NULL, NULL);
+}