From 33194ff5f46e39db123c8a4668d3a4b0bde48ecd Mon Sep 17 00:00:00 2001 From: "John (J5) Palmieri" Date: Tue, 27 Apr 2010 17:12:41 -0400 Subject: add a get_indices_with_depth method to GtkTreePath with proper GI array annotations * get_indices does not return a length so we can not annotate it to return an array in bindings that use GObject Introspection * this method is the same as get_indices except it takes an int * as the depth parameter which we can then use in the array annotation * in C this function returns an integer pointer array and updates depth to the number of integers in the array * in a GI binding this returns the native array type for the bound language (e.g. in PyGI this returns a list of integers) --- gtk/gtktreemodel.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) (limited to 'gtk/gtktreemodel.c') diff --git a/gtk/gtktreemodel.c b/gtk/gtktreemodel.c index 5bdce35479..bf45a31f97 100644 --- a/gtk/gtktreemodel.c +++ b/gtk/gtktreemodel.c @@ -622,6 +622,31 @@ gtk_tree_path_get_indices (GtkTreePath *path) return path->indices; } +/** + * gtk_tree_path_get_indices_with_depth: + * @path: A #GtkTreePath. + * @depth: Number of elements returned in the integer array + * + * Returns the current indices of @path. + * This is an array of integers, each representing a node in a tree. + * It also returns the number of elements in the array. + * The array should not be freed. + * + * Return value: (array length=depth): The current indices, or %NULL. + * + * Since: 3.0 + **/ +gint * +gtk_tree_path_get_indices_with_depth (GtkTreePath *path, gint *depth) +{ + g_return_val_if_fail (path != NULL, NULL); + + if (depth) + *depth = path->depth; + + return path->indices; +} + /** * gtk_tree_path_free: * @path: A #GtkTreePath. -- cgit v1.2.1