diff options
author | Kristian Høgsberg <krh@bitplanet.net> | 2013-07-02 16:59:44 -0400 |
---|---|---|
committer | Kristian Høgsberg <krh@bitplanet.net> | 2013-07-02 17:01:46 -0400 |
commit | 3cff4693ea2d547191a2d4270d9444da7df7d462 (patch) | |
tree | 3cc9fdb2bf4d8ade1332d81a716bc9b275ad8a25 | |
parent | 477c7237e1f09695f37f062c2bb5520bc3a9ed4c (diff) |
wayland-server: Free non-legacy wl_resource structs during wl_client_destroy
We need to free the non-legacy resources during client shutdown as well.
-rw-r--r-- | src/wayland-server.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/wayland-server.c b/src/wayland-server.c index 5410553..32310b1 100644 --- a/src/wayland-server.c +++ b/src/wayland-server.c @@ -422,11 +422,17 @@ static void destroy_resource(void *element, void *data) { struct wl_resource *resource = element; + struct wl_client *client = resource->client; + uint32_t flags; wl_signal_emit(&resource->destroy_signal, resource); + flags = wl_map_lookup_flags(&client->objects, resource->object.id); if (resource->destroy) resource->destroy(resource); + + if (!(flags & WL_MAP_ENTRY_LEGACY)) + free(resource); } WL_EXPORT void @@ -438,9 +444,6 @@ wl_resource_destroy(struct wl_resource *resource) id = resource->object.id; destroy_resource(resource, NULL); - if (!(wl_map_lookup_flags(&client->objects, id) & WL_MAP_ENTRY_LEGACY)) - free(resource); - if (id < WL_SERVER_ID_START) { if (client->display_resource) { wl_resource_queue_event(client->display_resource, |