aboutsummaryrefslogtreecommitdiff
path: root/backend/libinput/backend.c
diff options
context:
space:
mode:
authorSimon Zeni <simon@bl4ckb0ne.ca>2022-02-22 16:17:48 -0500
committerKirill Primak <vyivel@eclair.cafe>2022-03-02 18:18:05 +0000
commit9dd6e2b90521fd438c90837c646a1fb4092bfe1b (patch)
tree11c1405faf1a7371d7b12f3464793b96c122ef48 /backend/libinput/backend.c
parent0a5a65cf4819ebffb74c410735ba676b288bb82d (diff)
backend/libinput: add devices wl_list
This commit prepares the ground for a wlr_libinput_input_device refactoring.
Diffstat (limited to 'backend/libinput/backend.c')
-rw-r--r--backend/libinput/backend.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/backend/libinput/backend.c b/backend/libinput/backend.c
index 8023807f..50726ec5 100644
--- a/backend/libinput/backend.c
+++ b/backend/libinput/backend.c
@@ -110,9 +110,11 @@ static bool backend_start(struct wlr_backend *wlr_backend) {
no_devs = NULL;
}
}
- if (!no_devs && backend->wlr_device_lists.size == 0) {
+ if (!no_devs && (backend->wlr_device_lists.size == 0
+ || wl_list_empty(&backend->devices))) {
handle_libinput_readable(libinput_fd, WL_EVENT_READABLE, backend);
- if (backend->wlr_device_lists.size == 0) {
+ if (backend->wlr_device_lists.size == 0
+ && wl_list_empty(&backend->devices)) {
wlr_log(WLR_ERROR, "libinput initialization failed, no input devices");
wlr_log(WLR_ERROR, "Set WLR_LIBINPUT_NO_DEVICES=1 to suppress this check");
return false;
@@ -150,6 +152,11 @@ static void backend_destroy(struct wlr_backend *wlr_backend) {
free(*wlr_devices_ptr);
}
+ struct wlr_libinput_input_device *dev, *tmp;
+ wl_list_for_each_safe(dev, tmp, &backend->devices, link) {
+ destroy_libinput_input_device(dev);
+ }
+
wlr_backend_finish(wlr_backend);
wl_list_remove(&backend->display_destroy.link);
@@ -212,6 +219,7 @@ struct wlr_backend *wlr_libinput_backend_create(struct wl_display *display,
wlr_backend_init(&backend->backend, &backend_impl);
wl_array_init(&backend->wlr_device_lists);
+ wl_list_init(&backend->devices);
backend->session = session;
backend->display = display;