aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-folder-cache.c
diff options
context:
space:
mode:
authorNot Zed <NotZed@Ximian.com>2002-07-24 15:21:15 +0800
committerMichael Zucci <zucchi@src.gnome.org>2002-07-24 15:21:15 +0800
commit0c43bcb20b82f8da6e6ffb71f85d27b251537e79 (patch)
tree2f3cbb1b59a87a5d0c03da7adb596d3906d8c788 /mail/mail-folder-cache.c
parent1080bf46a19e63965b11a93b4fe0ea2035fbd8a9 (diff)
downloadgsoc2013-evolution-0c43bcb20b82f8da6e6ffb71f85d27b251537e79.tar
gsoc2013-evolution-0c43bcb20b82f8da6e6ffb71f85d27b251537e79.tar.gz
gsoc2013-evolution-0c43bcb20b82f8da6e6ffb71f85d27b251537e79.tar.bz2
gsoc2013-evolution-0c43bcb20b82f8da6e6ffb71f85d27b251537e79.tar.lz
gsoc2013-evolution-0c43bcb20b82f8da6e6ffb71f85d27b251537e79.tar.xz
gsoc2013-evolution-0c43bcb20b82f8da6e6ffb71f85d27b251537e79.tar.zst
gsoc2013-evolution-0c43bcb20b82f8da6e6ffb71f85d27b251537e79.zip
Propagate name changes or removes to the mail config. #15951. Doesn't
2002-07-24 Not Zed <NotZed@Ximian.com> * mail-folder-cache.c (real_flush_updates): Propagate name changes or removes to the mail config. #15951. Doesn't enitrely work for local folders, because they are never renamed only removed and added thanks to the shell's api. * mail-config.c (mail_config_uri_renamed): If a store folder is renamed, this checks for any config that needs updating, so far sent and drafts folders. (mail_config_uri_deleted): Same, for deleted folders. svn path=/trunk/; revision=17568
Diffstat (limited to 'mail/mail-folder-cache.c')
-rw-r--r--mail/mail-folder-cache.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/mail/mail-folder-cache.c b/mail/mail-folder-cache.c
index 91001fa577..0e352bd634 100644
--- a/mail/mail-folder-cache.c
+++ b/mail/mail-folder-cache.c
@@ -45,6 +45,7 @@
/* For notifications of changes */
#include "mail-vfolder.h"
#include "mail-autofilter.h"
+#include "mail-config.h"
#define w(x)
#define d(x) /*(printf("%s(%d):%s: ", __FILE__, __LINE__, __PRETTY_FUNCTION__), (x))*/
@@ -156,6 +157,7 @@ real_flush_updates(void *o, void *event_data, void *data)
if (up->delete) {
mail_vfolder_delete_uri(up->store, up->uri);
mail_filter_delete_uri(up->store, up->uri);
+ mail_config_uri_deleted(CAMEL_STORE_CLASS(CAMEL_OBJECT_GET_CLASS(up->store))->compare_folder_name, up->uri);
} else
mail_vfolder_add_uri(up->store, up->uri, TRUE);
} else {
@@ -173,6 +175,7 @@ real_flush_updates(void *o, void *event_data, void *data)
d(printf("renaming folder '%s' to '%s'\n", up->olduri, up->uri));
mail_vfolder_rename_uri(up->store, up->olduri, up->uri);
mail_filter_rename_uri(up->store, up->olduri, up->uri);
+ mail_config_uri_renamed(CAMEL_STORE_CLASS(CAMEL_OBJECT_GET_CLASS(up->store))->compare_folder_name, up->olduri, up->uri);
}
if (up->name == NULL) {