gtklistbox: Add remove_all()
authorChristopher Davis <christopherdavis@gnome.org>
Wed, 29 Sep 2021 21:26:49 +0000 (14:26 -0700)
committerMatthias Clasen <mclasen@redhat.com>
Sun, 2 Apr 2023 23:46:02 +0000 (19:46 -0400)
Adds a function to remove all children from
a GtkListBox. This way app developers don't need to
implement this themselves.

gtk/gtklistbox.c
gtk/gtklistbox.h

index 18dad80889a989bcb496e2c101403dbd22789693..8d2c0d0a958f1efeab2819099ebe0e065eee02cd 100644 (file)
@@ -433,10 +433,7 @@ gtk_list_box_set_property (GObject      *obj,
 static void
 gtk_list_box_dispose (GObject *object)
 {
-  GtkWidget *child;
-
-  while ((child = gtk_widget_get_first_child (GTK_WIDGET (object))))
-    gtk_list_box_remove (GTK_LIST_BOX (object), child);
+  gtk_list_box_remove_all (GTK_LIST_BOX (object));
 
   G_OBJECT_CLASS (gtk_list_box_parent_class)->dispose (object);
 }
@@ -2422,6 +2419,31 @@ gtk_list_box_remove (GtkListBox *box,
     }
 }
 
+/**
+ * gtk_list_box_remove_all:
+ * @box: a `GtkListBox`
+ *
+ * Removes all rows from @box.
+ *
+ * This function does nothing if @box is backed by a model.
+ *
+ * Since: 4.12
+ */
+void
+gtk_list_box_remove_all (GtkListBox *box)
+{
+  GtkWidget *widget = GTK_WIDGET (box);
+  GtkWidget *child;
+
+  g_return_if_fail (GTK_IS_LIST_BOX (box));
+
+  if (box->bound_model)
+    return;
+
+  while ((child = gtk_widget_get_first_child (widget)) != NULL)
+    gtk_list_box_remove (box, child);
+}
+
 static void
 gtk_list_box_compute_expand (GtkWidget *widget,
                              gboolean  *hexpand_p,
index 1a2dec8cd96e2f2b1f8f01dcab0b53bfc6551b44..71d42e1ee2f59fc850824ea8ccf60bc9a7a5410c 100644 (file)
@@ -180,6 +180,9 @@ void           gtk_list_box_insert                       (GtkListBox
 GDK_AVAILABLE_IN_ALL
 void           gtk_list_box_remove                       (GtkListBox                    *box,
                                                           GtkWidget                     *child);
+GDK_AVAILABLE_IN_4_12
+void           gtk_list_box_remove_all                   (GtkListBox                    *box);
+
 GDK_AVAILABLE_IN_ALL
 GtkListBoxRow* gtk_list_box_get_selected_row             (GtkListBox                    *box);
 GDK_AVAILABLE_IN_ALL