aboutsummaryrefslogtreecommitdiff
path: root/sway/commands/seat.c
blob: 5b23dcc6a68e50e2963914404fd04376b317bf5f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include <string.h>
#include <strings.h>
#include "sway/commands.h"
#include "sway/input/input-manager.h"
#include "sway/input/seat.h"
#include "log.h"
#include "stringop.h"

// must be in order for the bsearch
static struct cmd_handler seat_handlers[] = {
	{ "attach", seat_cmd_attach },
	{ "cursor", seat_cmd_cursor },
	{ "fallback", seat_cmd_fallback },
	{ "hide_cursor", seat_cmd_hide_cursor },
	{ "pointer_constraint", seat_cmd_pointer_constraint },
};

struct cmd_results *cmd_seat(int argc, char **argv) {
	struct cmd_results *error = NULL;
	if ((error = checkarg(argc, "seat", EXPECTED_AT_LEAST, 2))) {
		return error;
	}

	if (!strcmp(argv[0], "-")) {
		if (config->reading) {
			return cmd_results_new(CMD_FAILURE,
					"Current seat alias (-) cannot be used in the config");
		}
		config->handler_context.seat_config =
			new_seat_config(config->handler_context.seat->wlr_seat->name);
	} else {
		config->handler_context.seat_config = new_seat_config(argv[0]);
	}
	if (!config->handler_context.seat_config) {
		return cmd_results_new(CMD_FAILURE, "Couldn't allocate config");
	}

	struct cmd_results *res = config_subcommand(argv + 1, argc - 1,
			seat_handlers, sizeof(seat_handlers));
	if (res && res->status != CMD_SUCCESS) {
		free_seat_config(config->handler_context.seat_config);
		config->handler_context.seat_config = NULL;
		return res;
	}

	struct seat_config *sc =
		store_seat_config(config->handler_context.seat_config);
	if (!config->reading) {
		input_manager_apply_seat_config(sc);
	}

	config->handler_context.seat_config = NULL;
	return cmd_results_new(CMD_SUCCESS, NULL);
}