diff options
| author | Drew DeVault <[email protected]> | 2018-08-27 13:44:08 -0400 | 
|---|---|---|
| committer | GitHub <[email protected]> | 2018-08-27 13:44:08 -0400 | 
| commit | 98ef29c22878c256dea5b4f0d1eaf556bfcb145f (patch) | |
| tree | 4e6db1e7ea1edf864c700b2c110b3388f2bdf1e1 | |
| parent | 82423b88b8c3d6a34e883a840db1bfe2fefc9932 (diff) | |
| parent | 11c1619f300f076adaa55aa54f996a59f8dada67 (diff) | |
Merge pull request #2523 from RedSoxFan/fix-floating-drag-outputs
Stop floaters from snapping on move to new output
| -rw-r--r-- | sway/tree/arrange.c | 22 | 
1 files changed, 12 insertions, 10 deletions
| diff --git a/sway/tree/arrange.c b/sway/tree/arrange.c index 60e5b951..8d67116a 100644 --- a/sway/tree/arrange.c +++ b/sway/tree/arrange.c @@ -216,16 +216,18 @@ static void arrange_workspace(struct sway_container *workspace) {  	// Adjust any floating containers  	double diff_x = workspace->x - prev_x;  	double diff_y = workspace->y - prev_y; -	for (int i = 0; i < workspace->sway_workspace->floating->length; ++i) { -		struct sway_container *floater = -			workspace->sway_workspace->floating->items[i]; -		container_floating_translate(floater, diff_x, diff_y); -		double center_x = floater->x + floater->width / 2; -		double center_y = floater->y + floater->height / 2; -		struct wlr_box workspace_box; -		container_get_box(workspace, &workspace_box); -		if (!wlr_box_contains_point(&workspace_box, center_x, center_y)) { -			container_floating_move_to_center(floater); +	if (diff_x != 0 || diff_y != 0) { +		for (int i = 0; i < workspace->sway_workspace->floating->length; ++i) { +			struct sway_container *floater = +				workspace->sway_workspace->floating->items[i]; +			container_floating_translate(floater, diff_x, diff_y); +			double center_x = floater->x + floater->width / 2; +			double center_y = floater->y + floater->height / 2; +			struct wlr_box workspace_box; +			container_get_box(workspace, &workspace_box); +			if (!wlr_box_contains_point(&workspace_box, center_x, center_y)) { +				container_floating_move_to_center(floater); +			}  		}  	} | 
