diff options
author | Drew DeVault <sir@cmpwn.com> | 2017-12-24 08:17:41 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-12-24 08:17:41 -0800 |
commit | a081b3bf7b99c0e044da26cd00fc74e367c66e63 (patch) | |
tree | a701435397e2722cb114ab0c0598081535cba394 /rootston | |
parent | e04d3501133dc0c73bb43af323bca51ab0b352a1 (diff) | |
parent | e85c2827c8929ed39d0931ba054047b0a35e7dcc (diff) |
Merge pull request #518 from martinetd/libinput_config
rootston: add arbitrary libinput config 'tap_enabled'
Diffstat (limited to 'rootston')
-rw-r--r-- | rootston/config.c | 10 | ||||
-rw-r--r-- | rootston/input.c | 12 | ||||
-rw-r--r-- | rootston/rootston.ini.example | 1 |
3 files changed, 23 insertions, 0 deletions
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 |