aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-vfolder.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/mail-vfolder.c')
-rw-r--r--mail/mail-vfolder.c129
1 files changed, 84 insertions, 45 deletions
diff --git a/mail/mail-vfolder.c b/mail/mail-vfolder.c
index 1ac18f7c63..6319546b2f 100644
--- a/mail/mail-vfolder.c
+++ b/mail/mail-vfolder.c
@@ -57,28 +57,28 @@ extern char *evolution_dir;
extern CamelSession *session;
static struct _vfolder_info *
-vfolder_find(const char *name)
+vfolder_find (const char *name)
{
GList *l = available_vfolders;
struct _vfolder_info *info;
-
+
while (l) {
info = l->data;
- if (!strcmp(info->name, name))
+ if (!strcmp (info->name, name))
return info;
- l = g_list_next(l);
+ l = g_list_next (l);
}
return NULL;
}
static void
-register_new_source(struct _vfolder_info *info, CamelFolder *folder)
+register_new_source (struct _vfolder_info *info, CamelFolder *folder)
{
FilterRule *rule = info->rule;
-
+
if (rule && info->folder && rule->source) {
int remote = (((CamelService *)folder->parent_store)->provider->flags & CAMEL_PROVIDER_IS_REMOTE) != 0;
-
+
if (!strcmp(rule->source, "local")) {
if (!remote) {
printf("adding local folder to vfolder %s\n", rule->name);
@@ -96,34 +96,36 @@ register_new_source(struct _vfolder_info *info, CamelFolder *folder)
}
}
-static void source_finalise(CamelFolder *sub, gpointer type, CamelFolder *vf)
+static void
+source_finalise (CamelFolder *sub, gpointer type, CamelFolder *vf)
{
GList *l = available_vfolders;
while (l) {
struct _vfolder_info *info = l->data;
-
+
if (info->folder)
camel_vee_folder_remove_folder(info->folder, sub);
-
+
l = l->next;
}
}
/* for registering potential vfolder sources */
-void vfolder_register_source(CamelFolder *folder)
+void
+vfolder_register_source (CamelFolder *folder)
{
GList *l;
-
+
if (CAMEL_IS_VEE_FOLDER(folder))
return;
-
+
if (g_list_find(source_folders, folder))
return;
-
+
/* FIXME: Hook to destroy event */
camel_object_hook_event((CamelObject *)folder, "finalize", (CamelObjectEventHookFunc)source_finalise, folder);
-
+
source_folders = g_list_append(source_folders, folder);
l = available_vfolders;
while (l) {
@@ -135,15 +137,15 @@ void vfolder_register_source(CamelFolder *folder)
/* go through the list of what we have, what we want, and make
them match, deleting/reconfiguring as required */
static void
-vfolder_refresh(void)
+vfolder_refresh (void)
{
GList *l;
GList *head = NULL; /* processed list */
struct _vfolder_info *info;
FilterRule *rule;
- GString *expr = g_string_new("");
+ GString *expr = g_string_new ("");
char *uri, *path;
-
+
rule = NULL;
while ( (rule = rule_context_next_rule((RuleContext *)context, rule, NULL)) ) {
info = vfolder_find(rule->name);
@@ -154,15 +156,15 @@ vfolder_refresh(void)
if (info->rule)
gtk_object_unref((GtkObject *)info->rule);
info->rule = rule;
-
+
available_vfolders = g_list_remove(available_vfolders, info);
-
+
/* check if the rule has changed ... otherwise, leave it */
if (strcmp(expr->str, info->query)) {
d(printf("Must reconfigure vfolder with new rule?\n"));
g_free(info->query);
info->query = g_strdup(expr->str);
-
+
uri = g_strdup_printf("vfolder:%s", info->name);
path = g_strdup_printf("/%s", info->name);
evolution_storage_removed_folder(vfolder_storage, path);
@@ -203,12 +205,12 @@ vfolder_refresh(void)
g_free(info);
l = g_list_next(l);
}
-
+
/* setup the virtual unmatched folder */
info = vfolder_find("UNMATCHED");
if (info == NULL) {
char *uri, *path;
-
+
info = g_malloc(sizeof(*info));
info->name = g_strdup("UNMATCHED");
info->query = g_strdup("UNMATCHED");
@@ -224,7 +226,7 @@ vfolder_refresh(void)
g_free(path);
}
head = g_list_append(head, info);
-
+
g_list_free(available_vfolders);
available_vfolders = head;
g_string_free(expr, TRUE);
@@ -250,41 +252,78 @@ unlist_vfolder (CamelObject *folder, gpointer event_data, gpointer user_data)
g_message ("Whoa, unlisting vfolder %p but can't find it", folder);
}
+static int
+vfolder_remove_cb (EvolutionStorage *storage,
+ const char *path,
+ const char *physical_uri,
+ gpointer user_data)
+{
+ vfolder_remove (physical_uri);
+ return EVOLUTION_STORAGE_OK;
+}
+
void
-vfolder_create_storage(EvolutionShellComponent *shell_component)
+vfolder_create_storage (EvolutionShellComponent *shell_component)
{
EvolutionShellClient *shell_client;
GNOME_Evolution_Shell corba_shell;
EvolutionStorage *storage;
char *user, *system;
-
+
shell_client = evolution_shell_component_get_owner (shell_component);
if (shell_client == NULL) {
g_warning ("We have no shell!?");
return;
}
global_shell_client = shell_client;
-
+
corba_shell = bonobo_object_corba_objref (BONOBO_OBJECT (shell_client));
-
+
storage = evolution_storage_new (_("VFolders"), NULL, NULL);
if (evolution_storage_register_on_shell (storage, corba_shell) != EVOLUTION_STORAGE_OK) {
g_warning ("Cannot register storage");
return;
}
-
+
vfolder_storage = storage;
-
+ gtk_signal_connect (GTK_OBJECT (storage), "remove_folder",
+ GTK_SIGNAL_FUNC (vfolder_remove_cb),
+ NULL);
+
user = g_strdup_printf ("%s/vfolders.xml", evolution_dir);
system = EVOLUTION_DATADIR "/evolution/vfoldertypes.xml";
- context = vfolder_context_new();
+ context = vfolder_context_new ();
printf("loading rules %s %s\n", system, user);
- if (rule_context_load((RuleContext *)context, system, user) != 0) {
+ if (rule_context_load ((RuleContext *)context, system, user) != 0) {
g_warning("cannot load vfolders: %s\n", ((RuleContext *)context)->error);
}
- g_free(user);
- vfolder_refresh();
+ g_free (user);
+ vfolder_refresh ();
+}
+
+void
+vfolder_remove (const char *uri)
+{
+ struct _vfolder_info *info;
+ VfolderRule *rule;
+ char *user;
+
+ g_warning ("vfolder_remove (\"%s\");", uri);
+
+ if (strncmp (uri, "vfolder:", 8))
+ return;
+
+ info = vfolder_find (uri + 8);
+ if (!info)
+ return;
+
+ user = g_strdup_printf ("%s/vfolders.xml", evolution_dir);
+ rule = (VfolderRule *)rule_context_find_rule ((RuleContext *) context, info->name, NULL);
+ rule_context_remove_rule ((RuleContext *) context, (FilterRule *) rule);
+ rule_context_save ((RuleContext *) context, user);
+ g_free (user);
+ vfolder_refresh ();
}
/* maps the shell's uri to the real vfolder uri and open the folder */
@@ -298,40 +337,40 @@ vfolder_uri_to_folder(const char *uri, CamelException *ex)
const char *sourceuri;
int sources;
GList *l;
-
+
if (strncmp (uri, "vfolder:", 8))
return NULL;
-
+
info = vfolder_find(uri+8);
if (info == NULL) {
g_warning("Shell trying to open unknown vFolder: %s", uri);
return NULL;
}
-
+
if (info->folder) {
camel_object_ref((CamelObject *)info->folder);
return (CamelFolder *)info->folder;
}
-
+
d(printf("Opening vfolder: %s\n", uri));
-
+
rule = (VfolderRule *)rule_context_find_rule((RuleContext *)context, info->name, NULL);
-
+
storeuri = g_strdup_printf("vfolder:%s/vfolder/%s", evolution_dir, info->name);
foldername = g_strdup_printf("%s?%s", info->name, info->query);
-
+
/* we dont have indexing on vfolders */
folder = mail_tool_get_folder_from_urlname (storeuri, foldername, CAMEL_STORE_FOLDER_CREATE, ex);
info->folder = (CamelVeeFolder *)folder;
camel_object_hook_event ((CamelObject *) info->folder, "finalize", unlist_vfolder, NULL);
-
+
mail_folder_cache_set_update_estorage (uri, vfolder_storage);
- mail_folder_cache_note_folder (uri, info->folder);
-
+ mail_folder_cache_note_folder (uri, CAMEL_FOLDER (info->folder));
+
bonobo_object_ref (BONOBO_OBJECT (vfolder_storage));
mail_hash_storage ((CamelService *)folder->parent_store, vfolder_storage);
- if (strcmp(uri+8, "UNMATCHED") != 0) {
+ if (strcmp (uri + 8, "UNMATCHED") != 0) {
sourceuri = NULL;
sources = 0;
while ( (sourceuri = vfolder_rule_next_source(rule, sourceuri)) ) {