summaryrefslogtreecommitdiff
path: root/tests/testcombochange.c
diff options
context:
space:
mode:
authorMatthias Clasen <maclas@gmx.de>2004-03-02 23:29:21 +0000
committerMatthias Clasen <matthiasc@src.gnome.org>2004-03-02 23:29:21 +0000
commit2169f50919be21b48fe1916af7ab663ac8d0b1a7 (patch)
tree76a65660c32ea782d4f3ef09312e13782e8ac532 /tests/testcombochange.c
parent2140cee8c86eaded329ed3d45650f07e73af05b6 (diff)
downloadgtk+-2169f50919be21b48fe1916af7ab663ac8d0b1a7.tar.gz
Add an animation mode, to test how the combobox behaves if the model
Wed Mar 3 00:28:59 2004 Matthias Clasen <maclas@gmx.de> * tests/testcombochange.c: Add an animation mode, to test how the combobox behaves if the model changes while it is popped up.
Diffstat (limited to 'tests/testcombochange.c')
-rw-r--r--tests/testcombochange.c39
1 files changed, 37 insertions, 2 deletions
diff --git a/tests/testcombochange.c b/tests/testcombochange.c
index 97224b3729..965460f551 100644
--- a/tests/testcombochange.c
+++ b/tests/testcombochange.c
@@ -155,11 +155,11 @@ on_reorder (void)
for (i = 0; i < contents->len; i++)
shuffle_array[i] = i;
- for (i = 0; i < contents->len - 1; i++)
+ for (i = 0; i + 1 < contents->len; i++)
{
gint pos = g_random_int_range (i, contents->len);
gint tmp;
-
+
tmp = shuffle_array[i];
shuffle_array[i] = shuffle_array[pos];
shuffle_array[pos] = tmp;
@@ -179,6 +179,37 @@ on_reorder (void)
g_free (shuffle_array);
}
+static int n_animations = 0;
+static int timer = 0;
+
+static gint
+animation_timer (gpointer data)
+{
+ switch (g_random_int_range (0, 3))
+ {
+ case 0:
+ on_insert ();
+ break;
+ case 1:
+ on_delete ();
+ break;
+ case 2:
+ on_reorder ();
+ break;
+ }
+
+ n_animations--;
+ return n_animations > 0;
+}
+
+static void
+on_animate (void)
+{
+ n_animations += 20;
+
+ timer = g_timeout_add (1000, (GSourceFunc) animation_timer, NULL);
+}
+
int
main (int argc, char **argv)
{
@@ -262,6 +293,10 @@ main (int argc, char **argv)
gtk_box_pack_start (GTK_BOX (button_vbox), button, FALSE, FALSE, 0);
g_signal_connect (button, "clicked", G_CALLBACK (on_reorder), NULL);
+ button = align_button_new ("Animate");
+ gtk_box_pack_start (GTK_BOX (button_vbox), button, FALSE, FALSE, 0);
+ g_signal_connect (button, "clicked", G_CALLBACK (on_animate), NULL);
+
gtk_widget_show_all (dialog);
gtk_dialog_run (GTK_DIALOG (dialog));