forked from AuroraMiddleware/gtk
treeview: Break reference cycles on unroot
It is a bad idea to have such cycles in the first place, and there is no need to let them linger past unroot. This stop the treeview depending on run_dispose to get freed, a simple unparent will work now.
This commit is contained in:
parent
329994291a
commit
d061bcad52
@ -644,6 +644,7 @@ static void gtk_tree_view_get_property (GObject *object,
|
||||
/* gtkwidget signals */
|
||||
static void gtk_tree_view_realize (GtkWidget *widget);
|
||||
static void gtk_tree_view_unrealize (GtkWidget *widget);
|
||||
static void gtk_tree_view_unroot (GtkWidget *widget);
|
||||
static void gtk_tree_view_map (GtkWidget *widget);
|
||||
static void gtk_tree_view_measure (GtkWidget *widget,
|
||||
GtkOrientation orientation,
|
||||
@ -1021,6 +1022,7 @@ gtk_tree_view_class_init (GtkTreeViewClass *class)
|
||||
widget_class->map = gtk_tree_view_map;
|
||||
widget_class->realize = gtk_tree_view_realize;
|
||||
widget_class->unrealize = gtk_tree_view_unrealize;
|
||||
widget_class->unroot = gtk_tree_view_unroot;
|
||||
widget_class->measure = gtk_tree_view_measure;
|
||||
widget_class->size_allocate = gtk_tree_view_size_allocate;
|
||||
widget_class->snapshot = gtk_tree_view_snapshot;
|
||||
@ -2311,6 +2313,19 @@ gtk_tree_view_unrealize (GtkWidget *widget)
|
||||
GTK_WIDGET_CLASS (gtk_tree_view_parent_class)->unrealize (widget);
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_tree_view_unroot (GtkWidget *widget)
|
||||
{
|
||||
GtkTreeView *tree_view = GTK_TREE_VIEW (widget);
|
||||
|
||||
/* break ref cycles */
|
||||
g_clear_pointer (&tree_view->scroll_to_path, gtk_tree_row_reference_free);
|
||||
g_clear_pointer (&tree_view->drag_dest_row, gtk_tree_row_reference_free);
|
||||
g_clear_pointer (&tree_view->top_row, gtk_tree_row_reference_free);
|
||||
|
||||
GTK_WIDGET_CLASS (gtk_tree_view_parent_class)->unroot (widget);
|
||||
}
|
||||
|
||||
/* GtkWidget::get_preferred_height helper */
|
||||
static void
|
||||
gtk_tree_view_update_height (GtkTreeView *tree_view)
|
||||
|
Loading…
Reference in New Issue
Block a user