diff options
author | Jeffrey Stedfast <fejj@ximian.com> | 2002-06-28 04:44:22 +0800 |
---|---|---|
committer | Jeffrey Stedfast <fejj@src.gnome.org> | 2002-06-28 04:44:22 +0800 |
commit | 11935da7a63b3c1055729854c8c551c9e9e3921a (patch) | |
tree | c6989c692395365d63ade877483be834fdec3896 /mail/component-factory.c | |
parent | c1db57e712495e431304076a1aa412c56bb1205a (diff) | |
download | gsoc2013-evolution-11935da7a63b3c1055729854c8c551c9e9e3921a.tar.gz gsoc2013-evolution-11935da7a63b3c1055729854c8c551c9e9e3921a.tar.zst gsoc2013-evolution-11935da7a63b3c1055729854c8c551c9e9e3921a.zip |
Recursively delete any subfolders.
2002-06-27 Jeffrey Stedfast <fejj@ximian.com>
* component-factory.c (storage_remove_folder): Recursively delete
any subfolders.
svn path=/trunk/; revision=17318
Diffstat (limited to 'mail/component-factory.c')
-rw-r--r-- | mail/component-factory.c | 53 |
1 files changed, 41 insertions, 12 deletions
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); } |