aboutsummaryrefslogtreecommitdiffstats
path: root/mail/test-thread.c
diff options
context:
space:
mode:
authorPeter Williams <peterw@src.gnome.org>2000-06-22 02:14:44 +0800
committerPeter Williams <peterw@src.gnome.org>2000-06-22 02:14:44 +0800
commit42d0cc5ca71d52130cea48c481344ce081b158a1 (patch)
tree5a41431ae2a59442fd21289e09b98d4e61cf2f7f /mail/test-thread.c
parent100bc92dd2821cf71c695ae5735647051b09ed45 (diff)
downloadgsoc2013-evolution-42d0cc5ca71d52130cea48c481344ce081b158a1.tar
gsoc2013-evolution-42d0cc5ca71d52130cea48c481344ce081b158a1.tar.gz
gsoc2013-evolution-42d0cc5ca71d52130cea48c481344ce081b158a1.tar.bz2
gsoc2013-evolution-42d0cc5ca71d52130cea48c481344ce081b158a1.tar.lz
gsoc2013-evolution-42d0cc5ca71d52130cea48c481344ce081b158a1.tar.xz
gsoc2013-evolution-42d0cc5ca71d52130cea48c481344ce081b158a1.tar.zst
gsoc2013-evolution-42d0cc5ca71d52130cea48c481344ce081b158a1.zip
Add the async mail API (still not hooked up though)
svn path=/trunk/; revision=3676
Diffstat (limited to 'mail/test-thread.c')
-rw-r--r--mail/test-thread.c113
1 files changed, 113 insertions, 0 deletions
diff --git a/mail/test-thread.c b/mail/test-thread.c
new file mode 100644
index 0000000000..f2b46be763
--- /dev/null
+++ b/mail/test-thread.c
@@ -0,0 +1,113 @@
+/* Tests the multithreaded UI code */
+
+#include "config.h"
+#include <unistd.h>
+#include <glib.h>
+#include <gtk/gtk.h>
+#include <stdio.h>
+#include "mail-threads.h"
+
+static void op_1( gpointer userdata );
+static void op_2( gpointer userdata );
+static void op_3( gpointer userdata );
+static void op_4( gpointer userdata );
+static gboolean queue_ops( void );
+
+static gboolean queue_ops( void )
+{
+ int i;
+ gchar buf[32];
+
+ g_message( "Top of queue_ops" );
+
+ mail_operation_try( "The Crawling Progress Bar of Doom", op_1, NULL );
+ mail_operation_try( "The Mysterious Message Setter", op_2, NULL );
+ mail_operation_try( "The Error Dialog of No Return", op_3, NULL );
+
+ for( i = 0; i < 7; i++ ) {
+ sprintf( buf, "Queue Filler %d", i );
+ mail_operation_try( buf, op_4, GINT_TO_POINTER( i ) );
+ }
+
+ g_message( "Waiting for finish..." );
+ mail_operation_wait_for_finish();
+
+ g_message( "Ops done -- queue some more!" );
+
+ mail_operation_try( "Progress Bar Redux", op_1, NULL );
+
+ g_message( "Waiting for finish again..." );
+ mail_operation_wait_for_finish();
+
+ g_message( "Ops done -- more, more!" );
+
+ for( i = 0; i < 3; i++ ) {
+ sprintf( buf, "Queue Filler %d", i );
+ mail_operation_try( buf, op_4, GINT_TO_POINTER( i ) );
+ }
+
+ g_message( "Waiting for finish AGAIN..." );
+ mail_operation_wait_for_finish();
+ g_message( "Ops done again. Exiting 0" );
+ gtk_exit( 0 );
+ return FALSE;
+}
+
+static void op_1( gpointer userdata )
+{
+ gfloat pct;
+
+ mail_op_show_progressbar();
+ mail_op_set_message( "Watch the progress bar!" );
+
+ for( pct = 0.0; pct < 1.0; pct += 0.1 ) {
+ sleep( 1 );
+ mail_op_set_percentage( pct );
+ }
+}
+
+static void op_2( gpointer userdata )
+{
+ int i;
+
+ mail_op_hide_progressbar();
+ for( i = 10; i > 0; i-- ) {
+ mail_op_set_message( "%d", i );
+ sleep( 1 );
+ }
+
+ mail_op_set_message( "BOOOM!" );
+ sleep( 1 );
+}
+
+static void op_3( gpointer userdata )
+{
+ gfloat pct;
+
+ mail_op_show_progressbar();
+ mail_op_set_message( "Frobulating the foosamatic" );
+
+ for( pct = 0.0; pct < 0.3; pct += 0.1 ) {
+ mail_op_set_percentage( pct );
+ sleep( 1 );
+ }
+
+ mail_op_error( "Oh no! The foosamatic was booby-trapped!" );
+ sleep( 1 );
+}
+
+static void op_4( gpointer userdata )
+{
+ mail_op_hide_progressbar();
+ mail_op_set_message( "Filler # %d", GPOINTER_TO_INT( userdata ) );
+ sleep( 1 );
+}
+
+int main( int argc, char **argv )
+{
+ g_thread_init( NULL );
+ gtk_init( &argc, &argv );
+ gtk_idle_add( (GtkFunction) queue_ops, NULL );
+ gtk_main();
+ return 0;
+}