summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Mikhaylenko <alexm@gnome.org>2021-02-18 13:41:41 +0500
committerAlexander Mikhaylenko <alexm@gnome.org>2021-02-18 13:41:41 +0500
commit8e2f90e342515cefa0c5825715e761a60503e970 (patch)
tree6a8371a0c5d268533b118d6ec769ba6404a26e5a
parent32c7ca50eafde6e762c2496b711168379e9f33fb (diff)
downloadgtk+-wip/exalm/root.tar.gz
widget: Don't assume GtkWindow root in gtk_widget_propagate_state()wip/exalm/root
Avoid crashes with GtkDragIcon children.
-rw-r--r--gtk/gtkwidget.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c
index 990d7c27ab..35a695e080 100644
--- a/gtk/gtkwidget.c
+++ b/gtk/gtkwidget.c
@@ -7748,16 +7748,22 @@ gtk_widget_propagate_state (GtkWidget *widget,
if (old_flags != new_flags)
{
- GtkWindowGroup *window_group;
GtkRoot *root;
- GtkWidget *grab;
+ GtkWidget *grab = NULL;
gboolean shadowed;
g_object_ref (widget);
root = gtk_widget_get_root (widget);
- window_group = gtk_window_get_group (GTK_WINDOW (root));
- grab = gtk_window_group_get_current_grab (window_group);
+
+ if (GTK_IS_WINDOW (root))
+ {
+ GtkWindowGroup *window_group;
+
+ window_group = gtk_window_get_group (GTK_WINDOW (root));
+ grab = gtk_window_group_get_current_grab (window_group);
+ }
+
shadowed = grab && grab != widget && !gtk_widget_is_ancestor (widget, grab);
if (!gtk_widget_is_sensitive (widget) && gtk_widget_has_grab (widget))