]> Pileus Git - ~andy/gtk/commitdiff
tests: Remove deleted rows from cache
authorBenjamin Otte <otte@redhat.com>
Mon, 19 Mar 2012 01:24:59 +0000 (02:24 +0100)
committerBenjamin Otte <otte@redhat.com>
Mon, 19 Mar 2012 01:26:16 +0000 (02:26 +0100)
Otherwise the GNode pointer address that we use for indexing might get
reused for a new node and then we don't start out with a pristine
refcount.

gtk/tests/gtktreemodelrefcount.c

index 76a38f19724ab4db17729cd0eb391b1959a24a03..7f29f994e15f7242ed6db3f0b5052e9c139c7518 100644 (file)
@@ -58,6 +58,28 @@ G_DEFINE_TYPE_WITH_CODE (GtkTreeModelRefCount, gtk_tree_model_ref_count, GTK_TYP
                          G_IMPLEMENT_INTERFACE (GTK_TYPE_TREE_MODEL,
                                                 gtk_tree_model_ref_count_tree_model_init))
 
+static void
+row_removed (GtkTreeModelRefCount *ref_model,
+             GtkTreePath *path)
+{
+  GHashTableIter iter;
+  GtkTreeIter tree_iter;
+
+  if (!gtk_tree_model_get_iter_first (GTK_TREE_MODEL (ref_model), &tree_iter))
+    {
+      g_hash_table_remove_all (ref_model->priv->node_hash);
+      return;
+    }
+
+  g_hash_table_iter_init (&iter, ref_model->priv->node_hash);
+
+  while (g_hash_table_iter_next (&iter, &tree_iter.user_data, NULL))
+    {
+      if (!gtk_tree_store_iter_is_valid (GTK_TREE_STORE (ref_model), &tree_iter))
+        g_hash_table_iter_remove (&iter);
+    }
+}
+
 static void
 gtk_tree_model_ref_count_init (GtkTreeModelRefCount *ref_model)
 {
@@ -69,6 +91,8 @@ gtk_tree_model_ref_count_init (GtkTreeModelRefCount *ref_model)
                                                       g_direct_equal,
                                                       NULL,
                                                       (GDestroyNotify)node_info_free);
+
+  g_signal_connect (ref_model, "row-deleted", G_CALLBACK (row_removed), NULL);
 }
 
 static void