aboutsummaryrefslogtreecommitdiff
path: root/sway/commands
diff options
context:
space:
mode:
Diffstat (limited to 'sway/commands')
-rw-r--r--sway/commands/input.c1
-rw-r--r--sway/commands/input/calibration_matrix.c40
2 files changed, 41 insertions, 0 deletions
diff --git a/sway/commands/input.c b/sway/commands/input.c
index 08af3cb2..588ef2d5 100644
--- a/sway/commands/input.c
+++ b/sway/commands/input.c
@@ -9,6 +9,7 @@
// must be in order for the bsearch
static struct cmd_handler input_handlers[] = {
{ "accel_profile", input_cmd_accel_profile },
+ { "calibration_matrix", input_cmd_calibration_matrix },
{ "click_method", input_cmd_click_method },
{ "drag", input_cmd_drag },
{ "drag_lock", input_cmd_drag_lock },
diff --git a/sway/commands/input/calibration_matrix.c b/sway/commands/input/calibration_matrix.c
new file mode 100644
index 00000000..ac15d152
--- /dev/null
+++ b/sway/commands/input/calibration_matrix.c
@@ -0,0 +1,40 @@
+#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"
+#include "stringop.h"
+#include "util.h"
+
+struct cmd_results *input_cmd_calibration_matrix(int argc, char **argv) {
+ struct cmd_results *error = NULL;
+ if ((error = checkarg(argc, "calibration_matrix", EXPECTED_EQUAL_TO, 1))) {
+ return error;
+ }
+ struct input_config *ic = config->handler_context.input_config;
+ if (!ic) {
+ return cmd_results_new(CMD_FAILURE, "No input device defined.");
+ }
+
+ list_t *split = split_string(argv[0], " ");
+ if (split->length != 6) {
+ return cmd_results_new(CMD_FAILURE, "calibration_matrix should be a space-separated list of length 6");
+ }
+
+ float parsed[6];
+ for (int i = 0; i < split->length; ++i) {
+ char *item = split->items[i];
+ float x = parse_float(item);
+ if (x != x) {
+ return cmd_results_new(CMD_FAILURE, "calibration_matrix: unable to parse float: %s", item);
+ }
+ parsed[i] = x;
+ }
+
+ ic->calibration_matrix.configured = true;
+ memcpy(ic->calibration_matrix.matrix, parsed, sizeof(ic->calibration_matrix.matrix));
+
+ return cmd_results_new(CMD_SUCCESS, NULL);
+}