]> Pileus Git - ~andy/gtk/blob - gtk/gtktreeview.h
docs: move documentation to inline comments: GtkTreeView
[~andy/gtk] / gtk / gtktreeview.h
1 /* gtktreeview.h
2  * Copyright (C) 2000  Red Hat, Inc.,  Jonathan Blandford <jrb@redhat.com>
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Library General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Library General Public License for more details.
13  *
14  * You should have received a copy of the GNU Library General Public
15  * License along with this library; if not, write to the
16  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17  * Boston, MA 02111-1307, USA.
18  */
19
20 #if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
21 #error "Only <gtk/gtk.h> can be included directly."
22 #endif
23
24 #ifndef __GTK_TREE_VIEW_H__
25 #define __GTK_TREE_VIEW_H__
26
27 #include <gtk/gtkcontainer.h>
28 #include <gtk/gtktreemodel.h>
29 #include <gtk/gtktreeviewcolumn.h>
30 #include <gtk/gtkdnd.h>
31 #include <gtk/gtkentry.h>
32
33 G_BEGIN_DECLS
34
35 /**
36  * GtkTreeViewDropPosition:
37  * @GTK_TREE_VIEW_DROP_BEFORE: dropped row is inserted before
38  * @GTK_TREE_VIEW_DROP_AFTER: dropped row is inserted after
39  * @GTK_TREE_VIEW_DROP_INTO_OR_BEFORE: dropped row becomes a child or is inserted before
40  * @GTK_TREE_VIEW_DROP_INTO_OR_AFTER: dropped row becomes a child or is inserted after
41  *
42  * An enum for determining where a dropped row goes.
43  */
44 typedef enum
45 {
46   /* drop before/after this row */
47   GTK_TREE_VIEW_DROP_BEFORE,
48   GTK_TREE_VIEW_DROP_AFTER,
49   /* drop as a child of this row (with fallback to before or after
50    * if into is not possible)
51    */
52   GTK_TREE_VIEW_DROP_INTO_OR_BEFORE,
53   GTK_TREE_VIEW_DROP_INTO_OR_AFTER
54 } GtkTreeViewDropPosition;
55
56 #define GTK_TYPE_TREE_VIEW              (gtk_tree_view_get_type ())
57 #define GTK_TREE_VIEW(obj)              (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_TREE_VIEW, GtkTreeView))
58 #define GTK_TREE_VIEW_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_TREE_VIEW, GtkTreeViewClass))
59 #define GTK_IS_TREE_VIEW(obj)           (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_TREE_VIEW))
60 #define GTK_IS_TREE_VIEW_CLASS(klass)   (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_TREE_VIEW))
61 #define GTK_TREE_VIEW_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_TREE_VIEW, GtkTreeViewClass))
62
63 typedef struct _GtkTreeView           GtkTreeView;
64 typedef struct _GtkTreeViewClass      GtkTreeViewClass;
65 typedef struct _GtkTreeViewPrivate    GtkTreeViewPrivate;
66 typedef struct _GtkTreeSelection      GtkTreeSelection;
67 typedef struct _GtkTreeSelectionClass GtkTreeSelectionClass;
68
69 struct _GtkTreeView
70 {
71   GtkContainer parent;
72
73   /*< private >*/
74   GtkTreeViewPrivate *priv;
75 };
76
77 struct _GtkTreeViewClass
78 {
79   GtkContainerClass parent_class;
80
81   void     (* row_activated)              (GtkTreeView       *tree_view,
82                                            GtkTreePath       *path,
83                                            GtkTreeViewColumn *column);
84   gboolean (* test_expand_row)            (GtkTreeView       *tree_view,
85                                            GtkTreeIter       *iter,
86                                            GtkTreePath       *path);
87   gboolean (* test_collapse_row)          (GtkTreeView       *tree_view,
88                                            GtkTreeIter       *iter,
89                                            GtkTreePath       *path);
90   void     (* row_expanded)               (GtkTreeView       *tree_view,
91                                            GtkTreeIter       *iter,
92                                            GtkTreePath       *path);
93   void     (* row_collapsed)              (GtkTreeView       *tree_view,
94                                            GtkTreeIter       *iter,
95                                            GtkTreePath       *path);
96   void     (* columns_changed)            (GtkTreeView       *tree_view);
97   void     (* cursor_changed)             (GtkTreeView       *tree_view);
98
99   /* Key Binding signals */
100   gboolean (* move_cursor)                (GtkTreeView       *tree_view,
101                                            GtkMovementStep    step,
102                                            gint               count);
103   gboolean (* select_all)                 (GtkTreeView       *tree_view);
104   gboolean (* unselect_all)               (GtkTreeView       *tree_view);
105   gboolean (* select_cursor_row)          (GtkTreeView       *tree_view,
106                                            gboolean           start_editing);
107   gboolean (* toggle_cursor_row)          (GtkTreeView       *tree_view);
108   gboolean (* expand_collapse_cursor_row) (GtkTreeView       *tree_view,
109                                            gboolean           logical,
110                                            gboolean           expand,
111                                            gboolean           open_all);
112   gboolean (* select_cursor_parent)       (GtkTreeView       *tree_view);
113   gboolean (* start_interactive_search)   (GtkTreeView       *tree_view);
114
115   /* Padding for future expansion */
116   void (*_gtk_reserved1) (void);
117   void (*_gtk_reserved2) (void);
118   void (*_gtk_reserved3) (void);
119   void (*_gtk_reserved4) (void);
120   void (*_gtk_reserved5) (void);
121   void (*_gtk_reserved6) (void);
122   void (*_gtk_reserved7) (void);
123   void (*_gtk_reserved8) (void);
124 };
125
126 /**
127  * GtkTreeViewColumnDropFunc:
128  * @tree_view: A #GtkTreeView
129  * @column: The #GtkTreeViewColumn being dragged
130  * @prev_column: A #GtkTreeViewColumn on one side of @column
131  * @next_column: A #GtkTreeViewColumn on the other side of @column
132  * @data: user data
133  *
134  * Function type for determining whether @column can be dropped in a
135  * particular spot (as determined by @prev_column and @next_column).  In
136  * left to right locales, @prev_column is on the left of the potential drop
137  * spot, and @next_column is on the right.  In right to left mode, this is
138  * reversed.  This function should return %TRUE if the spot is a valid drop
139  * spot.  Please note that returning %TRUE does not actually indicate that
140  * the column drop was made, but is meant only to indicate a possible drop
141  * spot to the user.
142  *
143  * Returns: %TRUE, if @column can be dropped in this spot
144  */
145 typedef gboolean (* GtkTreeViewColumnDropFunc) (GtkTreeView             *tree_view,
146                                                 GtkTreeViewColumn       *column,
147                                                 GtkTreeViewColumn       *prev_column,
148                                                 GtkTreeViewColumn       *next_column,
149                                                 gpointer                 data);
150
151 /**
152  * GtkTreeViewMappingFunc:
153  * @tree_view: A #GtkTreeView
154  * @path: The path that's expanded
155  * @user_data: user data
156  *
157  * Function used for gtk_tree_view_map_expanded_rows().
158  */
159 typedef void     (* GtkTreeViewMappingFunc)    (GtkTreeView             *tree_view,
160                                                 GtkTreePath             *path,
161                                                 gpointer                 user_data);
162
163 /**
164  * GtkTreeViewSearchEqualFunc:
165  * @model: the #GtkTreeModel being searched
166  * @column: the search column set by gtk_tree_view_set_search_column()
167  * @key: the key string to compare with
168  * @iter: a #GtkTreeIter pointing the row of @model that should be compared
169  *  with @key.
170  * @search_data: user data from gtk_tree_view_set_search_equal_func()
171  *
172  * A function used for checking whether a row in @model matches
173  * a search key string entered by the user. Note the return value
174  * is reversed from what you would normally expect, though it
175  * has some similarity to strcmp() returning 0 for equal strings.
176  *
177  * Returns: %FALSE if the row matches, %TRUE otherwise.
178  */
179 typedef gboolean (*GtkTreeViewSearchEqualFunc) (GtkTreeModel            *model,
180                                                 gint                     column,
181                                                 const gchar             *key,
182                                                 GtkTreeIter             *iter,
183                                                 gpointer                 search_data);
184
185 /**
186  * GtkTreeViewRowSeparatorFunc:
187  * @model: the #GtkTreeModel
188  * @iter: a #GtkTreeIter pointing at a row in @model
189  * @data: user data
190  *
191  * Function type for determining whether the row pointed to by @iter should
192  * be rendered as a separator. A common way to implement this is to have a
193  * boolean column in the model, whose values the #GtkTreeViewRowSeparatorFunc
194  * returns.
195  *
196  * Returns: %TRUE if the row is a separator
197  */
198 typedef gboolean (*GtkTreeViewRowSeparatorFunc) (GtkTreeModel      *model,
199                                                  GtkTreeIter       *iter,
200                                                  gpointer           data);
201 typedef void     (*GtkTreeViewSearchPositionFunc) (GtkTreeView  *tree_view,
202                                                    GtkWidget    *search_dialog,
203                                                    gpointer      user_data);
204
205
206 /* Creators */
207 GType                  gtk_tree_view_get_type                      (void) G_GNUC_CONST;
208 GtkWidget             *gtk_tree_view_new                           (void);
209 GtkWidget             *gtk_tree_view_new_with_model                (GtkTreeModel              *model);
210
211 /* Accessors */
212 GtkTreeModel          *gtk_tree_view_get_model                     (GtkTreeView               *tree_view);
213 void                   gtk_tree_view_set_model                     (GtkTreeView               *tree_view,
214                                                                     GtkTreeModel              *model);
215 GtkTreeSelection      *gtk_tree_view_get_selection                 (GtkTreeView               *tree_view);
216
217 #ifndef GTK_DISABLE_DEPRECATED
218
219 GtkAdjustment         *gtk_tree_view_get_hadjustment               (GtkTreeView               *tree_view);
220 void                   gtk_tree_view_set_hadjustment               (GtkTreeView               *tree_view,
221                                                                     GtkAdjustment             *adjustment);
222 GtkAdjustment         *gtk_tree_view_get_vadjustment               (GtkTreeView               *tree_view);
223 void                   gtk_tree_view_set_vadjustment               (GtkTreeView               *tree_view,
224                                                                     GtkAdjustment             *adjustment);
225
226 #endif
227
228 gboolean               gtk_tree_view_get_headers_visible           (GtkTreeView               *tree_view);
229 void                   gtk_tree_view_set_headers_visible           (GtkTreeView               *tree_view,
230                                                                     gboolean                   headers_visible);
231 void                   gtk_tree_view_columns_autosize              (GtkTreeView               *tree_view);
232 gboolean               gtk_tree_view_get_headers_clickable         (GtkTreeView *tree_view);
233 void                   gtk_tree_view_set_headers_clickable         (GtkTreeView               *tree_view,
234                                                                     gboolean                   setting);
235 void                   gtk_tree_view_set_rules_hint                (GtkTreeView               *tree_view,
236                                                                     gboolean                   setting);
237 gboolean               gtk_tree_view_get_rules_hint                (GtkTreeView               *tree_view);
238
239 /* Column funtions */
240 gint                   gtk_tree_view_append_column                 (GtkTreeView               *tree_view,
241                                                                     GtkTreeViewColumn         *column);
242 gint                   gtk_tree_view_remove_column                 (GtkTreeView               *tree_view,
243                                                                     GtkTreeViewColumn         *column);
244 gint                   gtk_tree_view_insert_column                 (GtkTreeView               *tree_view,
245                                                                     GtkTreeViewColumn         *column,
246                                                                     gint                       position);
247 gint                   gtk_tree_view_insert_column_with_attributes (GtkTreeView               *tree_view,
248                                                                     gint                       position,
249                                                                     const gchar               *title,
250                                                                     GtkCellRenderer           *cell,
251                                                                     ...) G_GNUC_NULL_TERMINATED;
252 gint                   gtk_tree_view_insert_column_with_data_func  (GtkTreeView               *tree_view,
253                                                                     gint                       position,
254                                                                     const gchar               *title,
255                                                                     GtkCellRenderer           *cell,
256                                                                     GtkTreeCellDataFunc        func,
257                                                                     gpointer                   data,
258                                                                     GDestroyNotify             dnotify);
259 GtkTreeViewColumn     *gtk_tree_view_get_column                    (GtkTreeView               *tree_view,
260                                                                     gint                       n);
261 GList                 *gtk_tree_view_get_columns                   (GtkTreeView               *tree_view);
262 void                   gtk_tree_view_move_column_after             (GtkTreeView               *tree_view,
263                                                                     GtkTreeViewColumn         *column,
264                                                                     GtkTreeViewColumn         *base_column);
265 void                   gtk_tree_view_set_expander_column           (GtkTreeView               *tree_view,
266                                                                     GtkTreeViewColumn         *column);
267 GtkTreeViewColumn     *gtk_tree_view_get_expander_column           (GtkTreeView               *tree_view);
268 void                   gtk_tree_view_set_column_drag_function      (GtkTreeView               *tree_view,
269                                                                     GtkTreeViewColumnDropFunc  func,
270                                                                     gpointer                   user_data,
271                                                                     GDestroyNotify             destroy);
272
273 /* Actions */
274 void                   gtk_tree_view_scroll_to_point               (GtkTreeView               *tree_view,
275                                                                     gint                       tree_x,
276                                                                     gint                       tree_y);
277 void                   gtk_tree_view_scroll_to_cell                (GtkTreeView               *tree_view,
278                                                                     GtkTreePath               *path,
279                                                                     GtkTreeViewColumn         *column,
280                                                                     gboolean                   use_align,
281                                                                     gfloat                     row_align,
282                                                                     gfloat                     col_align);
283 void                   gtk_tree_view_row_activated                 (GtkTreeView               *tree_view,
284                                                                     GtkTreePath               *path,
285                                                                     GtkTreeViewColumn         *column);
286 void                   gtk_tree_view_expand_all                    (GtkTreeView               *tree_view);
287 void                   gtk_tree_view_collapse_all                  (GtkTreeView               *tree_view);
288 void                   gtk_tree_view_expand_to_path                (GtkTreeView               *tree_view,
289                                                                     GtkTreePath               *path);
290 gboolean               gtk_tree_view_expand_row                    (GtkTreeView               *tree_view,
291                                                                     GtkTreePath               *path,
292                                                                     gboolean                   open_all);
293 gboolean               gtk_tree_view_collapse_row                  (GtkTreeView               *tree_view,
294                                                                     GtkTreePath               *path);
295 void                   gtk_tree_view_map_expanded_rows             (GtkTreeView               *tree_view,
296                                                                     GtkTreeViewMappingFunc     func,
297                                                                     gpointer                   data);
298 gboolean               gtk_tree_view_row_expanded                  (GtkTreeView               *tree_view,
299                                                                     GtkTreePath               *path);
300 void                   gtk_tree_view_set_reorderable               (GtkTreeView               *tree_view,
301                                                                     gboolean                   reorderable);
302 gboolean               gtk_tree_view_get_reorderable               (GtkTreeView               *tree_view);
303 void                   gtk_tree_view_set_cursor                    (GtkTreeView               *tree_view,
304                                                                     GtkTreePath               *path,
305                                                                     GtkTreeViewColumn         *focus_column,
306                                                                     gboolean                   start_editing);
307 void                   gtk_tree_view_set_cursor_on_cell            (GtkTreeView               *tree_view,
308                                                                     GtkTreePath               *path,
309                                                                     GtkTreeViewColumn         *focus_column,
310                                                                     GtkCellRenderer           *focus_cell,
311                                                                     gboolean                   start_editing);
312 void                   gtk_tree_view_get_cursor                    (GtkTreeView               *tree_view,
313                                                                     GtkTreePath              **path,
314                                                                     GtkTreeViewColumn        **focus_column);
315
316
317 /* Layout information */
318 GdkWindow             *gtk_tree_view_get_bin_window                (GtkTreeView               *tree_view);
319 gboolean               gtk_tree_view_get_path_at_pos               (GtkTreeView               *tree_view,
320                                                                     gint                       x,
321                                                                     gint                       y,
322                                                                     GtkTreePath              **path,
323                                                                     GtkTreeViewColumn        **column,
324                                                                     gint                      *cell_x,
325                                                                     gint                      *cell_y);
326 void                   gtk_tree_view_get_cell_area                 (GtkTreeView               *tree_view,
327                                                                     GtkTreePath               *path,
328                                                                     GtkTreeViewColumn         *column,
329                                                                     GdkRectangle              *rect);
330 void                   gtk_tree_view_get_background_area           (GtkTreeView               *tree_view,
331                                                                     GtkTreePath               *path,
332                                                                     GtkTreeViewColumn         *column,
333                                                                     GdkRectangle              *rect);
334 void                   gtk_tree_view_get_visible_rect              (GtkTreeView               *tree_view,
335                                                                     GdkRectangle              *visible_rect);
336 gboolean               gtk_tree_view_get_visible_range             (GtkTreeView               *tree_view,
337                                                                     GtkTreePath              **start_path,
338                                                                     GtkTreePath              **end_path);
339
340 /* Drag-and-Drop support */
341 void                   gtk_tree_view_enable_model_drag_source      (GtkTreeView               *tree_view,
342                                                                     GdkModifierType            start_button_mask,
343                                                                     const GtkTargetEntry      *targets,
344                                                                     gint                       n_targets,
345                                                                     GdkDragAction              actions);
346 void                   gtk_tree_view_enable_model_drag_dest        (GtkTreeView               *tree_view,
347                                                                     const GtkTargetEntry      *targets,
348                                                                     gint                       n_targets,
349                                                                     GdkDragAction              actions);
350 void                   gtk_tree_view_unset_rows_drag_source        (GtkTreeView               *tree_view);
351 void                   gtk_tree_view_unset_rows_drag_dest          (GtkTreeView               *tree_view);
352
353
354 /* These are useful to implement your own custom stuff. */
355 void                   gtk_tree_view_set_drag_dest_row             (GtkTreeView               *tree_view,
356                                                                     GtkTreePath               *path,
357                                                                     GtkTreeViewDropPosition    pos);
358 void                   gtk_tree_view_get_drag_dest_row             (GtkTreeView               *tree_view,
359                                                                     GtkTreePath              **path,
360                                                                     GtkTreeViewDropPosition   *pos);
361 gboolean               gtk_tree_view_get_dest_row_at_pos           (GtkTreeView               *tree_view,
362                                                                     gint                       drag_x,
363                                                                     gint                       drag_y,
364                                                                     GtkTreePath              **path,
365                                                                     GtkTreeViewDropPosition   *pos);
366 cairo_surface_t       *gtk_tree_view_create_row_drag_icon          (GtkTreeView               *tree_view,
367                                                                     GtkTreePath               *path);
368
369 /* Interactive search */
370 void                       gtk_tree_view_set_enable_search     (GtkTreeView                *tree_view,
371                                                                 gboolean                    enable_search);
372 gboolean                   gtk_tree_view_get_enable_search     (GtkTreeView                *tree_view);
373 gint                       gtk_tree_view_get_search_column     (GtkTreeView                *tree_view);
374 void                       gtk_tree_view_set_search_column     (GtkTreeView                *tree_view,
375                                                                 gint                        column);
376 GtkTreeViewSearchEqualFunc gtk_tree_view_get_search_equal_func (GtkTreeView                *tree_view);
377 void                       gtk_tree_view_set_search_equal_func (GtkTreeView                *tree_view,
378                                                                 GtkTreeViewSearchEqualFunc  search_equal_func,
379                                                                 gpointer                    search_user_data,
380                                                                 GDestroyNotify              search_destroy);
381
382 GtkEntry                     *gtk_tree_view_get_search_entry         (GtkTreeView                   *tree_view);
383 void                          gtk_tree_view_set_search_entry         (GtkTreeView                   *tree_view,
384                                                                       GtkEntry                      *entry);
385 GtkTreeViewSearchPositionFunc gtk_tree_view_get_search_position_func (GtkTreeView                   *tree_view);
386 void                          gtk_tree_view_set_search_position_func (GtkTreeView                   *tree_view,
387                                                                       GtkTreeViewSearchPositionFunc  func,
388                                                                       gpointer                       data,
389                                                                       GDestroyNotify                 destroy);
390
391 /* Convert between the different coordinate systems */
392 void gtk_tree_view_convert_widget_to_tree_coords       (GtkTreeView *tree_view,
393                                                         gint         wx,
394                                                         gint         wy,
395                                                         gint        *tx,
396                                                         gint        *ty);
397 void gtk_tree_view_convert_tree_to_widget_coords       (GtkTreeView *tree_view,
398                                                         gint         tx,
399                                                         gint         ty,
400                                                         gint        *wx,
401                                                         gint        *wy);
402 void gtk_tree_view_convert_widget_to_bin_window_coords (GtkTreeView *tree_view,
403                                                         gint         wx,
404                                                         gint         wy,
405                                                         gint        *bx,
406                                                         gint        *by);
407 void gtk_tree_view_convert_bin_window_to_widget_coords (GtkTreeView *tree_view,
408                                                         gint         bx,
409                                                         gint         by,
410                                                         gint        *wx,
411                                                         gint        *wy);
412 void gtk_tree_view_convert_tree_to_bin_window_coords   (GtkTreeView *tree_view,
413                                                         gint         tx,
414                                                         gint         ty,
415                                                         gint        *bx,
416                                                         gint        *by);
417 void gtk_tree_view_convert_bin_window_to_tree_coords   (GtkTreeView *tree_view,
418                                                         gint         bx,
419                                                         gint         by,
420                                                         gint        *tx,
421                                                         gint        *ty);
422
423 /* This function should really never be used.  It is just for use by ATK.
424  */
425 typedef void (* GtkTreeDestroyCountFunc)  (GtkTreeView             *tree_view,
426                                            GtkTreePath             *path,
427                                            gint                     children,
428                                            gpointer                 user_data);
429 void gtk_tree_view_set_destroy_count_func (GtkTreeView             *tree_view,
430                                            GtkTreeDestroyCountFunc  func,
431                                            gpointer                 data,
432                                            GDestroyNotify           destroy);
433
434 void     gtk_tree_view_set_fixed_height_mode (GtkTreeView          *tree_view,
435                                               gboolean              enable);
436 gboolean gtk_tree_view_get_fixed_height_mode (GtkTreeView          *tree_view);
437 void     gtk_tree_view_set_hover_selection   (GtkTreeView          *tree_view,
438                                               gboolean              hover);
439 gboolean gtk_tree_view_get_hover_selection   (GtkTreeView          *tree_view);
440 void     gtk_tree_view_set_hover_expand      (GtkTreeView          *tree_view,
441                                               gboolean              expand);
442 gboolean gtk_tree_view_get_hover_expand      (GtkTreeView          *tree_view);
443 void     gtk_tree_view_set_rubber_banding    (GtkTreeView          *tree_view,
444                                               gboolean              enable);
445 gboolean gtk_tree_view_get_rubber_banding    (GtkTreeView          *tree_view);
446
447 gboolean gtk_tree_view_is_rubber_banding_active (GtkTreeView       *tree_view);
448
449 GtkTreeViewRowSeparatorFunc gtk_tree_view_get_row_separator_func (GtkTreeView               *tree_view);
450 void                        gtk_tree_view_set_row_separator_func (GtkTreeView                *tree_view,
451                                                                   GtkTreeViewRowSeparatorFunc func,
452                                                                   gpointer                    data,
453                                                                   GDestroyNotify              destroy);
454
455 GtkTreeViewGridLines        gtk_tree_view_get_grid_lines         (GtkTreeView                *tree_view);
456 void                        gtk_tree_view_set_grid_lines         (GtkTreeView                *tree_view,
457                                                                   GtkTreeViewGridLines        grid_lines);
458 gboolean                    gtk_tree_view_get_enable_tree_lines  (GtkTreeView                *tree_view);
459 void                        gtk_tree_view_set_enable_tree_lines  (GtkTreeView                *tree_view,
460                                                                   gboolean                    enabled);
461 void                        gtk_tree_view_set_show_expanders     (GtkTreeView                *tree_view,
462                                                                   gboolean                    enabled);
463 gboolean                    gtk_tree_view_get_show_expanders     (GtkTreeView                *tree_view);
464 void                        gtk_tree_view_set_level_indentation  (GtkTreeView                *tree_view,
465                                                                   gint                        indentation);
466 gint                        gtk_tree_view_get_level_indentation  (GtkTreeView                *tree_view);
467
468 /* Convenience functions for setting tooltips */
469 void          gtk_tree_view_set_tooltip_row    (GtkTreeView       *tree_view,
470                                                 GtkTooltip        *tooltip,
471                                                 GtkTreePath       *path);
472 void          gtk_tree_view_set_tooltip_cell   (GtkTreeView       *tree_view,
473                                                 GtkTooltip        *tooltip,
474                                                 GtkTreePath       *path,
475                                                 GtkTreeViewColumn *column,
476                                                 GtkCellRenderer   *cell);
477 gboolean      gtk_tree_view_get_tooltip_context(GtkTreeView       *tree_view,
478                                                 gint              *x,
479                                                 gint              *y,
480                                                 gboolean           keyboard_tip,
481                                                 GtkTreeModel     **model,
482                                                 GtkTreePath      **path,
483                                                 GtkTreeIter       *iter);
484 void          gtk_tree_view_set_tooltip_column (GtkTreeView       *tree_view,
485                                                 gint               column);
486 gint          gtk_tree_view_get_tooltip_column (GtkTreeView       *tree_view);
487
488 G_END_DECLS
489
490
491 #endif /* __GTK_TREE_VIEW_H__ */