diff options
author | Christian Hergert <chergert@redhat.com> | 2021-02-19 15:34:18 -0800 |
---|---|---|
committer | Christian Hergert <chergert@redhat.com> | 2021-02-19 15:43:49 -0800 |
commit | ea0d487f0ba7bae8a1d9442bae8cdbc623638fbc (patch) | |
tree | c58df41a59419cfcca1209c7e1c63096fc90ceef /gdk/macos | |
parent | 5797c72e9c2c17b52c4f7969eae0994636babba6 (diff) | |
download | gtk+-ea0d487f0ba7bae8a1d9442bae8cdbc623638fbc.tar.gz |
macos: fix resizing of resizable windows on macOS
Diffstat (limited to 'gdk/macos')
-rw-r--r-- | gdk/macos/gdkmacostoplevelsurface-private.h | 5 | ||||
-rw-r--r-- | gdk/macos/gdkmacostoplevelsurface.c | 24 |
2 files changed, 18 insertions, 11 deletions
diff --git a/gdk/macos/gdkmacostoplevelsurface-private.h b/gdk/macos/gdkmacostoplevelsurface-private.h index 8d3ec15b02..b0bddfa0c1 100644 --- a/gdk/macos/gdkmacostoplevelsurface-private.h +++ b/gdk/macos/gdkmacostoplevelsurface-private.h @@ -33,8 +33,9 @@ typedef struct _GdkMacosToplevelSurfaceClass GdkMacosToplevelSurfaceClass; struct _GdkMacosToplevelSurface { - GdkMacosSurface parent_instance; - guint decorated : 1; + GdkMacosSurface parent_instance; + GdkToplevelLayout *layout; + guint decorated : 1; }; struct _GdkMacosToplevelSurfaceClass diff --git a/gdk/macos/gdkmacostoplevelsurface.c b/gdk/macos/gdkmacostoplevelsurface.c index 5bce4101df..947d0b20d2 100644 --- a/gdk/macos/gdkmacostoplevelsurface.c +++ b/gdk/macos/gdkmacostoplevelsurface.c @@ -102,6 +102,12 @@ _gdk_macos_toplevel_surface_present (GdkToplevel *toplevel, g_assert (GDK_IS_MACOS_TOPLEVEL_SURFACE (self)); g_assert (GDK_IS_MACOS_WINDOW (nswindow)); + if (layout != self->layout) + { + g_clear_pointer (&self->layout, gdk_toplevel_layout_unref); + self->layout = gdk_toplevel_layout_copy (layout); + } + _gdk_macos_toplevel_surface_attach_to_parent (self); style_mask = [nswindow styleMask]; @@ -374,7 +380,6 @@ static gboolean _gdk_macos_toplevel_surface_compute_size (GdkSurface *surface) { GdkMacosToplevelSurface *self = (GdkMacosToplevelSurface *)surface; - NSWindow *nswindow = _gdk_macos_surface_get_native (GDK_MACOS_SURFACE (self)); GdkToplevelSize size; GdkDisplay *display; GdkMonitor *monitor; @@ -382,7 +387,6 @@ _gdk_macos_toplevel_surface_compute_size (GdkSurface *surface) int width, height; GdkGeometry geometry; GdkSurfaceHints mask; - NSWindowStyleMask style_mask; g_assert (GDK_IS_MACOS_TOPLEVEL_SURFACE (self)); @@ -393,7 +397,6 @@ _gdk_macos_toplevel_surface_compute_size (GdkSurface *surface) display = gdk_surface_get_display (surface); monitor = gdk_display_get_monitor_at_surface (display, surface); - style_mask = [nswindow styleMask]; if (monitor) { @@ -415,10 +418,11 @@ _gdk_macos_toplevel_surface_compute_size (GdkSurface *surface) g_warn_if_fail (size.width > 0); g_warn_if_fail (size.height > 0); - width = size.width; - height = size.height; + width = surface->width; + height = surface->height; - if (style_mask & NSWindowStyleMaskResizable) + if (self->layout != NULL && + gdk_toplevel_layout_get_resizable (self->layout)) { geometry.min_width = size.min_width; geometry.min_height = size.min_height; @@ -426,8 +430,8 @@ _gdk_macos_toplevel_surface_compute_size (GdkSurface *surface) } else { - geometry.max_width = geometry.min_width = width; - geometry.max_height = geometry.min_height = height; + geometry.max_width = geometry.min_width = size.width; + geometry.max_height = geometry.min_height = size.height; mask = GDK_HINT_MIN_SIZE | GDK_HINT_MAX_SIZE; } @@ -438,8 +442,9 @@ _gdk_macos_toplevel_surface_compute_size (GdkSurface *surface) size.shadow.bottom, size.shadow.left); - _gdk_macos_surface_set_geometry_hints (GDK_MACOS_SURFACE (self), &geometry, mask); gdk_surface_constrain_size (&geometry, mask, width, height, &width, &height); + + _gdk_macos_surface_set_geometry_hints (GDK_MACOS_SURFACE (self), &geometry, mask); _gdk_macos_surface_resize (GDK_MACOS_SURFACE (self), width, height); return FALSE; @@ -458,6 +463,7 @@ _gdk_macos_toplevel_surface_destroy (GdkSurface *surface, GdkMacosToplevelSurface *self = (GdkMacosToplevelSurface *)surface; g_clear_object (&GDK_SURFACE (self)->transient_for); + g_clear_pointer (&self->layout, gdk_toplevel_layout_unref); GDK_SURFACE_CLASS (_gdk_macos_toplevel_surface_parent_class)->destroy (surface, foreign_destroy); } |