mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2024-11-22 04:45:58 +01:00
types/wlr_xdg_output_v1: Fix wl_output.done bug.
If the client binds to version 3 of zxdg_output_v1 and version 1 of wl_output no wl_output.done or zxdg_output_v1.done event is emitted [1]. Also no wl_output.done event is emitted when version 2 or lower of zxdg_output_v1 is bound to. Add a version check to output_manager_handle_get_xdg_output so that no wl_output.done event is emitted when using version 1 of wl_output and version 2 or lower of zxdg_output_v1. [1]: https://gitlab.freedesktop.org/wayland/wayland-protocols/-/issues/81
This commit is contained in:
parent
346e524201
commit
9ab819684d
1 changed files with 8 additions and 4 deletions
|
@ -127,11 +127,11 @@ static void output_manager_handle_get_xdg_output(struct wl_client *client,
|
||||||
wl_resource_get_link(xdg_output_resource));
|
wl_resource_get_link(xdg_output_resource));
|
||||||
|
|
||||||
// Name and description should only be sent once per output
|
// Name and description should only be sent once per output
|
||||||
uint32_t version = wl_resource_get_version(xdg_output_resource);
|
uint32_t xdg_version = wl_resource_get_version(xdg_output_resource);
|
||||||
if (version >= ZXDG_OUTPUT_V1_NAME_SINCE_VERSION) {
|
if (xdg_version >= ZXDG_OUTPUT_V1_NAME_SINCE_VERSION) {
|
||||||
zxdg_output_v1_send_name(xdg_output_resource, output->name);
|
zxdg_output_v1_send_name(xdg_output_resource, output->name);
|
||||||
}
|
}
|
||||||
if (version >= ZXDG_OUTPUT_V1_DESCRIPTION_SINCE_VERSION &&
|
if (xdg_version >= ZXDG_OUTPUT_V1_DESCRIPTION_SINCE_VERSION &&
|
||||||
output->description != NULL) {
|
output->description != NULL) {
|
||||||
zxdg_output_v1_send_description(xdg_output_resource,
|
zxdg_output_v1_send_description(xdg_output_resource,
|
||||||
output->description);
|
output->description);
|
||||||
|
@ -139,7 +139,11 @@ static void output_manager_handle_get_xdg_output(struct wl_client *client,
|
||||||
|
|
||||||
output_send_details(xdg_output, xdg_output_resource);
|
output_send_details(xdg_output, xdg_output_resource);
|
||||||
|
|
||||||
wl_output_send_done(output_resource);
|
uint32_t wl_version = wl_resource_get_version(output_resource);
|
||||||
|
if (wl_version >= WL_OUTPUT_DONE_SINCE_VERSION &&
|
||||||
|
xdg_version >= OUTPUT_DONE_DEPRECATED_SINCE_VERSION) {
|
||||||
|
wl_output_send_done(output_resource);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct zxdg_output_manager_v1_interface
|
static const struct zxdg_output_manager_v1_interface
|
||||||
|
|
Loading…
Reference in a new issue