diff options
author | Matthias Clasen <mclasen@redhat.com> | 2023-05-17 12:30:16 -0400 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2023-05-17 12:31:16 -0400 |
commit | e121a5ca6f761fc4433187bf1ad13a093ede205d (patch) | |
tree | 834c25d985eaf575a8df142d6df44c0afb42a928 | |
parent | e79851502c27105ad8c6a205bb577e70ee6681a4 (diff) | |
download | gtk+-e121a5ca6f761fc4433187bf1ad13a093ede205d.tar.gz |
gridview: GC tiles first
Before checking that there are no tiles,
we need to gc any possibly leftover filler
tiles.
Fixes: #5836
-rw-r--r-- | gtk/gtkgridview.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/gtk/gtkgridview.c b/gtk/gtkgridview.c index 885826a138..438fd3dfa6 100644 --- a/gtk/gtkgridview.c +++ b/gtk/gtkgridview.c @@ -756,8 +756,14 @@ gtk_grid_view_size_allocate (GtkWidget *widget, min_row_height = ceil ((double) height / GTK_GRID_VIEW_MAX_VISIBLE_ROWS); gtk_list_base_get_border_spacing (GTK_LIST_BASE (self), &xspacing, &yspacing); + /* before we start: gc tiles */ + for (tile = gtk_list_tile_gc (self->item_manager, gtk_list_item_manager_get_first (self->item_manager)); + tile != NULL && tile->type == GTK_LIST_TILE_FILLER; + tile = gtk_list_tile_gc (self->item_manager, tile)) + {}; + /* step 0: exit early if list is empty */ - tile = gtk_list_tile_gc (self->item_manager, gtk_list_item_manager_get_first (self->item_manager)); + tile = gtk_list_item_manager_get_first (self->item_manager); if (tile == NULL) { gtk_list_base_allocate (GTK_LIST_BASE (self)); |