aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2017-12-24 08:17:41 -0800
committerGitHub <noreply@github.com>2017-12-24 08:17:41 -0800
commita081b3bf7b99c0e044da26cd00fc74e367c66e63 (patch)
treea701435397e2722cb114ab0c0598081535cba394
parente04d3501133dc0c73bb43af323bca51ab0b352a1 (diff)
parente85c2827c8929ed39d0931ba054047b0a35e7dcc (diff)
Merge pull request #518 from martinetd/libinput_config
rootston: add arbitrary libinput config 'tap_enabled'
-rw-r--r--include/rootston/config.h1
-rw-r--r--rootston/config.c10
-rw-r--r--rootston/input.c12
-rw-r--r--rootston/rootston.ini.example1
4 files changed, 24 insertions, 0 deletions
diff --git a/include/rootston/config.h b/include/rootston/config.h
index d453a82c..bd24e577 100644
--- a/include/rootston/config.h
+++ b/include/rootston/config.h
@@ -21,6 +21,7 @@ struct roots_device_config {
char *name;
char *seat;
char *mapped_output;
+ bool tap_enabled;
struct wlr_box *mapped_box;
struct wl_list link;
};
diff --git a/rootston/config.c b/rootston/config.c
index ed91d4fd..dd741186 100644
--- a/rootston/config.c
+++ b/rootston/config.c
@@ -342,6 +342,16 @@ static int config_ini_handler(void *user, const char *section, const char *name,
} else if (strcmp(name, "seat") == 0) {
free(dc->seat);
dc->seat = strdup(value);
+ } else if (strcmp(name, "tap_enabled") == 0) {
+ if (strcasecmp(value, "true") == 0) {
+ dc->tap_enabled = true;
+ } else if (strcasecmp(value, "false") == 0) {
+ dc->tap_enabled = false;
+ } else {
+ wlr_log(L_ERROR,
+ "got unknown tap_enabled value: %s",
+ value);
+ }
} else {
wlr_log(L_ERROR, "got unknown device config: %s", name);
}
diff --git a/rootston/input.c b/rootston/input.c
index a3904a61..74ce59d0 100644
--- a/rootston/input.c
+++ b/rootston/input.c
@@ -5,6 +5,7 @@
#include <wlr/util/log.h>
#include <wlr/xcursor.h>
#include <wlr/xwayland.h>
+#include <wlr/backend/libinput.h>
#include "rootston/server.h"
#include "rootston/config.h"
#include "rootston/input.h"
@@ -60,6 +61,17 @@ static void input_add_notify(struct wl_listener *listener, void *data) {
device->vendor, device->product, device_type(device->type), seat_name);
roots_seat_add_device(seat, device);
+
+ if (dc && wlr_input_device_is_libinput(device)) {
+ struct libinput_device *libinput_dev =
+ wlr_libinput_get_device_handle(device);
+
+ wlr_log(L_DEBUG, "input has config, tap_enabled: %d\n", dc->tap_enabled);
+ if (dc->tap_enabled) {
+ libinput_device_config_tap_set_enabled(libinput_dev,
+ LIBINPUT_CONFIG_TAP_ENABLED);
+ }
+ }
}
static void input_remove_notify(struct wl_listener *listener, void *data) {
diff --git a/rootston/rootston.ini.example b/rootston/rootston.ini.example
index a2fabb6b..0d19b751 100644
--- a/rootston/rootston.ini.example
+++ b/rootston/rootston.ini.example
@@ -30,6 +30,7 @@ theme = default
map-to-output = VGA-1
# Restrict cursor movements for this mouse to concrete rectangle
geometry = 2500x800
+# tap_enabled=true
[keyboard]
meta-key = Logo