aboutsummaryrefslogtreecommitdiffstats
path: root/shell/e-shell-offline-sync.c
diff options
context:
space:
mode:
Diffstat (limited to 'shell/e-shell-offline-sync.c')
-rw-r--r--shell/e-shell-offline-sync.c56
1 files changed, 17 insertions, 39 deletions
diff --git a/shell/e-shell-offline-sync.c b/shell/e-shell-offline-sync.c
index 67e33fd99b..dd10c58db2 100644
--- a/shell/e-shell-offline-sync.c
+++ b/shell/e-shell-offline-sync.c
@@ -31,6 +31,8 @@
#include "Evolution.h"
+#include <gconf/gconf-client.h>
+
#include <gal/widgets/e-gui-utils.h>
#include <gtk/gtklabel.h>
@@ -84,7 +86,6 @@ struct _SyncData {
/* The progress listener interface. */
-#if 0 /* FIXME */
static PortableServer_ServantBase__epv SyncFolderProgressListener_base_epv;
static POA_GNOME_Evolution_SyncFolderProgressListener__epv SyncFolderProgressListener_epv;
static POA_GNOME_Evolution_SyncFolderProgressListener__vepv SyncFolderProgressListener_vepv;
@@ -207,12 +208,10 @@ setup_progress_listener (SyncData *sync_data)
return TRUE;
}
-#endif
/* Setting up the progress dialog. */
-#if 0
static int
progress_dialog_close_callback (GnomeDialog *dialog,
void *data)
@@ -256,10 +255,8 @@ setup_dialog (SyncData *sync_data)
gtk_widget_show_all (sync_data->dialog);
}
-#endif
-#if 0
/* Sync the folder at the specified @folder_path. */
static void
sync_folder (SyncData *sync_data,
@@ -366,9 +363,7 @@ sync_folder (SyncData *sync_data,
CORBA_free (corba_folder);
CORBA_exception_free (&ev);
}
-#endif
-#if 0
/* Free up the data needed for syncing. */
static void
cleanup (SyncData *sync_data)
@@ -390,41 +385,22 @@ cleanup (SyncData *sync_data)
CORBA_exception_free (&ev);
}
-#endif
void
e_shell_offline_sync_all_folders (EShell *shell,
GtkWindow *parent_window)
{
-#if 0 /* FIXME */
- Bonobo_ConfigDatabase config_db;
- CORBA_sequence_CORBA_string *folder_path_sequence;
- CORBA_any *any;
- CORBA_Environment ev;
+ GConfClient *gconf_client;
SyncData *sync_data;
+ GSList *path_list;
+ GSList *p;
int i;
- config_db = e_shell_get_config_db (shell);
-
- CORBA_exception_init (&ev);
-
- /* Get the paths for the folders to sync up. */
-
- any = Bonobo_ConfigDatabase_getValue (config_db, "/OfflineFolders/paths", "", &ev);
- if (BONOBO_EX (&ev)) {
- g_warning ("Cannot get /OfflineFolders/paths from ConfigDatabase -- %s", BONOBO_EX_ID (&ev));
- CORBA_exception_free (&ev);
- return;
- }
- if (! CORBA_TypeCode_equal (any->_type, TC_CORBA_sequence_CORBA_string, &ev) || BONOBO_EX (&ev)) {
- g_warning ("/OfflineFolders/Paths in ConfigDatabase is not the expected type");
- CORBA_free (any);
- CORBA_exception_free (&ev);
- return;
- }
+ gconf_client = gconf_client_get_default ();
- folder_path_sequence = (CORBA_sequence_CORBA_string *) any->_value;
+ path_list = gconf_client_get_list (gconf_client, "/apps/evolution/shell/offline/folder_paths",
+ GCONF_VALUE_STRING, NULL);
sync_data = g_new0 (SyncData, 1);
sync_data->shell = shell;
@@ -436,10 +412,12 @@ e_shell_offline_sync_all_folders (EShell *shell,
setup_dialog (sync_data);
- for (i = 0; i < folder_path_sequence->_length; i ++) {
- sync_folder (sync_data,
- folder_path_sequence->_buffer[i],
- i + 1, folder_path_sequence->_length);
+ for (p = path_list, i = 1; p != NULL; p = p->next, i ++) {
+ const char *path;
+
+ path = (const char *) p->data;
+
+ sync_folder (sync_data, path, i, g_slist_length (path_list));
/* If the operation has been cancelled, stop syncing and
return. */
@@ -449,10 +427,10 @@ e_shell_offline_sync_all_folders (EShell *shell,
break;
}
}
+
done:
cleanup (sync_data);
- CORBA_free (folder_path_sequence);
- CORBA_exception_free (&ev);
-#endif
+ g_slist_foreach (path_list, (GFunc) g_free, NULL);
+ g_slist_free (path_list);
}