/usr/include/libgda-5.0/libgda/gda-tree.h is in libgda-5.0-dev 5.0.3-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 | /*
* Copyright (C) 2009 - 2011 Vivien Malerba <malerba@gnome-db.org>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef __GDA_TREE_H__
#define __GDA_TREE_H__
#include <glib-object.h>
#include <stdio.h>
#include "gda-decl.h"
G_BEGIN_DECLS
#define GDA_TYPE_TREE (gda_tree_get_type())
#define GDA_TREE(obj) (G_TYPE_CHECK_INSTANCE_CAST (obj, GDA_TYPE_TREE, GdaTree))
#define GDA_TREE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST (klass, GDA_TYPE_TREE, GdaTreeClass))
#define GDA_IS_TREE(obj) (G_TYPE_CHECK_INSTANCE_TYPE(obj, GDA_TYPE_TREE))
#define GDA_IS_TREE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GDA_TYPE_TREE))
#define GDA_TREE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GDA_TYPE_TREE, GdaTreeClass))
/* error reporting */
extern GQuark gda_tree_error_quark (void);
#define GDA_TREE_ERROR gda_tree_error_quark ()
typedef enum {
GDA_TREE_UNKNOWN_ERROR
} GdaTreeError;
struct _GdaTree {
GObject object;
GdaTreePrivate *priv;
};
struct _GdaTreeClass {
GObjectClass object_class;
/* signals */
void (* node_changed) (GdaTree *tree, GdaTreeNode *node);
void (* node_inserted) (GdaTree *tree, GdaTreeNode *node);
void (* node_has_child_toggled) (GdaTree *tree, GdaTreeNode *node);
void (* node_deleted) (GdaTree *tree, const gchar *node_path);
/*< private >*/
/* Padding for future expansion */
void (*_gda_reserved1) (void);
void (*_gda_reserved2) (void);
void (*_gda_reserved3) (void);
void (*_gda_reserved4) (void);
};
/**
* SECTION:gda-tree
* @short_description: A tree-structure
* @title: GdaTree
* @stability: Stable
* @see_also:
*
* The #GdaTree is the top level object representing hierarchically structured data. From this object it
* is also possible (depending on the tree managers it uses), to clean (remove all the nodes) the whole tree,
* or to request a complete or partial update of the nodes.
*
* It is also possible to set attributes to the tree itself (as it is possible to do for tree nodes),
* or to dump the whole or part of a tree in an indented and easy to read fashion.
*/
GType gda_tree_get_type (void) G_GNUC_CONST;
GdaTree* gda_tree_new (void);
void gda_tree_add_manager (GdaTree *tree, GdaTreeManager *manager);
void gda_tree_clean (GdaTree *tree);
gboolean gda_tree_update_all (GdaTree *tree, GError **error);
gboolean gda_tree_update_part (GdaTree *tree, GdaTreeNode *node, GError **error);
gboolean gda_tree_update_children (GdaTree *tree, GdaTreeNode *node, GError **error);
GSList *gda_tree_get_nodes_in_path (GdaTree *tree, const gchar *tree_path, gboolean use_names);
GdaTreeNode *gda_tree_get_node (GdaTree *tree, const gchar *tree_path, gboolean use_names);
gchar *gda_tree_get_node_path (GdaTree *tree, GdaTreeNode *node);
GdaTreeManager *gda_tree_get_node_manager (GdaTree *tree, GdaTreeNode *node);
void gda_tree_set_attribute (GdaTree *tree, const gchar *attribute, const GValue *value,
GDestroyNotify destroy);
void gda_tree_dump (GdaTree *tree, GdaTreeNode *node, FILE *stream);
G_END_DECLS
#endif
|