[gnome-builder/wip/lazy-tree] tree: more gb-tree cleanup
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/wip/lazy-tree] tree: more gb-tree cleanup
- Date: Sun, 14 Jun 2015 19:31:15 +0000 (UTC)
commit 6f639f25d2825d29ed59a7382fd599cd2cebb6cb
Author: Christian Hergert <christian hergert me>
Date: Sun Jun 14 12:31:08 2015 -0700
tree: more gb-tree cleanup
src/tree/gb-tree.c | 634 ++++++++++++++++++++++++----------------------------
1 files changed, 287 insertions(+), 347 deletions(-)
---
diff --git a/src/tree/gb-tree.c b/src/tree/gb-tree.c
index b554bab..97f7fcb 100644
--- a/src/tree/gb-tree.c
+++ b/src/tree/gb-tree.c
@@ -70,12 +70,6 @@ static GtkBuildableIface *gb_tree_parent_buildable_iface;
static GParamSpec *gParamSpecs [LAST_PROP];
static guint gSignals [LAST_SIGNAL];
-/**
- * gb_tree_unselect:
- * @tree: (in): A #GbTree.
- *
- * Unselects the current item in the tree.
- */
static void
gb_tree_unselect (GbTree *tree)
{
@@ -91,13 +85,6 @@ gb_tree_unselect (GbTree *tree)
IDE_EXIT;
}
-/**
- * gb_tree_select:
- * @tree: (in): A #GbTree.
- * @node: (in): A #GbTreeNode.
- *
- * Selects @node within the tree.
- */
static void
gb_tree_select (GbTree *tree,
GbTreeNode *node)
@@ -308,12 +295,6 @@ gb_tree_popup_menu (GtkWidget *widget)
return TRUE;
}
-/**
- * gb_tree_selection_changed:
- * @tree: (in): A #GbTree.
- *
- * Handle the selection changing.
- */
static void
gb_tree_selection_changed (GbTree *tree,
GtkTreeSelection *selection)
@@ -360,19 +341,6 @@ gb_tree_selection_changed (GbTree *tree,
IDE_EXIT;
}
-/**
- * gb_tree_get_iter_for_node:
- * @tree: (in): A #GbTree.
- * @parent: (in) (allow-none): A #GtkTreeIter of parent or %NULL.
- * @iter: (out): A location for a #GtkTreeIter.
- * @node: (in): A #GbTreeNode expected to be within @parent children.
- *
- * Looks for the #GtkTreeIter that contains @node within the children
- * of @parent. If that item is found, @iter is set and %TRUE is returned.
- * Otherwise, %FALSE is returned.
- *
- * Returns: %TRUE if successful; otherwise %FALSE.
- */
static gboolean
gb_tree_get_iter_for_node (GbTree *tree,
GtkTreeIter *parent,
@@ -435,7 +403,7 @@ gb_tree_add_builder_foreach_cb (GtkTreeModel *model,
IDE_RETURN (FALSE);
}
-gboolean
+static gboolean
gb_tree_foreach (GbTree *tree,
GtkTreeIter *iter,
GtkTreeModelForeachFunc func,
@@ -473,201 +441,6 @@ gb_tree_foreach (GbTree *tree,
return FALSE;
}
-void
-_gb_tree_rebuild_node (GbTree *tree,
- GbTreeNode *node)
-{
- GbTreePrivate *priv = gb_tree_get_instance_private (tree);
- GtkTreeModel *model;
- GtkTreePath *path;
- GtkTreeIter iter;
- GtkTreeIter child;
- guint i;
-
- g_return_if_fail (GB_IS_TREE (tree));
- g_return_if_fail (GB_IS_TREE_NODE (node));
-
- model = GTK_TREE_MODEL (priv->store);
- path = gb_tree_node_get_path (node);
- gtk_tree_model_get_iter (model, &iter, path);
-
- if (gtk_tree_model_iter_children (model, &child, &iter))
- {
- while (gtk_tree_store_remove (priv->store, &child))
- { /* Do Nothing */ }
- }
-
- priv->building++;
- for (i = 0; i < priv->builders->len; i++)
- {
- GbTreeBuilder *builder;
-
- /*
- * FIXME:
- *
- * Refactor this to do all builders when walking each node.
- */
-
- builder = g_ptr_array_index (priv->builders, i);
- gb_tree_foreach (tree,
- &iter,
- gb_tree_add_builder_foreach_cb,
- builder);
- priv->building--;
- }
-
- gtk_tree_path_free (path);
-}
-
-/**
- * gb_tree_add_builder:
- * @tree: (in): A #GbTree.
- * @builder: (in) (transfer full): A #GbTreeBuilder to add.
- *
- * Removes a builder from the tree.
- */
-void
-gb_tree_add_builder (GbTree *tree,
- GbTreeBuilder *builder)
-{
- GtkTreeIter iter;
- GbTreePrivate *priv = gb_tree_get_instance_private (tree);
-
- IDE_ENTRY;
-
- g_return_if_fail (GB_IS_TREE (tree));
- g_return_if_fail (GB_IS_TREE_BUILDER (builder));
-
- g_object_set (builder, "tree", tree, NULL);
- g_ptr_array_add (priv->builders, g_object_ref_sink (builder));
-
- if (gtk_tree_model_get_iter_first (GTK_TREE_MODEL (priv->store), &iter))
- {
- priv->building++;
- gb_tree_foreach (tree, &iter, gb_tree_add_builder_foreach_cb, builder);
- priv->building--;
- }
-
- _gb_tree_builder_added (builder, tree);
-
- IDE_EXIT;
-}
-
-/**
- * gb_tree_remove_builder:
- * @tree: (in): A #GbTree.
- * @builder: (in): A #GbTreeBuilder to remove.
- *
- * Removes a builder from the tree.
- */
-void
-gb_tree_remove_builder (GbTree *tree,
- GbTreeBuilder *builder)
-{
- GbTreePrivate *priv = gb_tree_get_instance_private (tree);
- gsize i;
-
- IDE_ENTRY;
-
- g_return_if_fail (GB_IS_TREE (tree));
- g_return_if_fail (GB_IS_TREE_BUILDER (builder));
-
- for (i = 0; i < priv->builders->len; i++)
- {
- if (builder == g_ptr_array_index (priv->builders, i))
- {
- g_object_ref (builder);
- g_ptr_array_remove_index (priv->builders, i);
- _gb_tree_builder_removed (builder, tree);
- g_object_unref (builder);
- }
- }
-
- IDE_EXIT;
-}
-
-/**
- * gb_tree_get_root:
- *
- * Retrieves the root node of the tree. The root node is not a visible node
- * in the tree, but a placeholder for all other builders to build upon.
- *
- * Returns: (transfer none) (nullable): A #GbTreeNode or %NULL.
- */
-GbTreeNode *
-gb_tree_get_root (GbTree *tree)
-{
- GbTreePrivate *priv = gb_tree_get_instance_private (tree);
-
- g_return_val_if_fail (GB_IS_TREE (tree), NULL);
-
- return priv->root;
-}
-
-/**
- * gb_tree_set_root:
- * @tree: (in): A #GbTree.
- * @node: (in): A #GbTreeNode.
- *
- * Sets the root node of the #GbTree widget. This is used to build
- * the items within the treeview. The item itself will not be added
- * to the tree, but the direct children will be.
- */
-void
-gb_tree_set_root (GbTree *tree,
- GbTreeNode *root)
-{
- GbTreeBuilder *builder;
- gint i;
- GbTreePrivate *priv = gb_tree_get_instance_private (tree);
-
- IDE_ENTRY;
-
- g_return_if_fail (GB_IS_TREE (tree));
-
- gtk_tree_store_clear (priv->store);
- g_clear_object (&priv->root);
-
- if (root)
- {
- priv->root = g_object_ref_sink (root);
- _gb_tree_node_set_tree (root, tree);
- for (i = 0; i < priv->builders->len; i++)
- {
- builder = g_ptr_array_index (priv->builders, i);
- _gb_tree_builder_build_node (builder, root);
- }
- }
-
- IDE_EXIT;
-}
-
-void
-gb_tree_rebuild (GbTree *tree)
-{
- GbTreeNode *root;
- GtkTreeSelection *selection;
- GbTreePrivate *priv = gb_tree_get_instance_private (tree);
-
- g_return_if_fail (GB_IS_TREE (tree));
-
- /* avoid dealign with selection changes while rebuilding */
- selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (tree));
- gtk_tree_selection_unselect_all (selection);
-
- if ((root = priv->root ? g_object_ref (priv->root) : NULL))
- {
- gb_tree_set_root (tree, root);
- g_object_unref (root);
- }
-}
-
-/**
- * pixbuf_func:
- * @cell_layout: (in): A #GtkCellRendererPixbuf.
- *
- * Handle preparing a pixbuf cell renderer for drawing.
- */
static void
pixbuf_func (GtkCellLayout *cell_layout,
GtkCellRenderer *cell,
@@ -684,12 +457,6 @@ pixbuf_func (GtkCellLayout *cell_layout,
g_clear_object (&node);
}
-/**
- * text_func:
- * @cell_layout: (in): A #GtkCellRendererText.
- *
- * Handle preparing a text cell renderer for drawing.
- */
static void
text_func (GtkCellLayout *cell_layout,
GtkCellRenderer *cell,
@@ -716,15 +483,6 @@ text_func (GtkCellLayout *cell_layout,
}
}
-/**
- * gb_tree_add:
- * @tree: (in): A #GbTree.
- * @node: (in): A #GbTreeNode.
- * @child: (in): A #GbTreeNode.
- * @prepend: (in): Should we prepend instead of append?
- *
- * Prepends or appends @child to @node within the #GbTree.
- */
static void
gb_tree_add (GbTree *tree,
GbTreeNode *node,
@@ -773,53 +531,6 @@ gb_tree_add (GbTree *tree,
}
}
-/**
- * gb_tree_append:
- * @tree: (in): A #GbTree.
- * @node: (in): A #GbTreeNode.
- * @child: (in): A #GbTreeNode.
- *
- * Appends @child to @node within the #GbTree.
- */
-void
-gb_tree_append (GbTree *tree,
- GbTreeNode *node,
- GbTreeNode *child)
-{
- g_return_if_fail (GB_IS_TREE (tree));
- g_return_if_fail (GB_IS_TREE_NODE (node));
- g_return_if_fail (GB_IS_TREE_NODE (child));
-
- gb_tree_add (tree, node, child, FALSE);
-}
-
-/**
- * gb_tree_prepend:
- * @tree: (in): A #GbTree.
- * @node: (in): A #GbTreeNode.
- * @child: (in): A #GbTreeNode.
- *
- * Appends @child to @node within the #GbTree.
- */
-void
-gb_tree_prepend (GbTree *tree,
- GbTreeNode *node,
- GbTreeNode *child)
-{
- g_return_if_fail (GB_IS_TREE (tree));
- g_return_if_fail (GB_IS_TREE_NODE (node));
- g_return_if_fail (GB_IS_TREE_NODE (child));
-
- gb_tree_add (tree, node, child, TRUE);
-}
-
-/**
- * gb_tree_row_activated:
- * @tree_view: (in): A #GbTree.
- * @path: (in): A #GtkTreePath.
- *
- * Handle the row being activated. Expand the row or collapse it.
- */
static void
gb_tree_row_activated (GtkTreeView *tree_view,
GtkTreePath *path)
@@ -933,63 +644,6 @@ gb_tree_find_item_foreach_cb (GtkTreeModel *model,
return FALSE;
}
-/**
- * gb_tree_find_custom:
- * @self: A #GbTree
- * @equal_func: A #GEqualFunc
- * @key: the key for @equal_func
- *
- * Walks the entire tree looking for the first item that matches given
- * @equal_func and @key.
- *
- * The first parameter to @equal_func will always be @key.
- * The second parameter will be the nodes #GbTreeNode:item property.
- *
- * Returns: (nullable) (transfer none): A #GbTreeNode or %NULL.
- */
-GbTreeNode *
-gb_tree_find_custom (GbTree *self,
- GEqualFunc equal_func,
- gpointer key)
-{
- GbTreePrivate *priv = gb_tree_get_instance_private (self);
- NodeLookup lookup;
-
- g_return_val_if_fail (GB_IS_TREE (self), NULL);
- g_return_val_if_fail (equal_func != NULL, NULL);
-
- lookup.key = key;
- lookup.equal_func = equal_func;
- lookup.result = NULL;
-
- gtk_tree_model_foreach (GTK_TREE_MODEL (priv->store),
- gb_tree_find_item_foreach_cb,
- &lookup);
-
- return lookup.result;
-}
-
-GbTreeNode *
-gb_tree_find_item (GbTree *self,
- GObject *item)
-{
- GbTreePrivate *priv = gb_tree_get_instance_private (self);
- NodeLookup lookup;
-
- g_return_val_if_fail (GB_IS_TREE (self), NULL);
- g_return_val_if_fail (!item || G_IS_OBJECT (item), NULL);
-
- lookup.key = item;
- lookup.equal_func = g_direct_equal;
- lookup.result = NULL;
-
- gtk_tree_model_foreach (GTK_TREE_MODEL (priv->store),
- gb_tree_find_item_foreach_cb,
- &lookup);
-
- return lookup.result;
-}
-
static void
gb_tree_real_action (GbTree *self,
const gchar *prefix,
@@ -1420,3 +1074,289 @@ _gb_tree_get_path (GbTree *tree,
return NULL;
}
+
+/**
+ * gb_tree_add_builder:
+ * @tree: (in): A #GbTree.
+ * @builder: (in) (transfer full): A #GbTreeBuilder to add.
+ *
+ * Removes a builder from the tree.
+ */
+void
+gb_tree_add_builder (GbTree *tree,
+ GbTreeBuilder *builder)
+{
+ GtkTreeIter iter;
+ GbTreePrivate *priv = gb_tree_get_instance_private (tree);
+
+ IDE_ENTRY;
+
+ g_return_if_fail (GB_IS_TREE (tree));
+ g_return_if_fail (GB_IS_TREE_BUILDER (builder));
+
+ g_object_set (builder, "tree", tree, NULL);
+ g_ptr_array_add (priv->builders, g_object_ref_sink (builder));
+
+ if (gtk_tree_model_get_iter_first (GTK_TREE_MODEL (priv->store), &iter))
+ {
+ priv->building++;
+ gb_tree_foreach (tree, &iter, gb_tree_add_builder_foreach_cb, builder);
+ priv->building--;
+ }
+
+ _gb_tree_builder_added (builder, tree);
+
+ IDE_EXIT;
+}
+
+/**
+ * gb_tree_remove_builder:
+ * @tree: (in): A #GbTree.
+ * @builder: (in): A #GbTreeBuilder to remove.
+ *
+ * Removes a builder from the tree.
+ */
+void
+gb_tree_remove_builder (GbTree *tree,
+ GbTreeBuilder *builder)
+{
+ GbTreePrivate *priv = gb_tree_get_instance_private (tree);
+ gsize i;
+
+ IDE_ENTRY;
+
+ g_return_if_fail (GB_IS_TREE (tree));
+ g_return_if_fail (GB_IS_TREE_BUILDER (builder));
+
+ for (i = 0; i < priv->builders->len; i++)
+ {
+ if (builder == g_ptr_array_index (priv->builders, i))
+ {
+ g_object_ref (builder);
+ g_ptr_array_remove_index (priv->builders, i);
+ _gb_tree_builder_removed (builder, tree);
+ g_object_unref (builder);
+ }
+ }
+
+ IDE_EXIT;
+}
+
+/**
+ * gb_tree_get_root:
+ *
+ * Retrieves the root node of the tree. The root node is not a visible node
+ * in the tree, but a placeholder for all other builders to build upon.
+ *
+ * Returns: (transfer none) (nullable): A #GbTreeNode or %NULL.
+ */
+GbTreeNode *
+gb_tree_get_root (GbTree *tree)
+{
+ GbTreePrivate *priv = gb_tree_get_instance_private (tree);
+
+ g_return_val_if_fail (GB_IS_TREE (tree), NULL);
+
+ return priv->root;
+}
+
+/**
+ * gb_tree_set_root:
+ * @tree: (in): A #GbTree.
+ * @node: (in): A #GbTreeNode.
+ *
+ * Sets the root node of the #GbTree widget. This is used to build
+ * the items within the treeview. The item itself will not be added
+ * to the tree, but the direct children will be.
+ */
+void
+gb_tree_set_root (GbTree *tree,
+ GbTreeNode *root)
+{
+ GbTreeBuilder *builder;
+ gint i;
+ GbTreePrivate *priv = gb_tree_get_instance_private (tree);
+
+ IDE_ENTRY;
+
+ g_return_if_fail (GB_IS_TREE (tree));
+
+ gtk_tree_store_clear (priv->store);
+ g_clear_object (&priv->root);
+
+ if (root)
+ {
+ priv->root = g_object_ref_sink (root);
+ _gb_tree_node_set_tree (root, tree);
+ for (i = 0; i < priv->builders->len; i++)
+ {
+ builder = g_ptr_array_index (priv->builders, i);
+ _gb_tree_builder_build_node (builder, root);
+ }
+ }
+
+ IDE_EXIT;
+}
+
+void
+gb_tree_rebuild (GbTree *tree)
+{
+ GbTreeNode *root;
+ GtkTreeSelection *selection;
+ GbTreePrivate *priv = gb_tree_get_instance_private (tree);
+
+ g_return_if_fail (GB_IS_TREE (tree));
+
+ /* avoid dealign with selection changes while rebuilding */
+ selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (tree));
+ gtk_tree_selection_unselect_all (selection);
+
+ if ((root = priv->root ? g_object_ref (priv->root) : NULL))
+ {
+ gb_tree_set_root (tree, root);
+ g_object_unref (root);
+ }
+}
+
+/**
+ * gb_tree_find_custom:
+ * @self: A #GbTree
+ * @equal_func: A #GEqualFunc
+ * @key: the key for @equal_func
+ *
+ * Walks the entire tree looking for the first item that matches given
+ * @equal_func and @key.
+ *
+ * The first parameter to @equal_func will always be @key.
+ * The second parameter will be the nodes #GbTreeNode:item property.
+ *
+ * Returns: (nullable) (transfer none): A #GbTreeNode or %NULL.
+ */
+GbTreeNode *
+gb_tree_find_custom (GbTree *self,
+ GEqualFunc equal_func,
+ gpointer key)
+{
+ GbTreePrivate *priv = gb_tree_get_instance_private (self);
+ NodeLookup lookup;
+
+ g_return_val_if_fail (GB_IS_TREE (self), NULL);
+ g_return_val_if_fail (equal_func != NULL, NULL);
+
+ lookup.key = key;
+ lookup.equal_func = equal_func;
+ lookup.result = NULL;
+
+ gtk_tree_model_foreach (GTK_TREE_MODEL (priv->store),
+ gb_tree_find_item_foreach_cb,
+ &lookup);
+
+ return lookup.result;
+}
+
+GbTreeNode *
+gb_tree_find_item (GbTree *self,
+ GObject *item)
+{
+ GbTreePrivate *priv = gb_tree_get_instance_private (self);
+ NodeLookup lookup;
+
+ g_return_val_if_fail (GB_IS_TREE (self), NULL);
+ g_return_val_if_fail (!item || G_IS_OBJECT (item), NULL);
+
+ lookup.key = item;
+ lookup.equal_func = g_direct_equal;
+ lookup.result = NULL;
+
+ gtk_tree_model_foreach (GTK_TREE_MODEL (priv->store),
+ gb_tree_find_item_foreach_cb,
+ &lookup);
+
+ return lookup.result;
+}
+
+/**
+ * gb_tree_append:
+ * @tree: (in): A #GbTree.
+ * @node: (in): A #GbTreeNode.
+ * @child: (in): A #GbTreeNode.
+ *
+ * Appends @child to @node within the #GbTree.
+ */
+void
+gb_tree_append (GbTree *tree,
+ GbTreeNode *node,
+ GbTreeNode *child)
+{
+ g_return_if_fail (GB_IS_TREE (tree));
+ g_return_if_fail (GB_IS_TREE_NODE (node));
+ g_return_if_fail (GB_IS_TREE_NODE (child));
+
+ gb_tree_add (tree, node, child, FALSE);
+}
+
+/**
+ * gb_tree_prepend:
+ * @tree: (in): A #GbTree.
+ * @node: (in): A #GbTreeNode.
+ * @child: (in): A #GbTreeNode.
+ *
+ * Appends @child to @node within the #GbTree.
+ */
+void
+gb_tree_prepend (GbTree *tree,
+ GbTreeNode *node,
+ GbTreeNode *child)
+{
+ g_return_if_fail (GB_IS_TREE (tree));
+ g_return_if_fail (GB_IS_TREE_NODE (node));
+ g_return_if_fail (GB_IS_TREE_NODE (child));
+
+ gb_tree_add (tree, node, child, TRUE);
+}
+
+void
+_gb_tree_rebuild_node (GbTree *tree,
+ GbTreeNode *node)
+{
+ GbTreePrivate *priv = gb_tree_get_instance_private (tree);
+ GtkTreeModel *model;
+ GtkTreePath *path;
+ GtkTreeIter iter;
+ GtkTreeIter child;
+ guint i;
+
+ g_return_if_fail (GB_IS_TREE (tree));
+ g_return_if_fail (GB_IS_TREE_NODE (node));
+
+ model = GTK_TREE_MODEL (priv->store);
+ path = gb_tree_node_get_path (node);
+ gtk_tree_model_get_iter (model, &iter, path);
+
+ if (gtk_tree_model_iter_children (model, &child, &iter))
+ {
+ while (gtk_tree_store_remove (priv->store, &child))
+ { /* Do Nothing */ }
+ }
+
+ priv->building++;
+ for (i = 0; i < priv->builders->len; i++)
+ {
+ GbTreeBuilder *builder;
+
+ /*
+ * FIXME:
+ *
+ * Refactor this to do all builders when walking each node.
+ */
+
+ builder = g_ptr_array_index (priv->builders, i);
+ gb_tree_foreach (tree,
+ &iter,
+ gb_tree_add_builder_foreach_cb,
+ builder);
+ priv->building--;
+ }
+
+ gtk_tree_path_free (path);
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]