[mutter] window-props: Check for actual size hints changes
- From: Jonas Ådahl <jadahl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter] window-props: Check for actual size hints changes
- Date: Mon, 19 Oct 2020 09:47:26 +0000 (UTC)
commit deaa9480a84938cc0120e433fa9f3607acdfa29c
Author: Olivier Fourdan <ofourdan redhat com>
Date: Thu Oct 15 14:23:41 2020 +0200
window-props: Check for actual size hints changes
The XSizeHints set by X11 clients give a hint to the window manager
about size increment, aspect ratio, base, minimum and maximum size, etc.
When an X11 client changes those values, there is a good chance that it
will affect the actual window size in some way, and mutter rightfully
queue a window resize in that case.
However, mutter does not check if any of the hints have actually changed
and unconditionally queue a window resize whenever a client changes its
WM_NORMAL_HINTS property.
That can be a problem when a zealous client such as xterm decides to
update its WM_NORMAL_HINTS property on resize, because in return mutter
will queue a non-user driven resize in the middle of user-driven events,
hence defeating the purpose of the META_MOVE_RESIZE_USER_ACTION flag.
To avoid that issue, make mutter a bit smarter and avoid queuing a
window resize if the XSizeHints haven't actually changed.
https://gitlab.gnome.org/GNOME/mutter/-/issues/543
src/x11/window-props.c | 31 ++++++++++++++++++++++++++-----
1 file changed, 26 insertions(+), 5 deletions(-)
---
diff --git a/src/x11/window-props.c b/src/x11/window-props.c
index d0ef19f799..ab3cae89ae 100644
--- a/src/x11/window-props.c
+++ b/src/x11/window-props.c
@@ -1140,6 +1140,22 @@ spew_size_hints_differences (const XSizeHints *old,
old->win_gravity, new->win_gravity);
}
+static gboolean
+hints_have_changed (const XSizeHints *old,
+ const XSizeHints *new)
+{
+ return FLAG_CHANGED (old, new, USPosition) ||
+ FLAG_CHANGED (old, new, USSize) ||
+ FLAG_CHANGED (old, new, PPosition) ||
+ FLAG_CHANGED (old, new, PSize) ||
+ FLAG_CHANGED (old, new, PMinSize) ||
+ FLAG_CHANGED (old, new, PMaxSize) ||
+ FLAG_CHANGED (old, new, PResizeInc) ||
+ FLAG_CHANGED (old, new, PAspect) ||
+ FLAG_CHANGED (old, new, PBaseSize) ||
+ FLAG_CHANGED (old, new, PWinGravity);
+}
+
void
meta_set_normal_hints (MetaWindow *window,
XSizeHints *hints)
@@ -1490,6 +1506,7 @@ reload_normal_hints (MetaWindow *window,
if (value->type != META_PROP_VALUE_INVALID)
{
XSizeHints old_hints;
+ gboolean hints_have_differences;
meta_topic (META_DEBUG_GEOMETRY, "Updating WM_NORMAL_HINTS for %s", window->desc);
@@ -1497,12 +1514,16 @@ reload_normal_hints (MetaWindow *window,
meta_set_normal_hints (window, value->v.size_hints.hints);
- spew_size_hints_differences (&old_hints, &window->size_hints);
-
- meta_window_recalc_features (window);
+ hints_have_differences = hints_have_changed (&old_hints,
+ &window->size_hints);
+ if (hints_have_differences)
+ {
+ spew_size_hints_differences (&old_hints, &window->size_hints);
+ meta_window_recalc_features (window);
- if (!initial)
- meta_window_queue(window, META_QUEUE_MOVE_RESIZE);
+ if (!initial)
+ meta_window_queue (window, META_QUEUE_MOVE_RESIZE);
+ }
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]