Learning_GTK4_tree/testsuite/gtk/listbox.c
2023-12-12 11:36:42 +01:00

452 lines
11 KiB
C

#include <gtk/gtk.h>
static int
sort_list (GtkListBoxRow *row1,
GtkListBoxRow *row2,
gpointer data)
{
GtkWidget *label1, *label2;
int n1, n2;
int *count = data;
(*count)++;
label1 = gtk_list_box_row_get_child (row1);
n1 = GPOINTER_TO_INT (g_object_get_data (G_OBJECT (label1), "data"));
label2 = gtk_list_box_row_get_child (row2);
n2 = GPOINTER_TO_INT (g_object_get_data (G_OBJECT (label2), "data"));
return (n1 - n2);
}
static void
check_sorted (GtkListBox *list)
{
GtkWidget *row, *label;
int res[100];
int index, value;
int n_rows = 0;
int i;
for (row = gtk_widget_get_first_child (GTK_WIDGET (list));
row != NULL;
row = gtk_widget_get_next_sibling (row))
{
if (!GTK_IS_LIST_BOX_ROW (row))
continue;
index = gtk_list_box_row_get_index (GTK_LIST_BOX_ROW (row));
label = gtk_list_box_row_get_child (GTK_LIST_BOX_ROW (row));
value = GPOINTER_TO_INT (g_object_get_data (G_OBJECT (label), "data"));
res[index] = value;
n_rows++;
}
for (i = 1; i < n_rows; i++)
g_assert_cmpint (res[i - 1], <=, res[i]);
}
static void
test_sort (void)
{
GtkListBox *list;
GtkListBoxRow *row;
GtkWidget *label;
int i, r;
char *s;
int count;
list = GTK_LIST_BOX (gtk_list_box_new ());
g_object_ref_sink (list);
for (i = 0; i < 100; i++)
{
r = g_random_int_range (0, 1000);
s = g_strdup_printf ("%d: %d", i, r);
label = gtk_label_new (s);
g_object_set_data (G_OBJECT (label), "data", GINT_TO_POINTER (r));
g_free (s);
gtk_list_box_insert (GTK_LIST_BOX (list), label, -1);
}
count = 0;
gtk_list_box_set_sort_func (list, sort_list, &count, NULL);
g_assert_cmpint (count, >, 0);
check_sorted (list);
count = 0;
gtk_list_box_invalidate_sort (list);
g_assert_cmpint (count, >, 0);
count = 0;
row = gtk_list_box_get_row_at_index (list, 0);
gtk_list_box_row_changed (row);
g_assert_cmpint (count, >, 0);
g_object_unref (list);
}
static GtkListBoxRow *callback_row;
static void
on_row_selected (GtkListBox *list_box,
GtkListBoxRow *row,
gpointer data)
{
int *i = data;
(*i)++;
callback_row = row;
}
static void
test_selection (void)
{
GtkListBox *list;
GtkListBoxRow *row, *row2;
GtkWidget *label;
int i;
char *s;
int count;
int index;
list = GTK_LIST_BOX (gtk_list_box_new ());
g_object_ref_sink (list);
g_assert_cmpint (gtk_list_box_get_selection_mode (list), ==, GTK_SELECTION_SINGLE);
g_assert_null (gtk_list_box_get_selected_row (list));
for (i = 0; i < 100; i++)
{
s = g_strdup_printf ("%d", i);
label = gtk_label_new (s);
g_object_set_data (G_OBJECT (label), "data", GINT_TO_POINTER (i));
g_free (s);
gtk_list_box_insert (GTK_LIST_BOX (list), label, -1);
}
count = 0;
g_signal_connect (list, "row-selected",
G_CALLBACK (on_row_selected),
&count);
row = gtk_list_box_get_row_at_index (list, 20);
g_assert_false (gtk_list_box_row_is_selected (row));
gtk_list_box_select_row (list, row);
g_assert_true (gtk_list_box_row_is_selected (row));
g_assert_true (callback_row == row);
g_assert_cmpint (count, ==, 1);
row2 = gtk_list_box_get_selected_row (list);
g_assert_true (row2 == row);
gtk_list_box_unselect_all (list);
row2 = gtk_list_box_get_selected_row (list);
g_assert_null (row2);
gtk_list_box_select_row (list, row);
row2 = gtk_list_box_get_selected_row (list);
g_assert_true (row2 == row);
gtk_list_box_set_selection_mode (list, GTK_SELECTION_BROWSE);
gtk_list_box_remove (GTK_LIST_BOX (list), GTK_WIDGET (row));
g_assert_null (callback_row);
g_assert_cmpint (count, ==, 4);
row2 = gtk_list_box_get_selected_row (list);
g_assert_null (row2);
row = gtk_list_box_get_row_at_index (list, 20);
gtk_list_box_select_row (list, row);
g_assert_true (gtk_list_box_row_is_selected (row));
g_assert_true (callback_row == row);
g_assert_cmpint (count, ==, 5);
gtk_list_box_set_selection_mode (list, GTK_SELECTION_NONE);
g_assert_false (gtk_list_box_row_is_selected (row));
g_assert_null (callback_row);
g_assert_cmpint (count, ==, 6);
row2 = gtk_list_box_get_selected_row (list);
g_assert_null (row2);
row = gtk_list_box_get_row_at_index (list, 20);
index = gtk_list_box_row_get_index (row);
g_assert_cmpint (index, ==, 20);
row = GTK_LIST_BOX_ROW (gtk_list_box_row_new ());
g_object_ref_sink (row);
index = gtk_list_box_row_get_index (row);
g_assert_cmpint (index, ==, -1);
g_object_unref (row);
g_object_unref (list);
}
static void
on_selected_rows_changed (GtkListBox *box, gpointer data)
{
int *i = data;
(*i)++;
}
static void
test_multi_selection (void)
{
GtkListBox *list;
GList *l;
GtkListBoxRow *row, *row2;
GtkWidget *label;
int i;
char *s;
int count;
list = GTK_LIST_BOX (gtk_list_box_new ());
g_object_ref_sink (list);
g_assert_cmpint (gtk_list_box_get_selection_mode (list), ==, GTK_SELECTION_SINGLE);
g_assert_null (gtk_list_box_get_selected_rows (list));
gtk_list_box_set_selection_mode (list, GTK_SELECTION_MULTIPLE);
for (i = 0; i < 100; i++)
{
s = g_strdup_printf ("%d", i);
label = gtk_label_new (s);
g_object_set_data (G_OBJECT (label), "data", GINT_TO_POINTER (i));
g_free (s);
gtk_list_box_insert (GTK_LIST_BOX (list), label, -1);
}
count = 0;
g_signal_connect (list, "selected-rows-changed",
G_CALLBACK (on_selected_rows_changed),
&count);
row = gtk_list_box_get_row_at_index (list, 20);
gtk_list_box_select_all (list);
g_assert_cmpint (count, ==, 1);
l = gtk_list_box_get_selected_rows (list);
g_assert_cmpint (g_list_length (l), ==, 100);
g_list_free (l);
g_assert_true (gtk_list_box_row_is_selected (row));
gtk_list_box_unselect_all (list);
g_assert_cmpint (count, ==, 2);
l = gtk_list_box_get_selected_rows (list);
g_assert_null (l);
g_assert_false (gtk_list_box_row_is_selected (row));
gtk_list_box_select_row (list, row);
g_assert_true (gtk_list_box_row_is_selected (row));
g_assert_cmpint (count, ==, 3);
l = gtk_list_box_get_selected_rows (list);
g_assert_cmpint (g_list_length (l), ==, 1);
g_assert_true (l->data == row);
g_list_free (l);
row2 = gtk_list_box_get_row_at_index (list, 40);
g_assert_false (gtk_list_box_row_is_selected (row2));
gtk_list_box_select_row (list, row2);
g_assert_true (gtk_list_box_row_is_selected (row2));
g_assert_cmpint (count, ==, 4);
l = gtk_list_box_get_selected_rows (list);
g_assert_cmpint (g_list_length (l), ==, 2);
g_assert_true (l->data == row);
g_assert_true (l->next->data == row2);
g_list_free (l);
gtk_list_box_unselect_row (list, row);
g_assert_false (gtk_list_box_row_is_selected (row));
g_assert_cmpint (count, ==, 5);
l = gtk_list_box_get_selected_rows (list);
g_assert_cmpint (g_list_length (l), ==, 1);
g_assert_true (l->data == row2);
g_list_free (l);
g_object_unref (list);
}
static gboolean
filter_func (GtkListBoxRow *row,
gpointer data)
{
int *count = data;
GtkWidget *child;
int i;
(*count)++;
child = gtk_list_box_row_get_child (row);
i = GPOINTER_TO_INT (g_object_get_data (G_OBJECT (child), "data"));
return (i % 2) == 0;
}
static void
check_filtered (GtkListBox *list)
{
int count;
GtkWidget *row;
count = 0;
for (row = gtk_widget_get_first_child (GTK_WIDGET (list));
row != NULL;
row = gtk_widget_get_next_sibling (row))
{
if (!GTK_IS_LIST_BOX_ROW (row))
continue;
if (gtk_widget_get_child_visible (row))
count++;
}
g_assert_cmpint (count, ==, 50);
}
static void
test_filter (void)
{
GtkListBox *list;
GtkListBoxRow *row;
int i;
char *s;
GtkWidget *label;
int count;
list = GTK_LIST_BOX (gtk_list_box_new ());
g_object_ref_sink (list);
g_assert_cmpint (gtk_list_box_get_selection_mode (list), ==, GTK_SELECTION_SINGLE);
g_assert_null (gtk_list_box_get_selected_row (list));
for (i = 0; i < 100; i++)
{
s = g_strdup_printf ("%d", i);
label = gtk_label_new (s);
g_object_set_data (G_OBJECT (label), "data", GINT_TO_POINTER (i));
g_free (s);
gtk_list_box_insert (GTK_LIST_BOX (list), label, -1);
}
count = 0;
gtk_list_box_set_filter_func (list, filter_func, &count, NULL);
g_assert_cmpint (count, >, 0);
check_filtered (list);
count = 0;
gtk_list_box_invalidate_filter (list);
g_assert_cmpint (count, >, 0);
count = 0;
row = gtk_list_box_get_row_at_index (list, 0);
gtk_list_box_row_changed (row);
g_assert_cmpint (count, >, 0);
g_object_unref (list);
}
static void
header_func (GtkListBoxRow *row,
GtkListBoxRow *before,
gpointer data)
{
GtkWidget *child;
int i;
int *count = data;
GtkWidget *header;
char *s;
(*count)++;
child = gtk_list_box_row_get_child (row);
i = GPOINTER_TO_INT (g_object_get_data (G_OBJECT (child), "data"));
if (i % 2 == 0)
{
s = g_strdup_printf ("Header %d", i);
header = gtk_label_new (s);
g_free (s);
}
else
header = NULL;
gtk_list_box_row_set_header (row, header);
}
static void
check_headers (GtkListBox *list)
{
int count;
GtkWidget *row;
count = 0;
for (row = gtk_widget_get_first_child (GTK_WIDGET (list));
row != NULL;
row = gtk_widget_get_next_sibling (row))
{
if (!GTK_IS_LIST_BOX_ROW (row))
continue;
if (gtk_list_box_row_get_header (GTK_LIST_BOX_ROW (row)) != NULL)
count++;
}
g_assert_cmpint (count, ==, 50);
}
static void
test_header (void)
{
GtkListBox *list;
GtkListBoxRow *row;
int i;
char *s;
GtkWidget *label;
int count;
list = GTK_LIST_BOX (gtk_list_box_new ());
g_object_ref_sink (list);
g_assert_cmpint (gtk_list_box_get_selection_mode (list), ==, GTK_SELECTION_SINGLE);
g_assert_null (gtk_list_box_get_selected_row (list));
for (i = 0; i < 100; i++)
{
s = g_strdup_printf ("%d", i);
label = gtk_label_new (s);
g_object_set_data (G_OBJECT (label), "data", GINT_TO_POINTER (i));
g_free (s);
gtk_list_box_insert (GTK_LIST_BOX (list), label, -1);
}
count = 0;
gtk_list_box_set_header_func (list, header_func, &count, NULL);
g_assert_cmpint (count, >, 0);
check_headers (list);
count = 0;
gtk_list_box_invalidate_headers (list);
g_assert_cmpint (count, >, 0);
count = 0;
row = gtk_list_box_get_row_at_index (list, 0);
gtk_list_box_row_changed (row);
g_assert_cmpint (count, >, 0);
g_object_unref (list);
}
int
main (int argc, char *argv[])
{
gtk_test_init (&argc, &argv);
g_test_add_func ("/listbox/sort", test_sort);
g_test_add_func ("/listbox/selection", test_selection);
g_test_add_func ("/listbox/multi-selection", test_multi_selection);
g_test_add_func ("/listbox/filter", test_filter);
g_test_add_func ("/listbox/header", test_header);
return g_test_run ();
}