aboutsummaryrefslogtreecommitdiff
path: root/rootston
diff options
context:
space:
mode:
authorRyan Walklin <ryan@testtoast.com>2018-11-28 20:03:42 +0000
committerRyan Walklin <ryan@crackotage.local>2018-12-15 14:42:35 +1100
commit810c7b700cfb381457ad1e5a07f184f4efdcc5d1 (patch)
treee7f909e9bac6ab8acaa6d5540a534088084fdebd /rootston
parent62a9cf87fafdbc5f271ea1489f3d3f6bd7288b6e (diff)
Working switches in rootston:
Factor out switch handling to separate file Add formal enum for toggle action Implement binding actions
Diffstat (limited to 'rootston')
-rw-r--r--rootston/config.c7
-rw-r--r--rootston/meson.build1
-rw-r--r--rootston/seat.c4
-rw-r--r--rootston/switch.c33
4 files changed, 39 insertions, 6 deletions
diff --git a/rootston/config.c b/rootston/config.c
index addc9d24..198aaba6 100644
--- a/rootston/config.c
+++ b/rootston/config.c
@@ -201,7 +201,7 @@ void add_binding_config(struct wl_list *bindings, const char* combination,
}
}
-void add_switch_config(struct wl_list *switches, const char *switch_name, const char *action,
+void add_switch_config(struct wl_list *switches, const char *switch_name, const char *action,
const char* command) {
struct roots_switch_config *sc = calloc(1, sizeof(struct roots_switch_config));
@@ -218,10 +218,11 @@ void add_switch_config(struct wl_list *switches, const char *switch_name, const
} else if (strcmp(action, "off") == 0) {
sc->switch_state = WLR_SWITCH_STATE_OFF;
} else if (strcmp(action, "toggle") == 0) {
- sc->switch_state = -1;
+ sc->switch_state = WLR_SWITCH_STATE_TOGGLE;
} else {
wlr_log(WLR_ERROR, "Invalid switch action %s/n for switch %s:%s",
action, switch_name, action);
+ return;
}
sc->command = strdup(command);
wl_list_insert(switches, &sc->link);
@@ -465,7 +466,7 @@ static int config_ini_handler(void *user, const char *section, const char *name,
add_binding_config(&config->bindings, name, value);
} else if (strncmp(switch_prefix, section, strlen(switch_prefix)) == 0) {
const char *switch_name = section + strlen(switch_prefix);
- add_switch_config(&config->bindings, switch_name, name, value);
+ add_switch_config(&config->switches, switch_name, name, value);
} else {
wlr_log(WLR_ERROR, "got unknown config section: %s", section);
}
diff --git a/rootston/meson.build b/rootston/meson.build
index 8fefdcc4..db90a508 100644
--- a/rootston/meson.build
+++ b/rootston/meson.build
@@ -10,6 +10,7 @@ sources = [
'main.c',
'output.c',
'seat.c',
+ 'switch.c',
'text_input.c',
'virtual_keyboard.c',
'wl_shell.c',
diff --git a/rootston/seat.c b/rootston/seat.c
index 33f27312..dda2f8df 100644
--- a/rootston/seat.c
+++ b/rootston/seat.c
@@ -82,8 +82,7 @@ static void handle_switch_toggle(struct wl_listener *listener, void *data) {
struct roots_desktop *desktop = lid_switch->seat->input->server->desktop;
wlr_idle_notify_activity(desktop->idle, lid_switch->seat->seat);
struct wlr_event_switch_toggle *event = data;
- wlr_log(WLR_DEBUG, "Switch event %s: type %i state %i", event->device->name, event->switch_type, event->switch_state);
- //roots_switch_handle_toggle(lid_switch, event);
+ roots_switch_handle_toggle(lid_switch, event);
}
static void handle_touch_down(struct wl_listener *listener, void *data) {
@@ -742,7 +741,6 @@ static void seat_add_switch(struct roots_seat *seat,
wlr_log(WLR_ERROR, "could not allocate switch for seat");
return;
}
-
device->data = lid_switch;
lid_switch->device = device;
lid_switch->seat = seat;
diff --git a/rootston/switch.c b/rootston/switch.c
new file mode 100644
index 00000000..3ccaad6a
--- /dev/null
+++ b/rootston/switch.c
@@ -0,0 +1,33 @@
+#include <stdlib.h>
+
+#include <wlr/util/log.h>
+
+#include "rootston/bindings.h"
+#include "rootston/config.h"
+#include "rootston/input.h"
+#include "rootston/seat.h"
+#include "rootston/switch.h"
+
+void roots_switch_handle_toggle(struct roots_switch *lid_switch,
+ struct wlr_event_switch_toggle *event) {
+ struct wl_list *bound_switches = &lid_switch->seat->input->server->config->switches;
+ struct roots_switch_config *sc;
+ wl_list_for_each(sc, bound_switches, link) {
+ bool device_match = false;
+ bool state_match = false;
+ if ((sc->name != NULL && strcmp(event->device->name, sc->name) == 0) ||
+ (sc->name == NULL && event->switch_type == sc->switch_type)) {
+ device_match = true;
+ }
+ if (!device_match) {
+ break;
+ }
+ if (sc->switch_state == WLR_SWITCH_STATE_TOGGLE ||
+ event->switch_state == sc->switch_state) {
+ state_match = true;
+ }
+ if (device_match && state_match) {
+ execute_binding_command(lid_switch->seat, lid_switch->seat->input, sc->command);
+ }
+ }
+}