fix decorations

This commit is contained in:
2026-04-21 19:05:37 +07:00
parent 06059f923b
commit 30dbaced7a
3 changed files with 426 additions and 18 deletions
+12 -12
View File
@@ -17,22 +17,22 @@ void xdg_toplevel_commit(struct wl_listener *listener, void *data)
int32_t borders_width = 2 * toplevel->border_width;
if (toplevel->toplevel.xdg->base->initial_commit) {
/* Forse server side decoration mode */
if (toplevel->decoration)
xdg_decoration_request_mode(&toplevel->decoration_request_mode, toplevel->decoration);
/* Let toplevel set preferred size */
wlr_xdg_toplevel_set_size(toplevel->toplevel.xdg, 0, 0);
toplevel->geometry.width = toplevel->toplevel.xdg->base->geometry.width + borders_width;
toplevel->geometry.height = toplevel->toplevel.xdg->base->geometry.height + borders_width;
} else {
/* Check for size because we did't set it on initial commit */
toplevel->geometry.width = toplevel->toplevel.xdg->base->geometry.width + borders_width;
toplevel->geometry.height = toplevel->toplevel.xdg->base->geometry.height + borders_width;
/* Update borders and position only after client prepared new buffer */
absinthe_toplevel_set_position(toplevel, toplevel->geometry.x, toplevel->geometry.y);
absinthe_toplevel_update_borders_geometry(toplevel);
toplevel->performing_resize = false;
/* Forse server side decoration mode */
if (toplevel->decoration)
xdg_decoration_request_mode(&toplevel->decoration_request_mode, toplevel->decoration);
return;
}
/* Check for size because we did't set it on initial commit */
toplevel->geometry.width = toplevel->toplevel.xdg->base->geometry.width + borders_width;
toplevel->geometry.height = toplevel->toplevel.xdg->base->geometry.height + borders_width;
/* Update borders and position only after client prepared new buffer */
absinthe_toplevel_set_position(toplevel, toplevel->geometry.x, toplevel->geometry.y);
absinthe_toplevel_update_borders_geometry(toplevel);
toplevel->performing_resize = false;
}