diff options
| author | Kenny Levinsen <kl@kl.wtf> | 2021-02-08 01:05:51 +0100 | 
|---|---|---|
| committer | Simon Ser <contact@emersion.fr> | 2021-02-09 09:37:10 +0100 | 
| commit | 90fa6953ea84477c09cb57fd60ded2bb0e33414d (patch) | |
| tree | 06be6b3e9f89033bbef9d3ef3092eae739e538ef /sway/desktop | |
| parent | 50205ade9d7b3d4c014fce5364db329c29acfa86 (diff) | |
| download | sway-90fa6953ea84477c09cb57fd60ded2bb0e33414d.tar.xz | |
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')
| -rw-r--r-- | sway/desktop/xdg_shell.c | 11 | ||||
| -rw-r--r-- | sway/desktop/xwayland.c | 23 | 
2 files changed, 20 insertions, 14 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); diff --git a/sway/desktop/xwayland.c b/sway/desktop/xwayland.c index e1a2e463..be9503e5 100644 --- a/sway/desktop/xwayland.c +++ b/sway/desktop/xwayland.c @@ -406,22 +406,25 @@ static void handle_commit(struct wl_listener *listener, void *data) {  	} else {  		struct wlr_box new_geo;  		get_geometry(view, &new_geo); +		bool new_size = new_geo.width != view->geometry.width || +				new_geo.height != view->geometry.height || +				new_geo.x != view->geometry.x || +				new_geo.y != view->geometry.y; -		if ((new_geo.width != view->geometry.width || -					new_geo.height != view->geometry.height || -					new_geo.x != view->geometry.x || -					new_geo.y != view->geometry.y)) { +		if (new_size) {  			// The view has unexpectedly sent a new size  			// eg. The Firefox "Save As" dialog when downloading a file  			desktop_damage_view(view); -			view_update_size(view, new_geo.width, new_geo.height);  			memcpy(&view->geometry, &new_geo, sizeof(struct wlr_box)); -			desktop_damage_view(view); -			transaction_commit_dirty(); -			transaction_notify_view_ready_by_geometry(view, +			if (container_is_floating(view->container)) { +				view_update_size(view, new_geo.width, new_geo.height); +				transaction_commit_dirty(); +				transaction_notify_view_ready_by_geometry(view,  					xsurface->x, xsurface->y, new_geo.width, new_geo.height); -		} else { -			memcpy(&view->geometry, &new_geo, sizeof(struct wlr_box)); +			} else { +				view_center_surface(view); +			} +			desktop_damage_view(view);  		}  	} | 
