aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-folder-cache.c
diff options
context:
space:
mode:
author8 <NotZed@Ximian.com>2001-10-19 08:45:02 +0800
committerMichael Zucci <zucchi@src.gnome.org>2001-10-19 08:45:02 +0800
commitae5590f88d2a2a7097d3f47b09ab96a9c2059a05 (patch)
tree72becf18c0ba7bafd92a07eed7954bedd26a133a /mail/mail-folder-cache.c
parentae6f93814ac620833fe9e7c7684b51a1ef01ea11 (diff)
downloadgsoc2013-evolution-ae5590f88d2a2a7097d3f47b09ab96a9c2059a05.tar.gz
gsoc2013-evolution-ae5590f88d2a2a7097d3f47b09ab96a9c2059a05.tar.zst
gsoc2013-evolution-ae5590f88d2a2a7097d3f47b09ab96a9c2059a05.zip
Added remove flag - its not adduri, its removeuri, its less typing than
2001-10-18 <NotZed@Ximian.com> * mail-vfolder.c (vfolder_adduri): Added remove flag - its not adduri, its removeuri, its less typing than creating a removeuri. (vfolder_adduri_do): Implement the remove flag. (mail_vfolder_remove_uri): Changed to mail_vfolder_delte_uri, to indicate its actually been deleted. (mail_vfolder_add_uri): Added remove flag. (rule_changed): When adding existing folders to a new rule, strdup the list data. * mail-folder-cache.c (store_finalised): Unhook from all events when done. (mail_note_store_remove): Remove a store from being noted. (free_folder_info): Also if we have a folder, unhook all events. Also remove the uri from vfolders. (mail_note_folder): Remove warning about adding folders to stores that aren't added yet - we might actually be removing the store. * component-factory.c (mail_remove_storage): Call mail_note_store_remove when we remove the storage. svn path=/trunk/; revision=13782
Diffstat (limited to 'mail/mail-folder-cache.c')
-rw-r--r--mail/mail-folder-cache.c55
1 files changed, 45 insertions, 10 deletions
diff --git a/mail/mail-folder-cache.c b/mail/mail-folder-cache.c
index d60dcbddc3..710147a8a1 100644
--- a/mail/mail-folder-cache.c
+++ b/mail/mail-folder-cache.c
@@ -172,7 +172,7 @@ setup_folder(CamelFolderInfo *fi, struct _store_info *si)
}
if (strstr(fi->url, ";noselect") == NULL)
- mail_vfolder_add_uri(store, fi->url);
+ mail_vfolder_add_uri(store, fi->url, FALSE);
camel_object_unref((CamelObject *)store);
}
@@ -205,7 +205,7 @@ folder_finalised(CamelObject *o, gpointer event_data, gpointer user_data)
{
struct _folder_info *mfi = user_data;
- (printf("Folder finalised '%s'!\n", ((CamelFolder *)o)->full_name));
+ d(printf("Folder finalised '%s'!\n", ((CamelFolder *)o)->full_name));
mfi->folder = NULL;
}
@@ -214,7 +214,7 @@ folder_deleted(CamelObject *o, gpointer event_data, gpointer user_data)
{
struct _folder_info *mfi = user_data;
- (printf("Folder deleted '%s'!\n", ((CamelFolder *)o)->full_name));
+ d(printf("Folder deleted '%s'!\n", ((CamelFolder *)o)->full_name));
mfi->folder = NULL;
}
@@ -241,7 +241,7 @@ void mail_note_folder(CamelFolder *folder)
LOCK(info_lock);
si = g_hash_table_lookup(stores, store);
if (si == NULL) {
- g_warning("Adding a folder `%s' to a store %p which hasn't been added yet?\n", folder->full_name, store);
+ /*g_warning("Adding a folder `%s' to a store %p which hasn't been added yet?", folder->full_name, store);*/
UNLOCK(info_lock);
return;
}
@@ -313,7 +313,7 @@ real_folder_deleted(CamelStore *store, void *event_data, CamelFolderInfo *fi)
d(printf("real_folder_deleted: %s (%s)\n", fi->full_name, fi->url));
if (strstr(fi->url, ";noselect") == NULL)
- mail_vfolder_remove_uri(store, fi->url);
+ mail_vfolder_delete_uri(store, fi->url);
camel_object_unref((CamelObject *)store);
camel_folder_info_free(fi);
@@ -344,13 +344,28 @@ store_folder_deleted(CamelObject *o, void *event_data, void *data)
store_folder_unsubscribed(o, event_data, data);
}
+static void
+unset_folder_info(char *path, struct _folder_info *mfi, void *data)
+{
+ if (mfi->folder) {
+ CamelFolder *folder = mfi->folder;
+
+ camel_object_unhook_event((CamelObject *)folder, "folder_changed", folder_changed, mfi);
+ camel_object_unhook_event((CamelObject *)folder, "message_changed", folder_changed, mfi);
+ camel_object_unhook_event((CamelObject *)folder, "deleted", folder_deleted, mfi);
+ camel_object_unhook_event((CamelObject *)folder, "finalize", folder_finalised, mfi);
+ }
+
+ if (strstr(mfi->uri, ";noselect") == NULL)
+ mail_vfolder_add_uri(mfi->store_info->store, mfi->uri, TRUE);
+}
static void
-free_folder_info(char *path, struct _folder_info *info, void *data)
+free_folder_info(char *path, struct _folder_info *mfi, void *data)
{
- g_free(info->path);
- g_free(info->full_name);
- g_free(info->uri);
+ g_free(mfi->path);
+ g_free(mfi->full_name);
+ g_free(mfi->uri);
}
static void
@@ -364,6 +379,14 @@ store_finalised(CamelObject *o, void *event_data, void *data)
si = g_hash_table_lookup(stores, store);
if (si) {
g_hash_table_remove(stores, store);
+
+ camel_object_unhook_event((CamelObject *)store, "folder_created", store_folder_created, NULL);
+ camel_object_unhook_event((CamelObject *)store, "folder_deleted", store_folder_deleted, NULL);
+ camel_object_unhook_event((CamelObject *)store, "folder_subscribed", store_folder_subscribed, NULL);
+ camel_object_unhook_event((CamelObject *)store, "folder_unsubscribed", store_folder_unsubscribed, NULL);
+ camel_object_unhook_event((CamelObject *)store, "finalize", store_finalised, NULL);
+
+ g_hash_table_foreach(si->folders, (GHFunc)unset_folder_info, NULL);
UNLOCK(info_lock);
mail_async_event_destroy(si->async_event);
LOCK(info_lock);
@@ -377,7 +400,7 @@ store_finalised(CamelObject *o, void *event_data, void *data)
static void
create_folders(CamelFolderInfo *fi, struct _store_info *si)
{
- printf("Setup new folder: %s\n", fi->url);
+ d(printf("Setup new folder: %s\n", fi->url));
setup_folder(fi, si);
@@ -409,6 +432,18 @@ update_folders(CamelStore *store, CamelFolderInfo *info, void *data)
}
void
+mail_note_store_remove(CamelStore *store)
+{
+ g_assert(CAMEL_IS_STORE(store));
+
+ if (stores == NULL)
+ return;
+
+ /* same action */
+ store_finalised((CamelObject *)store, NULL, NULL);
+}
+
+void
mail_note_store(CamelStore *store, EvolutionStorage *storage, GNOME_Evolution_Storage corba_storage,
void (*done)(CamelStore *store, CamelFolderInfo *info, void *data), void *data)
{