aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--shell/ChangeLog23
-rw-r--r--shell/Evolution-Offline.idl6
-rw-r--r--shell/Evolution-common.idl1
-rw-r--r--shell/e-folder.c60
-rw-r--r--shell/e-folder.h32
-rw-r--r--shell/e-shell-config-offline.c16
6 files changed, 102 insertions, 36 deletions
diff --git a/shell/ChangeLog b/shell/ChangeLog
index 45ac7e6240..ff0acc14de 100644
--- a/shell/ChangeLog
+++ b/shell/ChangeLog
@@ -1,5 +1,28 @@
2002-05-20 Ettore Perazzoli <ettore@ximian.com>
+ * Evolution-Offline.idl (syncFolder): Remove exception.
+ (cancelSyncFolder): Remove exception.
+
+ * e-shell-config-offline.c (storage_set_view_has_checkbox_func):
+ New.
+ (e_shell_config_offline_create_control): Pass it as the
+ @has_checkbox_func.
+
+ * e-folder.c: New member can_sync_offline in EFolderPrivate.
+ (init): Init to FALSE.
+ (e_folder_get_can_sync_offline): New.
+ (e_folder_to_corba): Set canSyncOffline in the returned CORBA
+ folder.
+ (e_folder_set_physical_uri): Protect from when @physical_uri and
+ ->physical_uri are the same thing.
+ (e_folder_set_description): Same here with description.
+ (e_folder_set_type_string): And type.
+
+ * Evolution-common.idl: New member canSyncOffline in struct
+ Folder.
+
+2002-05-20 Ettore Perazzoli <ettore@ximian.com>
+
* e-shell-config-offline.c
(e_shell_config_offline_create_control): Pass NULL for
@has_checkbox_func and @has_checkbox_func_data.
diff --git a/shell/Evolution-Offline.idl b/shell/Evolution-Offline.idl
index 97bfd0cc84..46821d72bb 100644
--- a/shell/Evolution-Offline.idl
+++ b/shell/Evolution-Offline.idl
@@ -59,13 +59,11 @@ interface Offline : Bonobo::Unknown {
/* Request the component to sync the specified folder. This has to
happen after ::prepareForOffline. */
oneway void syncFolder (in Folder folder,
- in SyncFolderProgressListener listener)
- raises (notPrepared);
+ in SyncFolderProgressListener listener);
/* Request the component to stop syncing the specified folder. This
has to happen after ::syncFolder. */
- oneway void cancelSyncFolder (in Folder folder)
- raises (notSyncing);
+ oneway void cancelSyncFolder (in Folder folder);
/* Ask the component to go into off-line mode. This always comes after
a ::prepareForOffline. */
diff --git a/shell/Evolution-common.idl b/shell/Evolution-common.idl
index 127521bdef..4cbf45ad7e 100644
--- a/shell/Evolution-common.idl
+++ b/shell/Evolution-common.idl
@@ -17,6 +17,7 @@ module Evolution {
string physicalUri;
string evolutionUri;
long unreadCount;
+ boolean canSyncOffline;
};
typedef sequence <Folder> FolderList;
diff --git a/shell/e-folder.c b/shell/e-folder.c
index 0de3160a74..3c2669f0bd 100644
--- a/shell/e-folder.c
+++ b/shell/e-folder.c
@@ -46,8 +46,9 @@ struct _EFolderPrivate {
int child_highlight;
int unread_count;
- int self_highlight : 1;
- int is_stock : 1;
+ unsigned int self_highlight : 1;
+ unsigned int is_stock : 1;
+ unsigned int can_sync_offline : 1;
};
#define EF_CLASS(obj) \
@@ -148,14 +149,15 @@ init (EFolder *folder)
EFolderPrivate *priv;
priv = g_new (EFolderPrivate, 1);
- priv->type = NULL;
- priv->name = NULL;
- priv->description = NULL;
- priv->physical_uri = NULL;
- priv->child_highlight = 0;
- priv->unread_count = 0;
- priv->self_highlight = FALSE;
- priv->is_stock = FALSE;
+ priv->type = NULL;
+ priv->name = NULL;
+ priv->description = NULL;
+ priv->physical_uri = NULL;
+ priv->child_highlight = 0;
+ priv->unread_count = 0;
+ priv->self_highlight = FALSE;
+ priv->is_stock = FALSE;
+ priv->can_sync_offline = FALSE;
folder->priv = priv;
}
@@ -274,6 +276,9 @@ e_folder_set_name (EFolder *folder,
g_return_if_fail (E_IS_FOLDER (folder));
g_return_if_fail (name != NULL);
+ if (folder->priv->name == name)
+ return;
+
g_free (folder->priv->name);
folder->priv->name = g_strdup (name);
@@ -316,6 +321,9 @@ e_folder_set_physical_uri (EFolder *folder,
g_return_if_fail (E_IS_FOLDER (folder));
g_return_if_fail (physical_uri != NULL);
+ if (folder->priv->physical_uri == physical_uri)
+ return;
+
g_free (folder->priv->physical_uri);
folder->priv->physical_uri = g_strdup (physical_uri);
@@ -361,6 +369,25 @@ e_folder_set_is_stock (EFolder *folder,
gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]);
}
+void
+e_folder_set_can_sync_offline (EFolder *folder,
+ gboolean can_sync_offline)
+{
+ g_return_if_fail (E_IS_FOLDER (folder));
+
+ folder->priv->can_sync_offline = !! can_sync_offline;
+
+ gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]);
+}
+
+gboolean
+e_folder_get_can_sync_offline (EFolder *folder)
+{
+ g_return_val_if_fail (E_IS_FOLDER (folder), FALSE);
+
+ return folder->priv->can_sync_offline;
+}
+
/* Gotta love CORBA. */
@@ -372,12 +399,13 @@ e_folder_to_corba (EFolder *folder,
g_return_if_fail (E_IS_FOLDER (folder));
g_return_if_fail (folder_return != NULL);
- folder_return->type = e_safe_corba_string_dup (e_folder_get_type_string (folder));
- folder_return->description = e_safe_corba_string_dup (e_folder_get_description (folder));
- folder_return->displayName = e_safe_corba_string_dup (e_folder_get_name (folder));
- folder_return->physicalUri = e_safe_corba_string_dup (e_folder_get_physical_uri (folder));
- folder_return->evolutionUri = e_safe_corba_string_dup (evolution_uri);
- folder_return->unreadCount = e_folder_get_unread_count (folder);
+ folder_return->type = e_safe_corba_string_dup (e_folder_get_type_string (folder));
+ folder_return->description = e_safe_corba_string_dup (e_folder_get_description (folder));
+ folder_return->displayName = e_safe_corba_string_dup (e_folder_get_name (folder));
+ folder_return->physicalUri = e_safe_corba_string_dup (e_folder_get_physical_uri (folder));
+ folder_return->evolutionUri = e_safe_corba_string_dup (evolution_uri);
+ folder_return->unreadCount = e_folder_get_unread_count (folder);
+ folder_return->canSyncOffline = e_folder_get_can_sync_offline (folder);
}
diff --git a/shell/e-folder.h b/shell/e-folder.h
index 48fa5b4789..4e7c9c1996 100644
--- a/shell/e-folder.h
+++ b/shell/e-folder.h
@@ -72,21 +72,23 @@ EFolder *e_folder_new (const char *name,
const char *type,
const char *description);
-const char *e_folder_get_name (EFolder *folder);
-const char *e_folder_get_type_string (EFolder *folder);
-const char *e_folder_get_description (EFolder *folder);
-const char *e_folder_get_physical_uri (EFolder *folder);
-int e_folder_get_unread_count (EFolder *folder);
-gboolean e_folder_get_highlighted (EFolder *folder);
-gboolean e_folder_get_is_stock (EFolder *folder);
-
-void e_folder_set_name (EFolder *folder, const char *name);
-void e_folder_set_type_string (EFolder *folder, const char *type);
-void e_folder_set_description (EFolder *folder, const char *description);
-void e_folder_set_physical_uri (EFolder *folder, const char *physical_uri);
-void e_folder_set_unread_count (EFolder *folder, int unread_count);
-void e_folder_set_child_highlight (EFolder *folder, gboolean highlighted);
-void e_folder_set_is_stock (EFolder *folder, gboolean is_stock);
+const char *e_folder_get_name (EFolder *folder);
+const char *e_folder_get_type_string (EFolder *folder);
+const char *e_folder_get_description (EFolder *folder);
+const char *e_folder_get_physical_uri (EFolder *folder);
+int e_folder_get_unread_count (EFolder *folder);
+gboolean e_folder_get_highlighted (EFolder *folder);
+gboolean e_folder_get_is_stock (EFolder *folder);
+gboolean e_folder_get_can_sync_offline (EFolder *folder);
+
+void e_folder_set_name (EFolder *folder, const char *name);
+void e_folder_set_type_string (EFolder *folder, const char *type);
+void e_folder_set_description (EFolder *folder, const char *description);
+void e_folder_set_physical_uri (EFolder *folder, const char *physical_uri);
+void e_folder_set_unread_count (EFolder *folder, int unread_count);
+void e_folder_set_child_highlight (EFolder *folder, gboolean highlighted);
+void e_folder_set_is_stock (EFolder *folder, gboolean is_stock);
+void e_folder_set_can_sync_offline (EFolder *folder, gboolean can_sync_offline);
void e_folder_to_corba (EFolder *folder,
const char *evolution_uri,
diff --git a/shell/e-shell-config-offline.c b/shell/e-shell-config-offline.c
index 2776d32cdd..bc497fece6 100644
--- a/shell/e-shell-config-offline.c
+++ b/shell/e-shell-config-offline.c
@@ -155,6 +155,20 @@ init_storage_set_view_status_from_config (EStorageSetView *storage_set_view,
CORBA_exception_free (&ev);
}
+static gboolean
+storage_set_view_has_checkbox_func (EStorageSet *storage_set,
+ const char *path,
+ void *data)
+{
+ EFolder *folder;
+
+ folder = e_storage_set_get_folder (storage_set, path);
+ if (folder == NULL)
+ return FALSE;
+
+ return e_folder_get_can_sync_offline (folder);
+}
+
BonoboObject *
e_shell_config_offline_create_control (EShell *shell)
{
@@ -168,7 +182,7 @@ e_shell_config_offline_create_control (EShell *shell)
page_data->storage_set_view = e_storage_set_new_view (e_shell_get_storage_set (shell), NULL);
e_storage_set_view_set_show_checkboxes (E_STORAGE_SET_VIEW (page_data->storage_set_view), TRUE,
- NULL, NULL);
+ storage_set_view_has_checkbox_func, NULL);
gtk_widget_show (page_data->storage_set_view);
init_storage_set_view_status_from_config (E_STORAGE_SET_VIEW (page_data->storage_set_view), shell);