aboutsummaryrefslogtreecommitdiffstats
path: root/sway/commands/seat/idle.c
blob: 2974453e9ac15c1a155b1cbab5b86bba896863a5 (plain) (blame)
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#include <limits.h>
#include <string.h>
#include <strings.h>
#include <stdint.h>
#include "log.h"
#include "sway/commands.h"
#include "sway/config.h"
#include "sway/input/seat.h"

static const struct {
	const char *name;
	uint32_t value;
} idle_source_strings[] = {
	{ "keyboard", IDLE_SOURCE_KEYBOARD },
	{ "pointer", IDLE_SOURCE_POINTER },
	{ "touch", IDLE_SOURCE_TOUCH },
	{ "tablet_pad", IDLE_SOURCE_TABLET_PAD },
	{ "tablet_tool", IDLE_SOURCE_TABLET_TOOL },
	{ "switch", IDLE_SOURCE_SWITCH },
};

static uint32_t parse_sources(int argc, char **argv) {
	uint32_t sources = 0;
	for (int i = 0; i < argc; ++i) {
		uint32_t value = 0;
		for (size_t j = 0; j < sizeof(idle_source_strings)
				/ sizeof(idle_source_strings[0]); ++j) {
			if (strcasecmp(idle_source_strings[j].name, argv[i]) == 0) {
				value = idle_source_strings[j].value;
				break;
			}
		}
		if (value == 0) {
			return UINT32_MAX;
		}
		sources |= value;
	}
	return sources;
}

struct cmd_results *seat_cmd_idle_inhibit(int argc, char **argv) {
	struct cmd_results *error = NULL;
	if ((error = checkarg(argc, "idle_inhibit", EXPECTED_AT_LEAST, 1))) {
		return error;
	}
	if (!config->handler_context.seat_config) {
		return cmd_results_new(CMD_FAILURE, "No seat defined");
	}

	uint32_t sources = parse_sources(argc, argv);
	if (sources == UINT32_MAX) {
		return cmd_results_new(CMD_FAILURE, "Invalid idle source");
	}
	config->handler_context.seat_config->idle_inhibit_sources = sources;
	return cmd_results_new(CMD_SUCCESS, NULL);
}

struct cmd_results *seat_cmd_idle_wake(int argc, char **argv) {
	struct cmd_results *error = NULL;
	if ((error = checkarg(argc, "idle_wake", EXPECTED_AT_LEAST, 1))) {
		return error;
	}
	if (!config->handler_context.seat_config) {
		return cmd_results_new(CMD_FAILURE, "No seat defined");
	}

	uint32_t sources = parse_sources(argc, argv);
	if (sources == UINT32_MAX) {
		return cmd_results_new(CMD_FAILURE, "Invalid idle source");
	}
	config->handler_context.seat_config->idle_wake_sources = sources;
	sway_log(SWAY_INFO, "Warning: seat idle_wake is deprecated");
	if (config->reading) {
		config_add_swaynag_warning("seat idle_wake is deprecated. "
			"Only seat idle_inhibit is supported.");
	}
	return cmd_results_new(CMD_SUCCESS, NULL);
}