aboutsummaryrefslogtreecommitdiffstats
path: root/sway/commands/input
diff options
context:
space:
mode:
authorLibravatar Sergei Dolgov <dolgovs@gmail.com>2019-06-22 14:54:55 +0200
committerLibravatar Simon Ser <contact@emersion.fr>2019-07-05 18:41:56 +0300
commitc9cb5ced7f7597afeb73fd5b661a98462f170d11 (patch)
treecf2bc4d47657f680571375d12e5d02a0387f641c /sway/commands/input
parentcalibration_matrix: add the current matrix to the IPC description for libinpu... (diff)
downloadsway-c9cb5ced7f7597afeb73fd5b661a98462f170d11.tar.gz
sway-c9cb5ced7f7597afeb73fd5b661a98462f170d11.tar.zst
sway-c9cb5ced7f7597afeb73fd5b661a98462f170d11.zip
calibration_matrix: expect 6 individual values
Example usage from command line: swaymsg input type:touch calibration_matrix -- -1 0 1 0 -1 1
Diffstat (limited to 'sway/commands/input')
-rw-r--r--sway/commands/input/calibration_matrix.c11
1 files changed, 3 insertions, 8 deletions
diff --git a/sway/commands/input/calibration_matrix.c b/sway/commands/input/calibration_matrix.c
index 9ac2bd7f..38749fbb 100644
--- a/sway/commands/input/calibration_matrix.c
+++ b/sway/commands/input/calibration_matrix.c
@@ -10,7 +10,7 @@
10 10
11struct cmd_results *input_cmd_calibration_matrix(int argc, char **argv) { 11struct cmd_results *input_cmd_calibration_matrix(int argc, char **argv) {
12 struct cmd_results *error = NULL; 12 struct cmd_results *error = NULL;
13 if ((error = checkarg(argc, "calibration_matrix", EXPECTED_EQUAL_TO, 1))) { 13 if ((error = checkarg(argc, "calibration_matrix", EXPECTED_EQUAL_TO, 6))) {
14 return error; 14 return error;
15 } 15 }
16 struct input_config *ic = config->handler_context.input_config; 16 struct input_config *ic = config->handler_context.input_config;
@@ -18,14 +18,9 @@ struct cmd_results *input_cmd_calibration_matrix(int argc, char **argv) {
18 return cmd_results_new(CMD_FAILURE, "No input device defined."); 18 return cmd_results_new(CMD_FAILURE, "No input device defined.");
19 } 19 }
20 20
21 list_t *split = split_string(argv[0], " ");
22 if (split->length != 6) {
23 return cmd_results_new(CMD_FAILURE, "calibration_matrix should be a space-separated list of length 6");
24 }
25
26 float parsed[6]; 21 float parsed[6];
27 for (int i = 0; i < split->length; ++i) { 22 for (int i = 0; i < argc; ++i) {
28 char *item = split->items[i]; 23 char *item = argv[i];
29 float x = parse_float(item); 24 float x = parse_float(item);
30 if (isnan(x)) { 25 if (isnan(x)) {
31 return cmd_results_new(CMD_FAILURE, "calibration_matrix: unable to parse float: %s", item); 26 return cmd_results_new(CMD_FAILURE, "calibration_matrix: unable to parse float: %s", item);