forked from AuroraMiddleware/gtk
inspector: Make updates overlay not crash
... when a window gets hidden and later reshown. The code now properly cleans up a window when it gets unmapped instead of trying to retain previous updates information.
This commit is contained in:
parent
c50052e223
commit
0cd8dd4294
@ -67,17 +67,6 @@ gtk_update_free (gpointer data)
|
|||||||
g_slice_free (GtkUpdate, region);
|
g_slice_free (GtkUpdate, region);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
gtk_widget_updates_release_widget (GtkWidgetUpdates *updates)
|
|
||||||
{
|
|
||||||
g_assert (updates->widget);
|
|
||||||
g_signal_handler_disconnect (updates->widget, updates->unmap_callback);
|
|
||||||
if (updates->tick_callback)
|
|
||||||
gtk_widget_remove_tick_callback (updates->widget, updates->tick_callback);
|
|
||||||
updates->tick_callback = 0;
|
|
||||||
updates->widget = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtk_widget_updates_free (gpointer data)
|
gtk_widget_updates_free (gpointer data)
|
||||||
{
|
{
|
||||||
@ -85,12 +74,21 @@ gtk_widget_updates_free (gpointer data)
|
|||||||
|
|
||||||
g_queue_free_full (updates->updates, gtk_update_free);
|
g_queue_free_full (updates->updates, gtk_update_free);
|
||||||
g_clear_pointer (&updates->last, gsk_render_node_unref);
|
g_clear_pointer (&updates->last, gsk_render_node_unref);
|
||||||
if (updates->widget)
|
g_signal_handler_disconnect (updates->widget, updates->unmap_callback);
|
||||||
gtk_widget_updates_release_widget (updates);
|
if (updates->tick_callback)
|
||||||
|
gtk_widget_remove_tick_callback (updates->widget, updates->tick_callback);
|
||||||
|
updates->tick_callback = 0;
|
||||||
|
|
||||||
g_slice_free (GtkWidgetUpdates, updates);
|
g_slice_free (GtkWidgetUpdates, updates);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gtk_widget_updates_unmap_widget (GtkWidget *widget,
|
||||||
|
GtkUpdatesOverlay *self)
|
||||||
|
{
|
||||||
|
g_hash_table_remove (self->toplevels, widget);
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gtk_widget_updates_tick (GtkWidget *widget,
|
gtk_widget_updates_tick (GtkWidget *widget,
|
||||||
GdkFrameClock *clock,
|
GdkFrameClock *clock,
|
||||||
@ -135,7 +133,7 @@ gtk_update_overlay_lookup_for_widget (GtkUpdatesOverlay *self,
|
|||||||
updates = g_slice_new0 (GtkWidgetUpdates);
|
updates = g_slice_new0 (GtkWidgetUpdates);
|
||||||
updates->updates = g_queue_new ();
|
updates->updates = g_queue_new ();
|
||||||
updates->widget = widget;
|
updates->widget = widget;
|
||||||
updates->unmap_callback = g_signal_connect_swapped (widget, "unmap", G_CALLBACK (gtk_widget_updates_release_widget), updates);
|
updates->unmap_callback = g_signal_connect (widget, "unmap", G_CALLBACK (gtk_widget_updates_unmap_widget), self);
|
||||||
|
|
||||||
g_hash_table_insert (self->toplevels, g_object_ref (widget), updates);
|
g_hash_table_insert (self->toplevels, g_object_ref (widget), updates);
|
||||||
return updates;
|
return updates;
|
||||||
@ -269,7 +267,7 @@ gtk_updates_overlay_class_init (GtkUpdatesOverlayClass *klass)
|
|||||||
static void
|
static void
|
||||||
gtk_updates_overlay_init (GtkUpdatesOverlay *self)
|
gtk_updates_overlay_init (GtkUpdatesOverlay *self)
|
||||||
{
|
{
|
||||||
self->toplevels = g_hash_table_new_full (g_direct_hash, g_direct_equal, NULL, gtk_widget_updates_free);
|
self->toplevels = g_hash_table_new_full (g_direct_hash, g_direct_equal, g_object_unref, gtk_widget_updates_free);
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkInspectorOverlay *
|
GtkInspectorOverlay *
|
||||||
|
Loading…
Reference in New Issue
Block a user