summaryrefslogtreecommitdiff
path: root/sway/desktop/xdg_shell.c
diff options
context:
space:
mode:
authorKenny Levinsen <[email protected]>2021-02-08 01:05:51 +0100
committerSimon Ser <[email protected]>2021-02-09 09:37:10 +0100
commit90fa6953ea84477c09cb57fd60ded2bb0e33414d (patch)
tree06be6b3e9f89033bbef9d3ef3092eae739e538ef /sway/desktop/xdg_shell.c
parent50205ade9d7b3d4c014fce5364db329c29acfa86 (diff)
shells: Only center tiled views on size change
The size of a tiled container cannot change in response to new buffer sizes, so there is no need to commit a new transaction. Instead, simply recenter the view with the new geometry, leaving the full transaction flow for floating containers.
Diffstat (limited to 'sway/desktop/xdg_shell.c')
-rw-r--r--sway/desktop/xdg_shell.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/sway/desktop/xdg_shell.c b/sway/desktop/xdg_shell.c
index 667fb9e5..cbf16662 100644
--- a/sway/desktop/xdg_shell.c
+++ b/sway/desktop/xdg_shell.c
@@ -295,17 +295,20 @@ static void handle_commit(struct wl_listener *listener, void *data) {
if (new_size) {
// The view has unexpectedly sent a new size
desktop_damage_view(view);
- view_update_size(view, new_geo.width, new_geo.height);
memcpy(&view->geometry, &new_geo, sizeof(struct wlr_box));
+ if (container_is_floating(view->container)) {
+ view_update_size(view, new_geo.width, new_geo.height);
+ transaction_commit_dirty();
+ transaction_notify_view_ready_immediately(view);
+ } else {
+ view_center_surface(view);
+ }
desktop_damage_view(view);
- transaction_commit_dirty();
}
if (view->container->node.instruction) {
transaction_notify_view_ready_by_serial(view,
xdg_surface->configure_serial);
- } else if (new_size) {
- transaction_notify_view_ready_immediately(view);
}
view_damage_from(view);