2003-07-11 12:51:24 +00:00
|
|
|
|
/* gtktreemodelfilter.h
|
|
|
|
|
* Copyright (C) 2000,2001 Red Hat, Inc., Jonathan Blandford <jrb@redhat.com>
|
|
|
|
|
* Copyright (C) 2001-2003 Kristian Rietveld <kris@gtk.org>
|
|
|
|
|
*
|
2003-10-24 18:36:55 +00:00
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
2003-07-11 12:51:24 +00:00
|
|
|
|
*
|
2003-10-24 18:36:55 +00:00
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
2003-07-11 12:51:24 +00:00
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
2003-10-24 18:36:55 +00:00
|
|
|
|
* Library General Public License for more details.
|
2003-07-11 12:51:24 +00:00
|
|
|
|
*
|
2003-10-24 18:36:55 +00:00
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
2012-02-27 13:01:10 +00:00
|
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
2003-07-11 12:51:24 +00:00
|
|
|
|
*/
|
|
|
|
|
|
2012-12-28 14:57:34 +00:00
|
|
|
|
#ifndef __GTK_TREE_MODEL_FILTER_H__
|
|
|
|
|
#define __GTK_TREE_MODEL_FILTER_H__
|
|
|
|
|
|
2009-10-21 18:30:04 +00:00
|
|
|
|
#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
|
2008-05-28 15:07:04 +00:00
|
|
|
|
#error "Only <gtk/gtk.h> can be included directly."
|
|
|
|
|
#endif
|
|
|
|
|
|
2003-07-11 12:51:24 +00:00
|
|
|
|
#include <gtk/gtktreemodel.h>
|
|
|
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
|
|
#define GTK_TYPE_TREE_MODEL_FILTER (gtk_tree_model_filter_get_type ())
|
|
|
|
|
#define GTK_TREE_MODEL_FILTER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_TREE_MODEL_FILTER, GtkTreeModelFilter))
|
|
|
|
|
#define GTK_TREE_MODEL_FILTER_CLASS(vtable) (G_TYPE_CHECK_CLASS_CAST ((vtable), GTK_TYPE_TREE_MODEL_FILTER, GtkTreeModelFilterClass))
|
|
|
|
|
#define GTK_IS_TREE_MODEL_FILTER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_TREE_MODEL_FILTER))
|
|
|
|
|
#define GTK_IS_TREE_MODEL_FILTER_CLASS(vtable) (G_TYPE_CHECK_CLASS_TYPE ((vtable), GTK_TYPE_TREE_MODEL_FILTER))
|
2009-12-09 04:48:58 +00:00
|
|
|
|
#define GTK_TREE_MODEL_FILTER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_TREE_MODEL_FILTER, GtkTreeModelFilterClass))
|
2003-07-11 12:51:24 +00:00
|
|
|
|
|
2010-10-22 20:32:10 +00:00
|
|
|
|
/**
|
|
|
|
|
* GtkTreeModelFilterVisibleFunc:
|
2021-05-20 13:17:04 +00:00
|
|
|
|
* @model: the child model of the `GtkTreeModelFilter`
|
|
|
|
|
* @iter: a `GtkTreeIter` pointing to the row in @model whose visibility
|
2010-10-22 20:32:10 +00:00
|
|
|
|
* is determined
|
2011-01-18 05:28:24 +00:00
|
|
|
|
* @data: (closure): user data given to gtk_tree_model_filter_set_visible_func()
|
2010-10-22 20:32:10 +00:00
|
|
|
|
*
|
|
|
|
|
* A function which decides whether the row indicated by @iter is visible.
|
|
|
|
|
*
|
|
|
|
|
* Returns: Whether the row indicated by @iter is visible.
|
|
|
|
|
*/
|
2003-07-11 12:51:24 +00:00
|
|
|
|
typedef gboolean (* GtkTreeModelFilterVisibleFunc) (GtkTreeModel *model,
|
|
|
|
|
GtkTreeIter *iter,
|
|
|
|
|
gpointer data);
|
2010-10-22 20:32:10 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* GtkTreeModelFilterModifyFunc:
|
2021-05-20 13:17:04 +00:00
|
|
|
|
* @model: the `GtkTreeModelFilter`
|
|
|
|
|
* @iter: a `GtkTreeIter` pointing to the row whose display values are determined
|
|
|
|
|
* @value: (out caller-allocates): A `GValue` which is already initialized for
|
2013-11-28 00:54:09 +00:00
|
|
|
|
* with the correct type for the column @column.
|
2010-10-22 20:32:10 +00:00
|
|
|
|
* @column: the column whose display value is determined
|
2011-01-18 05:28:24 +00:00
|
|
|
|
* @data: (closure): user data given to gtk_tree_model_filter_set_modify_func()
|
2010-10-22 20:32:10 +00:00
|
|
|
|
*
|
|
|
|
|
* A function which calculates display values from raw values in the model.
|
|
|
|
|
* It must fill @value with the display value for the column @column in the
|
|
|
|
|
* row indicated by @iter.
|
|
|
|
|
*
|
2014-02-07 18:01:26 +00:00
|
|
|
|
* Since this function is called for each data access, it’s not a
|
2010-10-22 20:32:10 +00:00
|
|
|
|
* particularly efficient operation.
|
|
|
|
|
*/
|
|
|
|
|
|
2003-07-11 12:51:24 +00:00
|
|
|
|
typedef void (* GtkTreeModelFilterModifyFunc) (GtkTreeModel *model,
|
|
|
|
|
GtkTreeIter *iter,
|
|
|
|
|
GValue *value,
|
2020-07-24 13:54:49 +00:00
|
|
|
|
int column,
|
2003-07-11 12:51:24 +00:00
|
|
|
|
gpointer data);
|
|
|
|
|
|
|
|
|
|
typedef struct _GtkTreeModelFilter GtkTreeModelFilter;
|
|
|
|
|
typedef struct _GtkTreeModelFilterClass GtkTreeModelFilterClass;
|
|
|
|
|
typedef struct _GtkTreeModelFilterPrivate GtkTreeModelFilterPrivate;
|
|
|
|
|
|
|
|
|
|
struct _GtkTreeModelFilter
|
|
|
|
|
{
|
|
|
|
|
GObject parent;
|
|
|
|
|
|
|
|
|
|
/*< private >*/
|
2010-07-14 00:19:36 +00:00
|
|
|
|
GtkTreeModelFilterPrivate *priv;
|
2003-07-11 12:51:24 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct _GtkTreeModelFilterClass
|
|
|
|
|
{
|
|
|
|
|
GObjectClass parent_class;
|
2003-10-24 18:26:13 +00:00
|
|
|
|
|
2009-12-09 09:21:34 +00:00
|
|
|
|
gboolean (* visible) (GtkTreeModelFilter *self,
|
|
|
|
|
GtkTreeModel *child_model,
|
|
|
|
|
GtkTreeIter *iter);
|
|
|
|
|
void (* modify) (GtkTreeModelFilter *self,
|
|
|
|
|
GtkTreeModel *child_model,
|
|
|
|
|
GtkTreeIter *iter,
|
|
|
|
|
GValue *value,
|
2020-07-24 13:54:49 +00:00
|
|
|
|
int column);
|
2009-12-09 09:21:34 +00:00
|
|
|
|
|
2019-05-29 02:23:08 +00:00
|
|
|
|
/*< private >*/
|
|
|
|
|
|
|
|
|
|
gpointer padding[8];
|
2003-07-11 12:51:24 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* base */
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2004-11-23 20:02:15 +00:00
|
|
|
|
GType gtk_tree_model_filter_get_type (void) G_GNUC_CONST;
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
GtkTreeModel *gtk_tree_model_filter_new (GtkTreeModel *child_model,
|
|
|
|
|
GtkTreePath *root);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
void gtk_tree_model_filter_set_visible_func (GtkTreeModelFilter *filter,
|
|
|
|
|
GtkTreeModelFilterVisibleFunc func,
|
|
|
|
|
gpointer data,
|
2008-06-18 09:12:32 +00:00
|
|
|
|
GDestroyNotify destroy);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
void gtk_tree_model_filter_set_modify_func (GtkTreeModelFilter *filter,
|
2020-07-24 13:54:49 +00:00
|
|
|
|
int n_columns,
|
2003-07-11 12:51:24 +00:00
|
|
|
|
GType *types,
|
|
|
|
|
GtkTreeModelFilterModifyFunc func,
|
|
|
|
|
gpointer data,
|
2008-06-18 09:12:32 +00:00
|
|
|
|
GDestroyNotify destroy);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
void gtk_tree_model_filter_set_visible_column (GtkTreeModelFilter *filter,
|
2020-07-24 13:54:49 +00:00
|
|
|
|
int column);
|
2003-07-11 12:51:24 +00:00
|
|
|
|
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
GtkTreeModel *gtk_tree_model_filter_get_model (GtkTreeModelFilter *filter);
|
|
|
|
|
|
|
|
|
|
/* conversion */
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-06-12 14:48:43 +00:00
|
|
|
|
gboolean gtk_tree_model_filter_convert_child_iter_to_iter (GtkTreeModelFilter *filter,
|
2003-07-11 12:51:24 +00:00
|
|
|
|
GtkTreeIter *filter_iter,
|
|
|
|
|
GtkTreeIter *child_iter);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
void gtk_tree_model_filter_convert_iter_to_child_iter (GtkTreeModelFilter *filter,
|
|
|
|
|
GtkTreeIter *child_iter,
|
|
|
|
|
GtkTreeIter *filter_iter);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
GtkTreePath *gtk_tree_model_filter_convert_child_path_to_path (GtkTreeModelFilter *filter,
|
|
|
|
|
GtkTreePath *child_path);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2004-01-22 23:47:42 +00:00
|
|
|
|
GtkTreePath *gtk_tree_model_filter_convert_path_to_child_path (GtkTreeModelFilter *filter,
|
2003-07-11 12:51:24 +00:00
|
|
|
|
GtkTreePath *filter_path);
|
|
|
|
|
|
|
|
|
|
/* extras */
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
void gtk_tree_model_filter_refilter (GtkTreeModelFilter *filter);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2003-07-11 12:51:24 +00:00
|
|
|
|
void gtk_tree_model_filter_clear_cache (GtkTreeModelFilter *filter);
|
|
|
|
|
|
2022-09-24 01:54:15 +00:00
|
|
|
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(GtkTreeModelFilter, g_object_unref)
|
|
|
|
|
|
2003-07-11 12:51:24 +00:00
|
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
|
|
#endif /* __GTK_TREE_MODEL_FILTER_H__ */
|