sway

i3-compatible Wayland compositor
git clone https://git.awy.one/sway
Log | Files | Refs | README | LICENSE

commit 8dadfd42dff1531f793ad2f2c237a05c05f6d180
parent 5d19906556fe27dd9f2ee12a819cc14dd33e3fea
Author: emersion <contact@emersion.fr>
Date:   Wed, 10 Oct 2018 23:52:29 +0200

Merge pull request #2817 from trmendes/libinput-disable-touchscreen-support

Add libinput send_events config for touch
Diffstat:
Msway/input/input-manager.c | 26++++++++++++++++++++++++++
1 file changed, 26 insertions(+), 0 deletions(-)

diff --git a/sway/input/input-manager.c b/sway/input/input-manager.c @@ -116,6 +116,28 @@ static void input_manager_libinput_config_keyboard( } } +static void input_manager_libinput_config_touch( + struct sway_input_device *input_device) { + struct wlr_input_device *wlr_device = input_device->wlr_device; + struct input_config *ic = input_device_get_config(input_device); + struct libinput_device *libinput_device; + + if (!ic || !wlr_input_device_is_libinput(wlr_device)) { + return; + } + + libinput_device = wlr_libinput_get_device_handle(wlr_device); + wlr_log(WLR_DEBUG, "input_manager_libinput_config_touch(%s)", + ic->identifier); + + if (ic->send_events != INT_MIN) { + wlr_log(WLR_DEBUG, "libinput_config_touch(%s) send_events_set_mode(%d)", + ic->identifier, ic->send_events); + libinput_device_config_send_events_set_mode(libinput_device, + ic->send_events); + } +} + static void input_manager_libinput_config_pointer( struct sway_input_device *input_device) { struct wlr_input_device *wlr_device = input_device->wlr_device; @@ -267,6 +289,8 @@ static void handle_new_input(struct wl_listener *listener, void *data) { input_manager_libinput_config_pointer(input_device); } else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_KEYBOARD) { input_manager_libinput_config_keyboard(input_device); + } else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_TOUCH) { + input_manager_libinput_config_touch(input_device); } wl_signal_add(&device->events.destroy, &input_device->device_destroy); @@ -430,6 +454,8 @@ void input_manager_apply_input_config(struct sway_input_manager *input, input_manager_libinput_config_pointer(input_device); } else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_KEYBOARD) { input_manager_libinput_config_keyboard(input_device); + } else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_TOUCH) { + input_manager_libinput_config_touch(input_device); } struct sway_seat *seat = NULL;