mirror of
https://gitlab.freedesktop.org/wayland/wayland.git
synced 2025-10-29 05:40:16 -04:00
server: add wl_client_get_user_data/wl_client_set_user_data
The only way to attach some data to a wl_client seems to be setting up a destroy listener and use wl_container_of. Let's make it straight forward to attach some data. Having an explicit destroy callback for the user data makes managing the user data lifetime much more convenient. All other callbacks, be they wl_resource request listeners, destroy listeners or destructors, or wl_client destroy listeners, can assume that the wl_client user data still exists if it was set. Otherwise making that guarantee would be complicated. Co-authored-by: Pekka Paalanen <pekka.paalanen@collabora.com> Signed-off-by: Sebastian Wick <sebastian@sebastianwick.net>
This commit is contained in:
parent
6a7284c632
commit
9c4213ed3e
3 changed files with 71 additions and 0 deletions
|
|
@ -80,12 +80,21 @@ client_late_destroy_notify(struct wl_listener *l, void *data)
|
|||
listener->late_done = true;
|
||||
}
|
||||
|
||||
static void
|
||||
client_user_data_destroy(void *data)
|
||||
{
|
||||
bool *user_data_destroyed = data;
|
||||
|
||||
*user_data_destroyed = true;
|
||||
}
|
||||
|
||||
TEST(client_destroy_listener)
|
||||
{
|
||||
struct wl_display *display;
|
||||
struct wl_client *client;
|
||||
struct wl_resource *resource;
|
||||
struct client_destroy_listener a, b;
|
||||
bool user_data_destroyed = false;
|
||||
int s[2];
|
||||
|
||||
assert(socketpair(AF_UNIX, SOCK_STREAM | SOCK_CLOEXEC, 0, s) == 0);
|
||||
|
|
@ -94,6 +103,9 @@ TEST(client_destroy_listener)
|
|||
client = wl_client_create(display, s[0]);
|
||||
assert(client);
|
||||
|
||||
wl_client_set_user_data(client, &user_data_destroyed, client_user_data_destroy);
|
||||
assert(wl_client_get_user_data(client) == &user_data_destroyed);
|
||||
|
||||
resource = wl_resource_create(client, &wl_callback_interface, 1, 0);
|
||||
assert(resource);
|
||||
|
||||
|
|
@ -128,6 +140,8 @@ TEST(client_destroy_listener)
|
|||
wl_list_remove(&a.resource_listener.link);
|
||||
wl_list_remove(&a.late_listener.link);
|
||||
|
||||
assert(!user_data_destroyed);
|
||||
|
||||
wl_client_destroy(client);
|
||||
|
||||
assert(!a.done);
|
||||
|
|
@ -136,6 +150,7 @@ TEST(client_destroy_listener)
|
|||
assert(b.done);
|
||||
assert(b.resource_done);
|
||||
assert(b.late_done);
|
||||
assert(user_data_destroyed);
|
||||
|
||||
close(s[0]);
|
||||
close(s[1]);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue