[gnome-builder/wip/symbol-tree] tree: move model access functions to gb-tree.c
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/wip/symbol-tree] tree: move model access functions to gb-tree.c
- Date: Fri, 19 Jun 2015 09:01:01 +0000 (UTC)
commit 985a30c2b3fc8a3e4bd0364977eaa0204e827d93
Author: Christian Hergert <christian hergert me>
Date: Fri Jun 19 01:59:02 2015 -0700
tree: move model access functions to gb-tree.c
We need this so that we can apply filters going forward.
src/tree/gb-tree-node.c | 41 +++--------------------------------------
src/tree/gb-tree-private.h | 5 +++++
src/tree/gb-tree.c | 40 ++++++++++++++++++++++++++++++++++++++++
3 files changed, 48 insertions(+), 38 deletions(-)
---
diff --git a/src/tree/gb-tree-node.c b/src/tree/gb-tree-node.c
index 1764f94..89ee636 100644
--- a/src/tree/gb-tree-node.c
+++ b/src/tree/gb-tree-node.c
@@ -173,27 +173,10 @@ void
gb_tree_node_remove (GbTreeNode *node,
GbTreeNode *child)
{
- GtkTreeModel *model = NULL;
- GtkTreePath *path;
- GtkTreeIter iter;
- GbTree *tree = NULL;
-
g_return_if_fail (GB_IS_TREE_NODE (node));
+ g_return_if_fail (GB_IS_TREE_NODE (child));
- tree = gb_tree_node_get_tree (node);
- model = gtk_tree_view_get_model (GTK_TREE_VIEW (tree));
- path = gb_tree_node_get_path (node);
-
- g_object_ref (tree);
- g_object_ref (model);
-
- if (gtk_tree_model_get_iter (model, &iter, path))
- gtk_tree_store_remove (GTK_TREE_STORE (model), &iter);
-
- g_clear_object (&model);
- g_clear_object (&tree);
-
- gtk_tree_path_free (path);
+ _gb_tree_remove (node->tree, child);
}
/**
@@ -238,31 +221,13 @@ gboolean
gb_tree_node_get_iter (GbTreeNode *self,
GtkTreeIter *iter)
{
- GtkTreeModel *model;
- GtkTreePath *path;
gboolean ret = FALSE;
g_return_val_if_fail (GB_IS_TREE_NODE (self), FALSE);
g_return_val_if_fail (iter != NULL, FALSE);
if (self->tree != NULL)
- {
- model = gtk_tree_view_get_model (GTK_TREE_VIEW (self->tree));
- path = gb_tree_node_get_path (self);
- ret = gtk_tree_model_get_iter (model, iter, path);
- gtk_tree_path_free (path);
- }
-
-#if 0
- if (ret)
- {
- GbTreeNode *other = NULL;
-
- gtk_tree_model_get (model, iter, 0, &other, -1);
- g_assert (other == self);
- g_clear_object (&other);
- }
-#endif
+ ret = _gb_tree_get_iter (self->tree, self, iter);
return ret;
}
diff --git a/src/tree/gb-tree-private.h b/src/tree/gb-tree-private.h
index 5aee1e9..8da051c 100644
--- a/src/tree/gb-tree-private.h
+++ b/src/tree/gb-tree-private.h
@@ -38,6 +38,11 @@ void _gb_tree_insert_sorted (GbTree *self,
GbTreeNode *child,
GbTreeNodeCompareFunc compare_func,
gpointer user_data);
+void _gb_tree_remove (GbTree *self,
+ GbTreeNode *node);
+gboolean _gb_tree_get_iter (GbTree *self,
+ GbTreeNode *node,
+ GtkTreeIter *iter);
void _gb_tree_node_set_tree (GbTreeNode *node,
GbTree *tree);
diff --git a/src/tree/gb-tree.c b/src/tree/gb-tree.c
index 54ad72a..bbc706a 100644
--- a/src/tree/gb-tree.c
+++ b/src/tree/gb-tree.c
@@ -1513,3 +1513,43 @@ failure:
return NULL;
}
+
+void
+_gb_tree_remove (GbTree *self,
+ GbTreeNode *node)
+{
+ GbTreePrivate *priv = gb_tree_get_instance_private (self);
+ GtkTreePath *path;
+ GtkTreeIter iter;
+
+ g_return_if_fail (GB_IS_TREE (self));
+ g_return_if_fail (GB_IS_TREE_NODE (node));
+
+ path = gb_tree_node_get_path (node);
+
+ if (gtk_tree_model_get_iter (GTK_TREE_MODEL (priv->store), &iter, path))
+ gtk_tree_store_remove (priv->store, &iter);
+
+ gtk_tree_path_free (path);
+}
+
+gboolean
+_gb_tree_get_iter (GbTree *self,
+ GbTreeNode *node,
+ GtkTreeIter *iter)
+{
+ GbTreePrivate *priv = gb_tree_get_instance_private (self);
+ GtkTreePath *path;
+ gboolean ret;
+
+ g_return_val_if_fail (GB_IS_TREE (self), FALSE);
+ g_return_val_if_fail (GB_IS_TREE_NODE (node), FALSE);
+ g_return_val_if_fail (iter, FALSE);
+
+ path = gb_tree_node_get_path (node);
+ ret = gtk_tree_model_get_iter (GTK_TREE_MODEL (priv->store), iter, path);
+ gtk_tree_path_free (path);
+
+ return ret;
+}
+
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]