sway

i3-compatible Wayland compositor
git clone https://git.awy.one/sway
Log | Files | Refs | README | LICENSE

commit 3b1db30a5e5758ec099b79250681cbf4be5ae0e9
parent 4371c746e4d46c866ba4cdac2b3fba63a8de762e
Author: Ryan Dwyer <ryandwyer1@gmail.com>
Date:   Sat, 26 May 2018 20:37:04 +1000

Use surface size if xdg shell's geometry isn't set

Diffstat:
Msway/desktop/xdg_shell.c | 13+++++++++----
Msway/desktop/xdg_shell_v6.c | 13+++++++++----
2 files changed, 18 insertions(+), 8 deletions(-)

diff --git a/sway/desktop/xdg_shell.c b/sway/desktop/xdg_shell.c @@ -182,13 +182,18 @@ static void handle_commit(struct wl_listener *listener, void *data) { struct sway_xdg_shell_view *xdg_shell_view = wl_container_of(listener, xdg_shell_view, commit); struct sway_view *view = &xdg_shell_view->view; - struct wlr_box *geometry = &view->wlr_xdg_surface->geometry; + int width = view->wlr_xdg_surface->geometry.width; + int height = view->wlr_xdg_surface->geometry.height; + if (!width && !height) { + width = view->wlr_xdg_surface->surface->current->width; + height = view->wlr_xdg_surface->surface->current->height; + } if (!view->natural_width && !view->natural_height) { - view->natural_width = geometry->width; - view->natural_height = geometry->height; + view->natural_width = width; + view->natural_height = height; } if (view->swayc && container_is_floating(view->swayc)) { - view_update_size(view, geometry->width, geometry->height); + view_update_size(view, width, height); } else { view_update_size(view, xdg_shell_view->pending_width, xdg_shell_view->pending_height); diff --git a/sway/desktop/xdg_shell_v6.c b/sway/desktop/xdg_shell_v6.c @@ -181,13 +181,18 @@ static void handle_commit(struct wl_listener *listener, void *data) { struct sway_xdg_shell_v6_view *xdg_shell_v6_view = wl_container_of(listener, xdg_shell_v6_view, commit); struct sway_view *view = &xdg_shell_v6_view->view; - struct wlr_box *geometry = &view->wlr_xdg_surface_v6->geometry; + int width = view->wlr_xdg_surface_v6->geometry.width; + int height = view->wlr_xdg_surface_v6->geometry.height; + if (!width && !height) { + width = view->wlr_xdg_surface_v6->surface->current->width; + height = view->wlr_xdg_surface_v6->surface->current->height; + } if (!view->natural_width && !view->natural_height) { - view->natural_width = geometry->width; - view->natural_height = geometry->height; + view->natural_width = width; + view->natural_height = height; } if (view->swayc && container_is_floating(view->swayc)) { - view_update_size(view, geometry->width, geometry->height); + view_update_size(view, width, height); } else { view_update_size(view, xdg_shell_v6_view->pending_width, xdg_shell_v6_view->pending_height);