Compare commits
3 Commits
flatten-li
...
slice-list
Author | SHA1 | Date | |
---|---|---|---|
|
cd8a810d69 | ||
|
8f63a5ab63 | ||
|
eb3381723f |
@@ -36,7 +36,6 @@ struct _GtkListListModel
|
|||||||
{
|
{
|
||||||
GObject parent_instance;
|
GObject parent_instance;
|
||||||
|
|
||||||
GType item_type;
|
|
||||||
guint n_items;
|
guint n_items;
|
||||||
gpointer (* get_first) (gpointer);
|
gpointer (* get_first) (gpointer);
|
||||||
gpointer (* get_next) (gpointer, gpointer);
|
gpointer (* get_next) (gpointer, gpointer);
|
||||||
@@ -55,9 +54,7 @@ struct _GtkListListModelClass
|
|||||||
static GType
|
static GType
|
||||||
gtk_list_list_model_get_item_type (GListModel *list)
|
gtk_list_list_model_get_item_type (GListModel *list)
|
||||||
{
|
{
|
||||||
GtkListListModel *self = GTK_LIST_LIST_MODEL (list);
|
return G_TYPE_OBJECT;
|
||||||
|
|
||||||
return self->item_type;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static guint
|
static guint
|
||||||
@@ -143,8 +140,7 @@ gtk_list_list_model_init (GtkListListModel *self)
|
|||||||
}
|
}
|
||||||
|
|
||||||
GtkListListModel *
|
GtkListListModel *
|
||||||
gtk_list_list_model_new (GType item_type,
|
gtk_list_list_model_new (gpointer (* get_first) (gpointer),
|
||||||
gpointer (* get_first) (gpointer),
|
|
||||||
gpointer (* get_next) (gpointer, gpointer),
|
gpointer (* get_next) (gpointer, gpointer),
|
||||||
gpointer (* get_previous) (gpointer, gpointer),
|
gpointer (* get_previous) (gpointer, gpointer),
|
||||||
gpointer (* get_last) (gpointer),
|
gpointer (* get_last) (gpointer),
|
||||||
@@ -161,8 +157,7 @@ gtk_list_list_model_new (GType item_type,
|
|||||||
item = get_next (item, data))
|
item = get_next (item, data))
|
||||||
n_items++;
|
n_items++;
|
||||||
|
|
||||||
return gtk_list_list_model_new_with_size (item_type,
|
return gtk_list_list_model_new_with_size (n_items,
|
||||||
n_items,
|
|
||||||
get_first,
|
get_first,
|
||||||
get_next,
|
get_next,
|
||||||
get_previous,
|
get_previous,
|
||||||
@@ -173,8 +168,7 @@ gtk_list_list_model_new (GType item_type,
|
|||||||
}
|
}
|
||||||
|
|
||||||
GtkListListModel *
|
GtkListListModel *
|
||||||
gtk_list_list_model_new_with_size (GType item_type,
|
gtk_list_list_model_new_with_size (guint n_items,
|
||||||
guint n_items,
|
|
||||||
gpointer (* get_first) (gpointer),
|
gpointer (* get_first) (gpointer),
|
||||||
gpointer (* get_next) (gpointer, gpointer),
|
gpointer (* get_next) (gpointer, gpointer),
|
||||||
gpointer (* get_previous) (gpointer, gpointer),
|
gpointer (* get_previous) (gpointer, gpointer),
|
||||||
@@ -185,7 +179,6 @@ gtk_list_list_model_new_with_size (GType item_type,
|
|||||||
{
|
{
|
||||||
GtkListListModel *result;
|
GtkListListModel *result;
|
||||||
|
|
||||||
g_return_val_if_fail (g_type_is_a (item_type, G_TYPE_OBJECT), NULL);
|
|
||||||
g_return_val_if_fail (get_first != NULL, NULL);
|
g_return_val_if_fail (get_first != NULL, NULL);
|
||||||
g_return_val_if_fail (get_next != NULL, NULL);
|
g_return_val_if_fail (get_next != NULL, NULL);
|
||||||
g_return_val_if_fail (get_previous != NULL, NULL);
|
g_return_val_if_fail (get_previous != NULL, NULL);
|
||||||
@@ -193,7 +186,6 @@ gtk_list_list_model_new_with_size (GType item_type,
|
|||||||
|
|
||||||
result = g_object_new (GTK_TYPE_LIST_LIST_MODEL, NULL);
|
result = g_object_new (GTK_TYPE_LIST_LIST_MODEL, NULL);
|
||||||
|
|
||||||
result->item_type = item_type;
|
|
||||||
result->n_items = n_items;
|
result->n_items = n_items;
|
||||||
result->get_first = get_first;
|
result->get_first = get_first;
|
||||||
result->get_next = get_next;
|
result->get_next = get_next;
|
||||||
|
@@ -37,8 +37,7 @@ typedef struct _GtkListListModelClass GtkListListModelClass;
|
|||||||
|
|
||||||
GType gtk_list_list_model_get_type (void) G_GNUC_CONST;
|
GType gtk_list_list_model_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
GtkListListModel * gtk_list_list_model_new (GType item_type,
|
GtkListListModel * gtk_list_list_model_new (gpointer (* get_first) (gpointer),
|
||||||
gpointer (* get_first) (gpointer),
|
|
||||||
gpointer (* get_next) (gpointer, gpointer),
|
gpointer (* get_next) (gpointer, gpointer),
|
||||||
gpointer (* get_previous) (gpointer, gpointer),
|
gpointer (* get_previous) (gpointer, gpointer),
|
||||||
gpointer (* get_last) (gpointer),
|
gpointer (* get_last) (gpointer),
|
||||||
@@ -46,8 +45,7 @@ GtkListListModel * gtk_list_list_model_new (GType
|
|||||||
gpointer data,
|
gpointer data,
|
||||||
GDestroyNotify notify);
|
GDestroyNotify notify);
|
||||||
|
|
||||||
GtkListListModel * gtk_list_list_model_new_with_size (GType item_type,
|
GtkListListModel * gtk_list_list_model_new_with_size (guint n_items,
|
||||||
guint n_items,
|
|
||||||
gpointer (* get_first) (gpointer),
|
gpointer (* get_first) (gpointer),
|
||||||
gpointer (* get_next) (gpointer, gpointer),
|
gpointer (* get_next) (gpointer, gpointer),
|
||||||
gpointer (* get_previous) (gpointer, gpointer),
|
gpointer (* get_previous) (gpointer, gpointer),
|
||||||
|
@@ -412,7 +412,7 @@ gtk_map_list_model_augment (GtkRbTree *map,
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* gtk_map_list_model_new:
|
* gtk_map_list_model_new:
|
||||||
* @model: (allow-none): The model to map or %NULL for none
|
* @model: (transfer full) (allow-none): The model to map or %NULL for none
|
||||||
* @map_func: (allow-none): map function or %NULL to not map items
|
* @map_func: (allow-none): map function or %NULL to not map items
|
||||||
* @user_data: (closure): user data passed to @map_func
|
* @user_data: (closure): user data passed to @map_func
|
||||||
* @user_destroy: destroy notifier for @user_data
|
* @user_destroy: destroy notifier for @user_data
|
||||||
@@ -435,6 +435,9 @@ gtk_map_list_model_new (GListModel *model,
|
|||||||
"model", model,
|
"model", model,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
|
/* consume the reference */
|
||||||
|
g_clear_object (&model);
|
||||||
|
|
||||||
if (map_func)
|
if (map_func)
|
||||||
gtk_map_list_model_set_map_func (result, map_func, user_data, user_destroy);
|
gtk_map_list_model_set_map_func (result, map_func, user_data, user_destroy);
|
||||||
|
|
||||||
|
@@ -30,11 +30,12 @@
|
|||||||
* @short_description: A list model that presents a slice out of a larger list
|
* @short_description: A list model that presents a slice out of a larger list
|
||||||
* @see_also: #GListModel
|
* @see_also: #GListModel
|
||||||
*
|
*
|
||||||
* #GtkSliceListModel is a list model that takes a list model and presents a slice of
|
* #GtkSliceListModel is a list model that takes a list model and presents a
|
||||||
* that model.
|
* slice of that model.
|
||||||
*
|
*
|
||||||
* This is useful when implementing paging by setting the size to the number of elements
|
* This is useful when implementing paging by setting the size to the number
|
||||||
* per page and updating the offset whenever a different page is opened.
|
* of elements per page and updating the offset whenever a different page is
|
||||||
|
* opened.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define DEFAULT_SIZE 10
|
#define DEFAULT_SIZE 10
|
||||||
@@ -300,7 +301,7 @@ gtk_slice_list_model_init (GtkSliceListModel *self)
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* gtk_slice_list_model_new:
|
* gtk_slice_list_model_new:
|
||||||
* @model: (transfer none) (allow-none): The model to use
|
* @model: (transfer full) (allow-none): The model to use, or %NULL
|
||||||
* @offset: the offset of the slice
|
* @offset: the offset of the slice
|
||||||
* @size: maximum size of the slice
|
* @size: maximum size of the slice
|
||||||
*
|
*
|
||||||
@@ -314,13 +315,20 @@ gtk_slice_list_model_new (GListModel *model,
|
|||||||
guint offset,
|
guint offset,
|
||||||
guint size)
|
guint size)
|
||||||
{
|
{
|
||||||
|
GtkSliceListModel *self;
|
||||||
|
|
||||||
g_return_val_if_fail (model == NULL || G_IS_LIST_MODEL (model), NULL);
|
g_return_val_if_fail (model == NULL || G_IS_LIST_MODEL (model), NULL);
|
||||||
|
|
||||||
return g_object_new (GTK_TYPE_SLICE_LIST_MODEL,
|
self = g_object_new (GTK_TYPE_SLICE_LIST_MODEL,
|
||||||
"model", model,
|
"model", model,
|
||||||
"offset", offset,
|
"offset", offset,
|
||||||
"size", size,
|
"size", size,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
|
/* consume the reference */
|
||||||
|
g_clear_object (&model);
|
||||||
|
|
||||||
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -11535,8 +11535,7 @@ gtk_widget_observe_children (GtkWidget *widget)
|
|||||||
if (priv->children_observer)
|
if (priv->children_observer)
|
||||||
return g_object_ref (G_LIST_MODEL (priv->children_observer));
|
return g_object_ref (G_LIST_MODEL (priv->children_observer));
|
||||||
|
|
||||||
priv->children_observer = gtk_list_list_model_new (GTK_TYPE_WIDGET,
|
priv->children_observer = gtk_list_list_model_new ((gpointer) gtk_widget_get_first_child,
|
||||||
(gpointer) gtk_widget_get_first_child,
|
|
||||||
(gpointer) gtk_widget_get_next_sibling,
|
(gpointer) gtk_widget_get_next_sibling,
|
||||||
(gpointer) gtk_widget_get_prev_sibling,
|
(gpointer) gtk_widget_get_prev_sibling,
|
||||||
(gpointer) gtk_widget_get_last_child,
|
(gpointer) gtk_widget_get_last_child,
|
||||||
@@ -11622,14 +11621,13 @@ gtk_widget_observe_controllers (GtkWidget *widget)
|
|||||||
if (priv->controller_observer)
|
if (priv->controller_observer)
|
||||||
return g_object_ref (G_LIST_MODEL (priv->controller_observer));
|
return g_object_ref (G_LIST_MODEL (priv->controller_observer));
|
||||||
|
|
||||||
priv->controller_observer = gtk_list_list_model_new (GTK_TYPE_EVENT_CONTROLLER,
|
priv->controller_observer = gtk_list_list_model_new (gtk_widget_controller_list_get_first,
|
||||||
gtk_widget_controller_list_get_first,
|
gtk_widget_controller_list_get_next,
|
||||||
gtk_widget_controller_list_get_next,
|
gtk_widget_controller_list_get_prev,
|
||||||
gtk_widget_controller_list_get_prev,
|
NULL,
|
||||||
NULL,
|
(gpointer) g_object_ref,
|
||||||
(gpointer) g_object_ref,
|
widget,
|
||||||
widget,
|
gtk_widget_controller_observer_destroyed);
|
||||||
gtk_widget_controller_observer_destroyed);
|
|
||||||
|
|
||||||
return G_LIST_MODEL (priv->controller_observer);
|
return G_LIST_MODEL (priv->controller_observer);
|
||||||
}
|
}
|
||||||
|
@@ -244,7 +244,6 @@ gtk_inspector_controllers_set_object (GtkInspectorControllers *self,
|
|||||||
gtk_property_lookup_list_model_set_object (self->model, object);
|
gtk_property_lookup_list_model_set_object (self->model, object);
|
||||||
|
|
||||||
map_model = gtk_map_list_model_new (G_LIST_MODEL (self->model), map_to_controllers, NULL, NULL);
|
map_model = gtk_map_list_model_new (G_LIST_MODEL (self->model), map_to_controllers, NULL, NULL);
|
||||||
g_object_unref (self->model);
|
|
||||||
|
|
||||||
flatten_model = gtk_flatten_list_model_new (G_LIST_MODEL (map_model));
|
flatten_model = gtk_flatten_list_model_new (G_LIST_MODEL (map_model));
|
||||||
|
|
||||||
|
@@ -196,7 +196,7 @@ new_model (GListStore *store)
|
|||||||
GtkMapListModel *result;
|
GtkMapListModel *result;
|
||||||
GString *changes;
|
GString *changes;
|
||||||
|
|
||||||
result = gtk_map_list_model_new (G_LIST_MODEL (store), map_multiply, GUINT_TO_POINTER (2), NULL);
|
result = gtk_map_list_model_new (g_object_ref (G_LIST_MODEL (store)), map_multiply, GUINT_TO_POINTER (2), NULL);
|
||||||
changes = g_string_new ("");
|
changes = g_string_new ("");
|
||||||
g_object_set_qdata_full (G_OBJECT(result), changes_quark, changes, free_changes);
|
g_object_set_qdata_full (G_OBJECT(result), changes_quark, changes, free_changes);
|
||||||
g_signal_connect (result, "items-changed", G_CALLBACK (items_changed), changes);
|
g_signal_connect (result, "items-changed", G_CALLBACK (items_changed), changes);
|
||||||
|
Reference in New Issue
Block a user