Compare commits

...

3 Commits

Author SHA1 Message Date
Matthias Clasen
cd8a810d69 slicelistmodel: Make constructor transfer full
This is for consistency with other wrapping list constructors.
We want them all to be transfer full, allow-none.

Update all callers.
2020-07-26 15:38:15 -04:00
Matthias Clasen
8f63a5ab63 listlistmodel: Drop item_type
We are using G_TYPE_OBJECT throughout, so there
is no need for GtkListListModel to do anything else.

Update all callers.
2020-07-26 14:37:55 -04:00
Matthias Clasen
eb3381723f maplistmodel: Make constructor transfer full
This is for consistency with other wrapping list constructors.
We want them all to be transfer full, allow-none.

Update all callers.
2020-07-26 14:23:16 -04:00
7 changed files with 33 additions and 35 deletions

View File

@@ -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;

View File

@@ -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),

View File

@@ -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);

View File

@@ -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;
} }
/** /**

View File

@@ -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);
} }

View File

@@ -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));

View File

@@ -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);