aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog5
-rw-r--r--mail/component-factory.c53
2 files changed, 46 insertions, 12 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index fef5e09858..195ff4ac99 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,8 @@
+2002-06-27 Jeffrey Stedfast <fejj@ximian.com>
+
+ * component-factory.c (storage_remove_folder): Recursively delete
+ any subfolders.
+
2002-06-26 Jeffrey Stedfast <fejj@ximian.com>
* mail-config.c (config_read): Don't allow the pgp type to be
diff --git a/mail/component-factory.c b/mail/component-factory.c
index e42e9128f9..3b14bba8af 100644
--- a/mail/component-factory.c
+++ b/mail/component-factory.c
@@ -1073,9 +1073,9 @@ storage_create_folder (EvolutionStorage *storage,
char *name;
CamelURL *url;
CamelException ex;
-
+
/* We could just use 'path' always here? */
-
+
if (strcmp (type, "mail") != 0) {
notify_listener (listener, GNOME_Evolution_Storage_UNSUPPORTED_TYPE);
return;
@@ -1112,13 +1112,36 @@ storage_create_folder (EvolutionStorage *storage,
for (fi = root; fi; fi = fi->child)
camel_store_subscribe_folder (store, fi->full_name, NULL);
}
-
+
camel_store_free_folder_info (store, root);
notify_listener (listener, GNOME_Evolution_Storage_OK);
}
static void
+storage_remove_folder_recursive (EvolutionStorage *storage, CamelStore *store, CamelFolderInfo *root, CamelException *ex)
+{
+ CamelFolderInfo *fi;
+
+ /* delete all children */
+ fi = root->child;
+ while (fi && !camel_exception_is_set (ex)) {
+ storage_remove_folder_recursive (storage, store, fi, ex);
+ fi = fi->sibling;
+ }
+
+ if (!camel_exception_is_set (ex)) {
+ if (camel_store_supports_subscriptions (store))
+ camel_store_unsubscribe_folder (store, root->full_name, NULL);
+
+ camel_store_delete_folder (store, root->full_name, ex);
+
+ if (!camel_exception_is_set (ex))
+ evolution_storage_removed_folder (storage, root->path);
+ }
+}
+
+static void
storage_remove_folder (EvolutionStorage *storage,
const Bonobo_Listener listener,
const char *path,
@@ -1126,9 +1149,10 @@ storage_remove_folder (EvolutionStorage *storage,
gpointer user_data)
{
CamelStore *store = user_data;
+ CamelFolderInfo *root, *fi;
CamelURL *url = NULL;
- char *name;
CamelException ex;
+ char *name;
g_warning ("storage_remove_folder: path=\"%s\"; uri=\"%s\"", path, physical_uri);
@@ -1143,8 +1167,6 @@ storage_remove_folder (EvolutionStorage *storage,
return;
}
- camel_exception_init (&ex);
-
if (url->fragment)
name = url->fragment;
else if (url->path && url->path[0])
@@ -1152,16 +1174,22 @@ storage_remove_folder (EvolutionStorage *storage,
else
name = "";
- if (camel_store_supports_subscriptions (store))
- camel_store_unsubscribe_folder (store, name, NULL);
-
- camel_store_delete_folder (store, name, &ex);
+ camel_exception_init (&ex);
+ root = camel_store_get_folder_info (store, name, CAMEL_STORE_FOLDER_INFO_FAST |
+ CAMEL_STORE_FOLDER_INFO_RECURSIVE, &ex);
camel_url_free (url);
- if (camel_exception_is_set (&ex))
+ if (!root || camel_exception_is_set (&ex))
goto exception;
- evolution_storage_removed_folder (storage, path);
+ fi = root;
+ while (fi && !camel_exception_is_set (&ex)) {
+ storage_remove_folder_recursive (storage, store, fi, &ex);
+ if (camel_exception_is_set (&ex))
+ goto exception;
+ fi = fi->sibling;
+ }
+ camel_store_free_folder_info (store, root);
notify_listener (listener, GNOME_Evolution_Storage_OK);
return;
@@ -1169,6 +1197,7 @@ storage_remove_folder (EvolutionStorage *storage,
exception:
/* FIXME: do better than this... */
camel_exception_clear (&ex);
+ camel_store_free_folder_info (store, root);
notify_listener (listener, GNOME_Evolution_Storage_INVALID_URI);
}