2019-12-03 04:43:14 +00:00
|
|
|
/*
|
|
|
|
* Copyright © 2019 Matthias Clasen
|
|
|
|
*
|
|
|
|
* 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.1 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, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* Authors: Matthias Clasen <mclasen@redhat.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include "gtkcustomsorter.h"
|
|
|
|
|
|
|
|
#include "gtkintl.h"
|
|
|
|
#include "gtktypebuiltins.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* SECTION:gtkcustomsorter
|
|
|
|
* @Title: GtkCustomSorter
|
2020-07-17 01:45:11 +00:00
|
|
|
* @Short_description: Sorting with a callbacks
|
2019-12-03 04:43:14 +00:00
|
|
|
*
|
|
|
|
* GtkCustomSorter is a #GtkSorter implementation that sorts
|
|
|
|
* via a traditional #GCompareDataFunc callback.
|
|
|
|
*/
|
|
|
|
struct _GtkCustomSorter
|
|
|
|
{
|
|
|
|
GtkSorter parent_instance;
|
|
|
|
|
|
|
|
GCompareDataFunc sort_func;
|
|
|
|
gpointer user_data;
|
|
|
|
GDestroyNotify user_destroy;
|
|
|
|
};
|
|
|
|
|
|
|
|
G_DEFINE_TYPE (GtkCustomSorter, gtk_custom_sorter, GTK_TYPE_SORTER)
|
|
|
|
|
|
|
|
static GtkOrdering
|
|
|
|
gtk_custom_sorter_compare (GtkSorter *sorter,
|
|
|
|
gpointer item1,
|
|
|
|
gpointer item2)
|
|
|
|
{
|
|
|
|
GtkCustomSorter *self = GTK_CUSTOM_SORTER (sorter);
|
|
|
|
|
|
|
|
if (!self->sort_func)
|
|
|
|
return GTK_ORDERING_EQUAL;
|
|
|
|
|
|
|
|
return gtk_ordering_from_cmpfunc (self->sort_func (item1, item2, self->user_data));
|
|
|
|
}
|
|
|
|
|
|
|
|
static GtkSorterOrder
|
|
|
|
gtk_custom_sorter_get_order (GtkSorter *sorter)
|
|
|
|
{
|
|
|
|
GtkCustomSorter *self = GTK_CUSTOM_SORTER (sorter);
|
|
|
|
|
|
|
|
if (!self->sort_func)
|
|
|
|
return GTK_SORTER_ORDER_NONE;
|
|
|
|
|
|
|
|
return GTK_SORTER_ORDER_PARTIAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gtk_custom_sorter_dispose (GObject *object)
|
|
|
|
{
|
|
|
|
GtkCustomSorter *self = GTK_CUSTOM_SORTER (object);
|
|
|
|
|
|
|
|
if (self->user_destroy)
|
|
|
|
self->user_destroy (self->user_data);
|
|
|
|
|
|
|
|
self->sort_func = NULL;
|
|
|
|
self->user_destroy = NULL;
|
|
|
|
self->user_data = NULL;
|
|
|
|
|
|
|
|
G_OBJECT_CLASS (gtk_custom_sorter_parent_class)->dispose (object);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gtk_custom_sorter_class_init (GtkCustomSorterClass *class)
|
|
|
|
{
|
|
|
|
GtkSorterClass *sorter_class = GTK_SORTER_CLASS (class);
|
|
|
|
GObjectClass *object_class = G_OBJECT_CLASS (class);
|
|
|
|
|
|
|
|
sorter_class->compare = gtk_custom_sorter_compare;
|
|
|
|
sorter_class->get_order = gtk_custom_sorter_get_order;
|
|
|
|
|
|
|
|
object_class->dispose = gtk_custom_sorter_dispose;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gtk_custom_sorter_init (GtkCustomSorter *self)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gtk_custom_sorter_new:
|
2020-12-04 23:04:36 +00:00
|
|
|
* @sort_func: (nullable): the #GCompareDataFunc to use for sorting
|
2019-12-03 04:43:14 +00:00
|
|
|
* @user_data: (nullable): user data to pass to @sort_func
|
|
|
|
* @user_destroy: (nullable): destroy notify for @user_data
|
|
|
|
*
|
|
|
|
* Creates a new #GtkSorter that works by calling
|
|
|
|
* @sort_func to compare items.
|
|
|
|
*
|
2020-07-17 01:45:11 +00:00
|
|
|
* If @sort_func is %NULL, all items are considered equal.
|
|
|
|
*
|
2020-08-03 19:54:42 +00:00
|
|
|
* Returns: a new #GtkCustomSorter
|
2020-07-17 01:45:11 +00:00
|
|
|
*/
|
2020-08-03 19:54:42 +00:00
|
|
|
GtkCustomSorter *
|
2019-12-03 04:43:14 +00:00
|
|
|
gtk_custom_sorter_new (GCompareDataFunc sort_func,
|
|
|
|
gpointer user_data,
|
|
|
|
GDestroyNotify user_destroy)
|
|
|
|
{
|
|
|
|
GtkCustomSorter *sorter;
|
|
|
|
|
|
|
|
sorter = g_object_new (GTK_TYPE_CUSTOM_SORTER, NULL);
|
|
|
|
|
|
|
|
gtk_custom_sorter_set_sort_func (sorter, sort_func, user_data, user_destroy);
|
|
|
|
|
2020-08-03 19:54:42 +00:00
|
|
|
return sorter;
|
2019-12-03 04:43:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gtk_custom_sorter_set_sort_func:
|
|
|
|
* @self: a #GtkCustomSorter
|
|
|
|
* @sort_func: (nullable): function to sort items
|
|
|
|
* @user_data: (nullable): user data to pass to @match_func
|
2020-07-17 01:45:11 +00:00
|
|
|
* @user_destroy: destroy notify for @user_data
|
2019-12-03 04:43:14 +00:00
|
|
|
*
|
|
|
|
* Sets (or unsets) the function used for sorting items.
|
2020-07-17 01:45:11 +00:00
|
|
|
*
|
|
|
|
* If @sort_func is %NULL, all items are considered equal.
|
|
|
|
*
|
2019-12-03 04:43:14 +00:00
|
|
|
* If the sort func changes its sorting behavior,
|
|
|
|
* gtk_sorter_changed() needs to be called.
|
|
|
|
*
|
|
|
|
* If a previous function was set, its @user_destroy will be
|
|
|
|
* called now.
|
|
|
|
**/
|
|
|
|
void
|
|
|
|
gtk_custom_sorter_set_sort_func (GtkCustomSorter *self,
|
|
|
|
GCompareDataFunc sort_func,
|
|
|
|
gpointer user_data,
|
|
|
|
GDestroyNotify user_destroy)
|
|
|
|
{
|
|
|
|
g_return_if_fail (GTK_IS_CUSTOM_SORTER (self));
|
|
|
|
g_return_if_fail (sort_func || (user_data == NULL && !user_destroy));
|
|
|
|
|
|
|
|
if (self->user_destroy)
|
|
|
|
self->user_destroy (self->user_data);
|
|
|
|
|
|
|
|
self->sort_func = sort_func;
|
|
|
|
self->user_data = user_data;
|
|
|
|
self->user_destroy = user_destroy;
|
|
|
|
|
|
|
|
gtk_sorter_changed (GTK_SORTER (self), GTK_SORTER_CHANGE_DIFFERENT);
|
|
|
|
}
|