The current widget lookup code bails out on insensitive widgets, there's
however legit cases where we want DnD handled by a parent of the insensitive
widget, so just keep going upwards in that case.
We also use now the widget state flags, because get_sensitive() doesn't
propagate across hierarchies, so we could conceivably find a drop site
inside an insensitive widget.
https://bugzilla.gnome.org/show_bug.cgi?id=751793
GList *hierarchy = NULL;
gboolean found = FALSE;
- if (!gtk_widget_get_mapped (widget) ||
- !gtk_widget_get_sensitive (widget))
+ if (!gtk_widget_get_mapped (widget))
return FALSE;
+ if (gtk_widget_get_state_flags (widget) & GTK_STATE_FLAG_INSENSITIVE)
+ {
+ widget = gtk_widget_get_parent (widget);
+ continue;
+ }
+
/* need to reference the entire hierarchy temporarily in case the
* ::drag-motion/::drag-drop callbacks change the widget hierarchy.
*/