diff options
author | Drew DeVault <sir@cmpwn.com> | 2017-08-12 08:21:18 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-08-12 08:21:18 -0400 |
commit | 53a53f55b4f2212fbe81e77beca85f45400e12de (patch) | |
tree | 3d54d0664fe73de8145ee57af890a818ec5b7e5b /backend/libinput/backend.c | |
parent | 65a899924221c3104800a8676852b34b0cd7223d (diff) | |
parent | 3ea878b76e7cf63caf9cddaaabe2faca053d9085 (diff) |
Merge pull request #74 from martinetd/more_leaks
More leaks
Diffstat (limited to 'backend/libinput/backend.c')
-rw-r--r-- | backend/libinput/backend.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/backend/libinput/backend.c b/backend/libinput/backend.c index 19fe8fe7..42c1eac9 100644 --- a/backend/libinput/backend.c +++ b/backend/libinput/backend.c @@ -33,6 +33,7 @@ static int wlr_libinput_readable(int fd, uint32_t mask, void *_state) { struct libinput_event *event; while ((event = libinput_get_event(state->libinput))) { wlr_libinput_event(state, event); + libinput_event_destroy(event); } return 0; } @@ -84,7 +85,9 @@ static void wlr_libinput_backend_destroy(struct wlr_backend_state *state) { for (size_t i = 0; i < state->devices->length; i++) { list_t *wlr_devices = state->devices->items[i]; for (size_t j = 0; j < wlr_devices->length; j++) { - wlr_input_device_destroy(wlr_devices->items[j]); + struct wlr_input_device *wlr_device = wlr_devices->items[j]; + wl_signal_emit(&state->backend->events.input_remove, wlr_device); + wlr_input_device_destroy(wlr_device); } list_free(wlr_devices); } |