|
|
@ -234,11 +234,21 @@ void create_xdg_popup(struct wlr_xdg_surface *xdg_surface,
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (xdg_surface->role != WLR_XDG_SURFACE_ROLE_NONE) {
|
|
|
|
|
|
|
|
wl_resource_post_error(xdg_surface->resource,
|
|
|
|
|
|
|
|
XDG_SURFACE_ERROR_ALREADY_CONSTRUCTED,
|
|
|
|
|
|
|
|
"xdg-surface has already been constructed");
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (xdg_surface->popup == NULL) {
|
|
|
|
xdg_surface->popup = calloc(1, sizeof(struct wlr_xdg_popup));
|
|
|
|
xdg_surface->popup = calloc(1, sizeof(struct wlr_xdg_popup));
|
|
|
|
if (!xdg_surface->popup) {
|
|
|
|
if (!xdg_surface->popup) {
|
|
|
|
wl_resource_post_no_memory(xdg_surface->resource);
|
|
|
|
wl_resource_post_no_memory(xdg_surface->resource);
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
xdg_surface->popup->base = xdg_surface;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
xdg_surface->popup->resource = wl_resource_create(
|
|
|
|
xdg_surface->popup->resource = wl_resource_create(
|
|
|
|
xdg_surface->client->client, &xdg_popup_interface,
|
|
|
|
xdg_surface->client->client, &xdg_popup_interface,
|
|
|
@ -253,7 +263,6 @@ void create_xdg_popup(struct wlr_xdg_surface *xdg_surface,
|
|
|
|
xdg_popup_handle_resource_destroy);
|
|
|
|
xdg_popup_handle_resource_destroy);
|
|
|
|
|
|
|
|
|
|
|
|
xdg_surface->role = WLR_XDG_SURFACE_ROLE_POPUP;
|
|
|
|
xdg_surface->role = WLR_XDG_SURFACE_ROLE_POPUP;
|
|
|
|
xdg_surface->popup->base = xdg_surface;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// positioner properties
|
|
|
|
// positioner properties
|
|
|
|
memcpy(&xdg_surface->popup->positioner, &positioner->attrs,
|
|
|
|
memcpy(&xdg_surface->popup->positioner, &positioner->attrs,
|
|
|
@ -265,19 +274,24 @@ void create_xdg_popup(struct wlr_xdg_surface *xdg_surface,
|
|
|
|
xdg_surface->popup->parent = parent->surface;
|
|
|
|
xdg_surface->popup->parent = parent->surface;
|
|
|
|
wl_list_insert(&parent->popups, &xdg_surface->popup->link);
|
|
|
|
wl_list_insert(&parent->popups, &xdg_surface->popup->link);
|
|
|
|
wlr_signal_emit_safe(&parent->events.new_popup, xdg_surface->popup);
|
|
|
|
wlr_signal_emit_safe(&parent->events.new_popup, xdg_surface->popup);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
wl_list_init(&xdg_surface->popup->link);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void destroy_xdg_popup(struct wlr_xdg_surface *surface) {
|
|
|
|
void destroy_xdg_popup(struct wlr_xdg_surface *xdg_surface) {
|
|
|
|
assert(surface->role == WLR_XDG_SURFACE_ROLE_POPUP);
|
|
|
|
assert(xdg_surface->role == WLR_XDG_SURFACE_ROLE_POPUP);
|
|
|
|
unmap_xdg_surface(surface);
|
|
|
|
unmap_xdg_surface(xdg_surface);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Don't destroy the popup state yet, the compositor might have some
|
|
|
|
|
|
|
|
// listeners set up. Anyway the client can only re-create another xdg-popup
|
|
|
|
|
|
|
|
// with this xdg-surface because of role restrictions.
|
|
|
|
|
|
|
|
wl_resource_set_user_data(xdg_surface->popup->resource, NULL);
|
|
|
|
|
|
|
|
xdg_surface->toplevel->resource = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
wl_resource_set_user_data(surface->popup->resource, NULL);
|
|
|
|
wl_list_remove(&xdg_surface->popup->link);
|
|
|
|
wl_list_remove(&surface->popup->link);
|
|
|
|
|
|
|
|
free(surface->popup);
|
|
|
|
|
|
|
|
surface->popup = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
surface->role = WLR_XDG_SURFACE_ROLE_NONE;
|
|
|
|
xdg_surface->role = WLR_XDG_SURFACE_ROLE_NONE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void wlr_xdg_popup_get_anchor_point(struct wlr_xdg_popup *popup,
|
|
|
|
void wlr_xdg_popup_get_anchor_point(struct wlr_xdg_popup *popup,
|
|
|
|