diff options
-rw-r--r-- | mail/ChangeLog | 6 | ||||
-rw-r--r-- | mail/component-factory.c | 84 |
2 files changed, 53 insertions, 37 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 02a80f2806..fdce71cd37 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,9 @@ +2003-03-05 Not Zed <NotZed@Ximian.com> + + * component-factory.c (idle_quit): Removed old quit code. + (owner_unset_cb): Make this call synchronous. Wont cover all + cases but should be ok most of the time. + 2003-03-04 Jeffrey Stedfast <fejj@ximian.com> * mail-search.c: Prototype some functions to shut the compiler up. diff --git a/mail/component-factory.c b/mail/component-factory.c index 54a8adabe4..477148bd14 100644 --- a/mail/component-factory.c +++ b/mail/component-factory.c @@ -890,41 +890,6 @@ user_create_new_item_cb (EvolutionShellComponent *shell_component, g_warning ("Don't know how to create item of type \"%s\"", id); } -static gboolean -idle_quit (gpointer user_data) -{ - static int shutdown_vfolder = FALSE; - static int shutdown_shutdown = FALSE; - - if (!shutdown_shutdown) { - if (e_thread_busy(NULL) || mail_msg_active(-1)) { - usleep(10000); - return TRUE; - } - - if (!shutdown_vfolder) { - shutdown_vfolder = TRUE; - mail_vfolder_shutdown(); - return TRUE; - } - - if (mail_async_event_destroy(async_event) == -1) - return TRUE; - - shutdown_shutdown = TRUE; - g_hash_table_foreach (storages_hash, free_storage, NULL); - g_hash_table_destroy (storages_hash); - storages_hash = NULL; - } - - if (e_list_length (folder_browser_factory_get_control_list ())) - return TRUE; - - bonobo_main_quit (); - - return FALSE; -} - static void owner_unset_cb (EvolutionShellComponent *shell_component, gpointer user_data); /* Table for signal handler setup/cleanup */ @@ -946,7 +911,11 @@ static void owner_unset_cb (EvolutionShellComponent *shell_component, gpointer user_data) { GConfClient *gconf; + CORBA_Environment ev; int i; + EIterator *it; + + printf("mailer shutdown\n"); gconf = gconf_client_get_default (); for (i=0;i<sizeof(shell_component_handlers)/sizeof(shell_component_handlers[0]);i++) @@ -963,8 +932,49 @@ owner_unset_cb (EvolutionShellComponent *shell_component, gpointer user_data) g_object_unref (search_context); search_context = NULL; - - g_timeout_add(100, idle_quit, NULL); + + /* force de-activate of all controls, tho only one should be active anyway? */ + CORBA_exception_init(&ev); + for (it = e_list_get_iterator(folder_browser_factory_get_control_list()); + e_iterator_is_valid(it); + e_iterator_next(it)) { + Bonobo_Control_activate(bonobo_object_corba_objref((BonoboObject *)e_iterator_get(it)), + FALSE, &ev); + } + CORBA_exception_free(&ev); + + for (i= 0;i<3;i++) { + /* need to flush any outstanding tasks before proceeding */ + + /* NOTE!! This may cause a deadlock situation, if we were + called from a deeper main loop than the top level + - is there a way to detect this? + - is this a very big problem? + FIXME: should use semaphores or something to wait rather than polling */ + while (e_thread_busy(NULL) || mail_msg_active(-1)) { + if (g_main_context_pending(NULL)) + g_main_context_iteration(NULL, TRUE); + else + usleep(100000); + } + + switch(i) { + case 0: + mail_vfolder_shutdown(); + break; + case 1: + if (mail_async_event_destroy(async_event) == -1) { + g_warning("Cannot destroy async event: would deadlock"); + g_warning(" system may be unstable at exit"); + } + break; + case 2: + g_hash_table_foreach (storages_hash, free_storage, NULL); + g_hash_table_destroy (storages_hash); + storages_hash = NULL; + break; + } + } } static void |