[mutter/wip/rstrode/rhel-8.0.0: 30/117] window: unmanage dialog when clearing transient_for
- From: Ray Strode <halfline src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/wip/rstrode/rhel-8.0.0: 30/117] window: unmanage dialog when clearing transient_for
- Date: Sun, 17 Feb 2019 17:25:21 +0000 (UTC)
commit 3712f8c99d9da93f01e0d1415ea3ab158ed6a813
Author: Olivier Fourdan <ofourdan redhat com>
Date: Tue Jul 10 14:42:42 2018 +0000
window: unmanage dialog when clearing transient_for
On Wayland, xdg-foreign would leave a modal dialog managed even after
the imported surface is destroyed.
This is sub-optimal and this breaks the atomic relationship one would
expect between the parent and its modal dialog.
Make sure we unmanage the dialog if transient_for is unset even for
Wayland native windows.
Related: https://gitlab.gnome.org/GNOME/mutter/issues/174
Related: https://gitlab.gnome.org/GNOME/mutter/issues/221
(cherry picked from commit b443bd42ac738092817addf48e0b363d140cad26)
src/core/window.c | 8 ++++++++
1 file changed, 8 insertions(+)
---
diff --git a/src/core/window.c b/src/core/window.c
index e68f5245c..a1f4aa4f3 100644
--- a/src/core/window.c
+++ b/src/core/window.c
@@ -7942,7 +7942,15 @@ meta_window_set_transient_for (MetaWindow *window,
}
}
}
+ else if (window->attached && parent == NULL)
+ {
+ guint32 timestamp;
+ timestamp =
+ meta_display_get_current_time_roundtrip (window->display);
+ meta_window_unmanage (window, timestamp);
+ return;
+ }
/* We know this won't create a reference cycle because we check for loops */
g_clear_object (&window->transient_for);
window->transient_for = parent ? g_object_ref (parent) : NULL;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]