diff options
Diffstat (limited to 'shell/e-shell-offline-handler.c')
-rw-r--r-- | shell/e-shell-offline-handler.c | 100 |
1 files changed, 51 insertions, 49 deletions
diff --git a/shell/e-shell-offline-handler.c b/shell/e-shell-offline-handler.c index 3554705f9f..008af4dd93 100644 --- a/shell/e-shell-offline-handler.c +++ b/shell/e-shell-offline-handler.c @@ -29,8 +29,6 @@ #include "e-shell-offline-handler.h" -#include "e-shell-offline-sync.h" - #include "e-shell-marshal.h" #include <gtk/gtkcellrenderertext.h> @@ -52,14 +50,14 @@ #include <bonobo/bonobo-main.h> #include <bonobo/bonobo-exception.h> - + #define GLADE_DIALOG_FILE_NAME EVOLUTION_GLADEDIR "/e-active-connection-dialog.glade" - + #define PARENT_TYPE GTK_TYPE_OBJECT static GtkObjectClass *parent_class = NULL; - + /* Private part. */ struct _OfflineProgressListenerServant { @@ -105,7 +103,7 @@ struct _EShellOfflineHandlerPrivate { int finished : 1; }; - + /* Signals. */ enum { @@ -116,12 +114,12 @@ enum { static guint signals[LAST_SIGNAL] = { 0 }; - + /* Forward declarations for the dialog handling. */ static void update_dialog_clist (EShellOfflineHandler *offline_handler); - + /* Implementation for the OfflineProgressListener interface. */ static PortableServer_ServantBase__epv OfflineProgressListener_base_epv; @@ -274,7 +272,7 @@ create_progress_listener (EShellOfflineHandler *offline_handler, return TRUE; } - + /* ComponentInfo handling. */ static ComponentInfo * @@ -322,7 +320,7 @@ component_info_free (ComponentInfo *component_info) CORBA_exception_free (&ev); } - + /* Utility functions. */ static void @@ -336,7 +334,25 @@ hash_foreach_free_component_info (void *key, component_info_free (component_info); } - + +static GNOME_Evolution_Offline +get_offline_interface (GNOME_Evolution_Component objref) +{ + GNOME_Evolution_Offline interface; + CORBA_Environment ev; + + CORBA_exception_init (&ev); + + interface = Bonobo_Unknown_queryInterface (objref, "IDL:GNOME/Evolution/Offline:1.0", &ev); + + if (ev._major != CORBA_NO_EXCEPTION) + interface = CORBA_OBJECT_NIL; + + CORBA_exception_free (&ev); + return interface; +} + + /* Cancelling the off-line procedure. */ static void @@ -344,24 +360,21 @@ cancel_offline (EShellOfflineHandler *offline_handler) { EShellOfflineHandlerPrivate *priv; EComponentRegistry *component_registry; - GList *component_ids; - GList *p; + GSList *component_infos; + GSList *p; priv = offline_handler->priv; - component_registry = e_shell_get_component_registry (priv->shell); - component_ids = e_component_registry_get_id_list (component_registry); + component_registry = e_shell_peek_component_registry (priv->shell); + component_infos = e_component_registry_peek_list (component_registry); - for (p = component_ids; p != NULL; p = p->next) { - EvolutionShellComponentClient *shell_component_client; + for (p = component_infos; p != NULL; p = p->next) { + EComponentInfo *info = p->data; GNOME_Evolution_Offline offline_interface; CORBA_Environment ev; const char *id; - id = (const char *) p->data; - shell_component_client = e_component_registry_get_component_by_id (component_registry, id); - - offline_interface = evolution_shell_component_client_get_offline_interface (shell_component_client); + offline_interface = get_offline_interface (info->iface); if (offline_interface == CORBA_OBJECT_NIL) continue; @@ -374,8 +387,6 @@ cancel_offline (EShellOfflineHandler *offline_handler) CORBA_exception_free (&ev); } - e_free_string_list (component_ids); - priv->num_total_connections = 0; if (! priv->finished) { @@ -384,7 +395,7 @@ cancel_offline (EShellOfflineHandler *offline_handler) } } - + /* Preparing the off-line procedure. */ static gboolean @@ -392,18 +403,17 @@ prepare_for_offline (EShellOfflineHandler *offline_handler) { EComponentRegistry *component_registry; EShellOfflineHandlerPrivate *priv; - GList *component_ids; - GList *p; + GSList *component_infos; + GSList *p; gboolean error; priv = offline_handler->priv; - component_registry = e_shell_get_component_registry (priv->shell); - - component_ids = e_component_registry_get_id_list (component_registry); + component_registry = e_shell_peek_component_registry (priv->shell); + component_infos = e_component_registry_peek_list (component_registry); error = FALSE; - for (p = component_ids; p != NULL; p = p->next) { - EvolutionShellComponentClient *shell_component_client; + for (p = component_infos; p != NULL; p = p->next) { + EComponentInfo *info = p->data; GNOME_Evolution_Offline offline_interface; GNOME_Evolution_OfflineProgressListener progress_listener_interface; GNOME_Evolution_ConnectionList *active_connection_list; @@ -412,9 +422,7 @@ prepare_for_offline (EShellOfflineHandler *offline_handler) CORBA_Environment ev; const char *id; - id = (const char *) p->data; - shell_component_client = e_component_registry_get_component_by_id (component_registry, id); - offline_interface = evolution_shell_component_client_get_offline_interface (shell_component_client); + offline_interface = get_offline_interface (info->iface); if (offline_interface == CORBA_OBJECT_NIL) continue; @@ -461,12 +469,10 @@ prepare_for_offline (EShellOfflineHandler *offline_handler) if (error) cancel_offline (offline_handler); - e_free_string_list (component_ids); - return ! error; } - + /* Finalizing the off-line procedure. */ static void @@ -519,7 +525,7 @@ finalize_offline (EShellOfflineHandler *offline_handler) g_object_unref (offline_handler); } - + /* The confirmation dialog. */ static void @@ -587,8 +593,6 @@ dialog_handle_ok (GtkDialog *dialog, g_assert (instruction_label != NULL); g_assert (GTK_IS_LABEL (instruction_label)); - e_shell_offline_sync_all_folders (priv->shell, GTK_WINDOW (dialog)); - gtk_label_set_text (GTK_LABEL (instruction_label), _("Closing connections...")); finalize_offline (offline_handler); @@ -665,7 +669,7 @@ pop_up_confirmation_dialog (EShellOfflineHandler *offline_handler) gtk_widget_show (dialog); } - + /* GObject methods. */ static void @@ -712,7 +716,7 @@ impl_finalize (GObject *object) (* G_OBJECT_CLASS (parent_class)->finalize) (object); } - + /* GTK type handling. */ static void @@ -768,7 +772,7 @@ init (EShellOfflineHandler *shell_offline_handler) shell_offline_handler->priv = priv; } - + /** * e_shell_offline_handler_construct: * @offline_handler: A pointer to an EShellOfflineHandler to construct. @@ -815,7 +819,7 @@ e_shell_offline_handler_new (EShell *shell) return offline_handler; } - + /** * e_shell_offline_handler_put_components_offline: * @offline_handler: A pointer to an EShellOfflineHandler object. @@ -855,15 +859,13 @@ e_shell_offline_handler_put_components_offline (EShellOfflineHandler *offline_ha return; } - if (priv->num_total_connections > 0 && priv->parent_window != NULL) { + if (priv->num_total_connections > 0 && priv->parent_window != NULL) pop_up_confirmation_dialog (offline_handler); - } else { - e_shell_offline_sync_all_folders (priv->shell, parent_window); + else finalize_offline (offline_handler); - } g_object_unref (offline_handler); } - + E_MAKE_TYPE (e_shell_offline_handler, "EShellOfflineHandler", EShellOfflineHandler, class_init, init, PARENT_TYPE) |