aboutsummaryrefslogtreecommitdiff
path: root/backend
diff options
context:
space:
mode:
Diffstat (limited to 'backend')
-rw-r--r--backend/wayland/backend.c4
-rw-r--r--backend/wayland/seat.c7
2 files changed, 9 insertions, 2 deletions
diff --git a/backend/wayland/backend.c b/backend/wayland/backend.c
index 2059b726..459baaa6 100644
--- a/backend/wayland/backend.c
+++ b/backend/wayland/backend.c
@@ -105,7 +105,9 @@ static void registry_global(void *data, struct wl_registry *registry,
} else if (strcmp(iface, wl_seat_interface.name) == 0) {
struct wl_seat *wl_seat = wl_registry_bind(registry, name,
&wl_seat_interface, 5);
- create_wl_seat(wl_seat, wl);
+ if (!create_wl_seat(wl_seat, wl)) {
+ wl_seat_destroy(wl_seat);
+ }
} else if (strcmp(iface, xdg_wm_base_interface.name) == 0) {
wl->xdg_wm_base = wl_registry_bind(registry, name,
&xdg_wm_base_interface, 1);
diff --git a/backend/wayland/seat.c b/backend/wayland/seat.c
index f20619d5..10a224a1 100644
--- a/backend/wayland/seat.c
+++ b/backend/wayland/seat.c
@@ -372,12 +372,17 @@ static struct wlr_wl_input_device *get_wl_input_device_from_input_device(
return (struct wlr_wl_input_device *)wlr_dev;
}
-void create_wl_seat(struct wl_seat *wl_seat, struct wlr_wl_backend *wl) {
+bool create_wl_seat(struct wl_seat *wl_seat, struct wlr_wl_backend *wl) {
assert(!wl->seat); // only one seat supported at the moment
struct wlr_wl_seat *seat = calloc(1, sizeof(struct wlr_wl_seat));
+ if (!seat) {
+ wlr_log_errno(WLR_ERROR, "Allocation failed");
+ return false;
+ }
seat->wl_seat = wl_seat;
wl->seat = seat;
wl_seat_add_listener(wl_seat, &seat_listener, wl);
+ return true;
}
void destroy_wl_seats(struct wlr_wl_backend *wl) {