summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKristian Høgsberg <krh@bitplanet.net>2013-07-02 16:59:44 -0400
committerKristian Høgsberg <krh@bitplanet.net>2013-07-02 17:01:46 -0400
commit3cff4693ea2d547191a2d4270d9444da7df7d462 (patch)
tree3cc9fdb2bf4d8ade1332d81a716bc9b275ad8a25
parent477c7237e1f09695f37f062c2bb5520bc3a9ed4c (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.c9
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,