diff options
| author | Furkan Sahin <furkan-dev@proton.me> | 2023-07-15 22:44:10 -0500 |
|---|---|---|
| committer | Furkan Sahin <furkan-dev@proton.me> | 2023-07-15 22:44:10 -0500 |
| commit | 7bbcf20ded00b4d661fe6a4843cdeb230873018a (patch) | |
| tree | 558cb67e819842f5b311b005884738e3ddca69f5 | |
| parent | 64be9625ed66bce2ae00da185de157696e4d4237 (diff) | |
view: update wlr_toplevel size on client resizes
If a floating client resizes itself, sway updates several of its
internal dimensions to match but not wlr_toplevel. This means that the
next time wlroots sends a toplevel configure event, it can have wrong
coordinates that resize the client back to its old size. To fix this,
let's just use wlr_xdg_toplevel_set_size so the wlr_toplevel has the
same dimensions as sway. Fixes #5266.
| -rw-r--r-- | sway/tree/view.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/sway/tree/view.c b/sway/tree/view.c index ec54fed8..8cc94a05 100644 --- a/sway/tree/view.c +++ b/sway/tree/view.c @@ -931,6 +931,11 @@ void view_update_size(struct sway_view *view) { con->pending.content_width = view->geometry.width; con->pending.content_height = view->geometry.height; container_set_geometry_from_content(con); + + // Update the next scheduled width/height so correct coordinates + // are sent on the next toplevel configure from wlroots. + wlr_xdg_toplevel_set_size(view->wlr_xdg_toplevel, view->geometry.width, + view->geometry.height); } void view_center_surface(struct sway_view *view) { |
