mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2024-11-27 15:15:58 +01:00
content-type-v1: use wlr_surface_synced
This commit is contained in:
parent
90e12fb978
commit
dc3b2b9439
1 changed files with 15 additions and 11 deletions
|
@ -8,8 +8,9 @@
|
||||||
struct wlr_content_type_v1_surface {
|
struct wlr_content_type_v1_surface {
|
||||||
struct wl_resource *resource;
|
struct wl_resource *resource;
|
||||||
struct wlr_addon addon;
|
struct wlr_addon addon;
|
||||||
struct wl_listener commit;
|
|
||||||
enum wp_content_type_v1_type pending, current;
|
enum wp_content_type_v1_type pending, current;
|
||||||
|
|
||||||
|
struct wlr_surface_synced synced;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void resource_handle_destroy(struct wl_client *client,
|
static void resource_handle_destroy(struct wl_client *client,
|
||||||
|
@ -56,7 +57,7 @@ static void content_type_surface_destroy(
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
wlr_addon_finish(&content_type_surface->addon);
|
wlr_addon_finish(&content_type_surface->addon);
|
||||||
wl_list_remove(&content_type_surface->commit.link);
|
wlr_surface_synced_finish(&content_type_surface->synced);
|
||||||
wl_resource_set_user_data(content_type_surface->resource, NULL);
|
wl_resource_set_user_data(content_type_surface->resource, NULL);
|
||||||
free(content_type_surface);
|
free(content_type_surface);
|
||||||
}
|
}
|
||||||
|
@ -72,12 +73,9 @@ static const struct wlr_addon_interface surface_addon_impl = {
|
||||||
.destroy = surface_addon_destroy,
|
.destroy = surface_addon_destroy,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void content_type_surface_handle_commit(struct wl_listener *listener,
|
static const struct wlr_surface_synced_impl surface_synced_impl = {
|
||||||
void *data) {
|
.state_size = sizeof(enum wp_content_type_v1_type),
|
||||||
struct wlr_content_type_v1_surface *content_type_surface =
|
};
|
||||||
wl_container_of(listener, content_type_surface, commit);
|
|
||||||
content_type_surface->current = content_type_surface->pending;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void content_type_surface_handle_resource_destroy(
|
static void content_type_surface_handle_resource_destroy(
|
||||||
struct wl_resource *resource) {
|
struct wl_resource *resource) {
|
||||||
|
@ -107,10 +105,19 @@ static void manager_handle_get_surface_content_type(struct wl_client *client,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!wlr_surface_synced_init(&content_type_surface->synced, surface,
|
||||||
|
&surface_synced_impl, &content_type_surface->pending,
|
||||||
|
&content_type_surface->current)) {
|
||||||
|
free(content_type_surface);
|
||||||
|
wl_resource_post_no_memory(manager_resource);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t version = wl_resource_get_version(manager_resource);
|
uint32_t version = wl_resource_get_version(manager_resource);
|
||||||
content_type_surface->resource = wl_resource_create(client,
|
content_type_surface->resource = wl_resource_create(client,
|
||||||
&wp_content_type_v1_interface, version, id);
|
&wp_content_type_v1_interface, version, id);
|
||||||
if (content_type_surface->resource == NULL) {
|
if (content_type_surface->resource == NULL) {
|
||||||
|
wlr_surface_synced_finish(&content_type_surface->synced);
|
||||||
free(content_type_surface);
|
free(content_type_surface);
|
||||||
wl_resource_post_no_memory(manager_resource);
|
wl_resource_post_no_memory(manager_resource);
|
||||||
return;
|
return;
|
||||||
|
@ -121,9 +128,6 @@ static void manager_handle_get_surface_content_type(struct wl_client *client,
|
||||||
|
|
||||||
wlr_addon_init(&content_type_surface->addon, &surface->addons,
|
wlr_addon_init(&content_type_surface->addon, &surface->addons,
|
||||||
manager, &surface_addon_impl);
|
manager, &surface_addon_impl);
|
||||||
|
|
||||||
content_type_surface->commit.notify = content_type_surface_handle_commit;
|
|
||||||
wl_signal_add(&surface->events.destroy, &content_type_surface->commit);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct wp_content_type_manager_v1_interface manager_impl = {
|
static const struct wp_content_type_manager_v1_interface manager_impl = {
|
||||||
|
|
Loading…
Reference in a new issue