diff options
-rw-r--r-- | mail/ChangeLog | 20 | ||||
-rw-r--r-- | mail/em-folder-tree-model.c | 16 | ||||
-rw-r--r-- | mail/mail-autofilter.c | 8 | ||||
-rw-r--r-- | mail/mail-folder-cache.c | 18 | ||||
-rw-r--r-- | mail/mail-vfolder.c | 66 |
5 files changed, 103 insertions, 25 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 4280d4aa02..a73e8cc722 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,5 +1,25 @@ 2004-01-16 Not Zed <NotZed@Ximian.com> + * mail-folder-cache.c (storeinfo_find_folder_info): change this to + check the store using the provider url_cmp and just lookup the + folder name directly. folder_compare can't be used for uri's, + this stuff was so broken, my fault :( + + ** See bug #52467. + + * em-folder-tree-model.c (sort_cb): handle null path (root?). + + * mail-vfolder.c (mail_vfolder_add_uri): map uri to euri before + processing. + (rule_changed): map uri to camel uri before looking up. + (mail_vfolder_delete_uri): handle as euri internally. + (mail_vfolder_rename_uri): " + + * mail-autofilter.c (vfolder_rule_from_message): map camel uri to + euri before setting as vfolder source. + +2004-01-16 Not Zed <NotZed@Ximian.com> + * default/C/Inbox: * default/C/Makefile.am: * default/Makefile.am: Startup files/folders. diff --git a/mail/em-folder-tree-model.c b/mail/em-folder-tree-model.c index 6f409cfb05..fc29c5e761 100644 --- a/mail/em-folder-tree-model.c +++ b/mail/em-folder-tree-model.c @@ -214,12 +214,20 @@ sort_cb (GtkTreeModel *model, GtkTreeIter *a, GtkTreeIter *b, gpointer user_data return -1; path = gtk_tree_model_get_path (model, a); - aname = gtk_tree_path_to_string (path); - gtk_tree_path_free (path); + if (path) { + aname = gtk_tree_path_to_string (path); + gtk_tree_path_free (path); + } else { + aname = g_strdup(""); + } path = gtk_tree_model_get_path (model, b); - bname = gtk_tree_path_to_string (path); - gtk_tree_path_free (path); + if (path) { + bname = gtk_tree_path_to_string (path); + gtk_tree_path_free (path); + } else { + bname = g_strdup(""); + } ret = strcmp (aname, bname); g_free (aname); diff --git a/mail/mail-autofilter.c b/mail/mail-autofilter.c index 79ab30f5dd..5d8de5fcad 100644 --- a/mail/mail-autofilter.c +++ b/mail/mail-autofilter.c @@ -326,11 +326,13 @@ FilterRule * vfolder_rule_from_message (VfolderContext *context, CamelMimeMessage *msg, int flags, const char *source) { VfolderRule *rule; - + char *euri = em_uri_from_camel(source); + rule = vfolder_rule_new (); - vfolder_rule_add_source (rule, source); + vfolder_rule_add_source (rule, euri); rule_from_message ((FilterRule *)rule, (RuleContext *)context, msg, flags); - + g_free(euri); + return (FilterRule *)rule; } diff --git a/mail/mail-folder-cache.c b/mail/mail-folder-cache.c index 750f9ab30d..285f1d1230 100644 --- a/mail/mail-folder-cache.c +++ b/mail/mail-folder-cache.c @@ -932,24 +932,34 @@ mail_note_store(CamelStore *store, CamelOperation *op, struct _find_info { const char *uri; struct _folder_info *fi; + CamelURL *url; }; /* look up on each storeinfo using proper hash function for that stores uri's */ static void storeinfo_find_folder_info(CamelStore *store, struct _store_info *si, struct _find_info *fi) { - if (fi->fi == NULL) - fi->fi = g_hash_table_lookup(si->folders_uri, fi->uri); + if (fi->fi == NULL) { + if (((CamelService *)store)->provider->url_equal(fi->url, ((CamelService *)store)->url)) { + char *path = fi->url->fragment?fi->url->fragment:fi->url->path; + + if (path[0] == '/') + path++; + fi->fi = g_hash_table_lookup(si->folders, path); + } + } } /* returns TRUE if the uri is available, folderp is set to a reffed folder if the folder has also already been opened */ int mail_note_get_folder_from_uri(const char *uri, CamelFolder **folderp) { - struct _find_info fi = { uri, NULL }; + struct _find_info fi = { uri, NULL, NULL }; if (stores == NULL) return FALSE; + fi.url = camel_url_new(uri, NULL); + LOCK(info_lock); g_hash_table_foreach(stores, (GHFunc)storeinfo_find_folder_info, &fi); if (folderp) { @@ -962,5 +972,7 @@ int mail_note_get_folder_from_uri(const char *uri, CamelFolder **folderp) } UNLOCK(info_lock); + camel_url_free(fi.url); + return fi.fi != NULL; } diff --git a/mail/mail-vfolder.c b/mail/mail-vfolder.c index f014e42d08..963006c915 100644 --- a/mail/mail-vfolder.c +++ b/mail/mail-vfolder.c @@ -168,6 +168,7 @@ static struct _mail_msg_op vfolder_setup_op = { vfolder_setup_free, }; +/* sources_uri should be camel uri's */ static int vfolder_setup(CamelFolder *folder, const char *query, GList *sources_uri, GList *sources_folder) { @@ -261,6 +262,8 @@ static struct _mail_msg_op vfolder_adduri_op = { vfolder_adduri_free, }; + +/* uri should be a camel uri */ static int vfolder_adduri(const char *uri, GList *folders, int remove) { @@ -292,6 +295,7 @@ my_list_find(GList *l, const char *uri, GCompareFunc cmp) return l; } +/* uri is a camel uri */ static int uri_is_ignore(const char *uri, GCompareFunc uri_cmp) { @@ -331,7 +335,7 @@ uri_is_ignore(const char *uri, GCompareFunc uri_cmp) /* called when a new uri becomes (un)available */ void -mail_vfolder_add_uri(CamelStore *store, const char *uri, int remove) +mail_vfolder_add_uri(CamelStore *store, const char *curi, int remove) { FilterRule *rule; const char *source; @@ -340,13 +344,17 @@ mail_vfolder_add_uri(CamelStore *store, const char *uri, int remove) int remote = (((CamelService *)store)->provider->flags & CAMEL_PROVIDER_IS_REMOTE) != 0; GCompareFunc uri_cmp = CAMEL_STORE_CLASS(CAMEL_OBJECT_GET_CLASS(store))->compare_folder_name; int is_ignore; + char *uri; - if (CAMEL_IS_VEE_STORE(store) || !strncmp(uri, "vtrash:", 7) || !strncmp(uri, "vjunk:", 6) || context == NULL) + uri = em_uri_from_camel(curi); + if (CAMEL_IS_VEE_STORE(store) || !strncmp(curi, "vtrash:", 7) || !strncmp(curi, "vjunk:", 6) || context == NULL) { + g_free(uri); return; + } g_assert(pthread_self() == mail_gui_thread); - is_ignore = uri_is_ignore(uri, uri_cmp); + is_ignore = uri_is_ignore(curi, uri_cmp); LOCK(); @@ -395,9 +403,15 @@ mail_vfolder_add_uri(CamelStore *store, const char *uri, int remove) /* we check using the store uri_cmp since its more accurate */ source = NULL; - while (!found && (source = vfolder_rule_next_source((VfolderRule *)rule, source))) - found = uri_cmp(uri, source); - + while (!found && (source = vfolder_rule_next_source((VfolderRule *)rule, source))) { + char *esource; + + esource = em_uri_from_camel(source); + found = uri_cmp(uri, esource); + d(printf(found?" '%s' == '%s'?\n":" '%s' != '%s'\n", uri, esource)); + g_free(esource); + } + if (found) { vf = g_hash_table_lookup(vfolder_hash, rule->name); g_assert(vf); @@ -409,22 +423,27 @@ mail_vfolder_add_uri(CamelStore *store, const char *uri, int remove) UNLOCK(); if (folders != NULL) - vfolder_adduri(uri, folders, remove); + vfolder_adduri(curi, folders, remove); + + g_free(uri); } /* called when a uri is deleted from a store */ void -mail_vfolder_delete_uri(CamelStore *store, const char *uri) +mail_vfolder_delete_uri(CamelStore *store, const char *curi) { GCompareFunc uri_cmp = CAMEL_STORE_CLASS(CAMEL_OBJECT_GET_CLASS(store))->compare_folder_name; FilterRule *rule; const char *source; CamelVeeFolder *vf; GString *changed; + char *uri; - if (context == NULL || !strncmp(uri, "vtrash:", 7) || !strncmp(uri, "vjunk:", 6)) + if (context == NULL || !strncmp(curi, "vtrash:", 7) || !strncmp(curi, "vjunk:", 6)) return; - + + uri = em_uri_from_camel(curi); + d(printf ("Deleting uri to check: %s\n", uri)); g_assert (pthread_self() == mail_gui_thread); @@ -474,25 +493,31 @@ mail_vfolder_delete_uri(CamelStore *store, const char *uri) } g_string_free (changed, TRUE); + + g_free(uri); } /* called when a uri is renamed in a store */ void -mail_vfolder_rename_uri(CamelStore *store, const char *from, const char *to) +mail_vfolder_rename_uri(CamelStore *store, const char *cfrom, const char *cto) { GCompareFunc uri_cmp = CAMEL_STORE_CLASS(CAMEL_OBJECT_GET_CLASS(store))->compare_folder_name; FilterRule *rule; const char *source; CamelVeeFolder *vf; int changed = 0; + char *from, *to; d(printf("vfolder rename uri: %s to %s\n", from, to)); - if (context == NULL || !strncmp(from, "vtrash:", 7) || !strncmp(to, "vtrash:", 7) || !strncmp(from, "vjunk:", 6) || !strncmp(to, "vjunk:", 6)) + if (context == NULL || !strncmp(cfrom, "vtrash:", 7) || !strncmp(cto, "vtrash:", 7) || !strncmp(cfrom, "vjunk:", 6) || !strncmp(cto, "vjunk:", 6)) return; g_assert(pthread_self() == mail_gui_thread); + from = em_uri_from_camel(cfrom); + to = em_uri_from_camel(cto); + LOCK(); /* see if any rules directly reference this removed uri */ @@ -527,6 +552,9 @@ mail_vfolder_rename_uri(CamelStore *store, const char *from, const char *to) rule_context_save((RuleContext *)context, user); g_free(user); } + + g_free(from); + g_fre(to); } /* ********************************************************************** */ @@ -571,12 +599,17 @@ rule_changed(FilterRule *rule, CamelFolder *folder) /* find any (currently available) folders, and add them to the ones to open */ sourceuri = NULL; while ( (sourceuri = vfolder_rule_next_source((VfolderRule *)rule, sourceuri)) ) { - if (mail_note_get_folder_from_uri(sourceuri, &newfolder)) { + char *curi = em_uri_to_camel(sourceuri); + + d(printf(" adding source '%s' '%s'\n", sourceuri, curi)); + if (mail_note_get_folder_from_uri(curi, &newfolder)) { if (newfolder) sources_folder = g_list_append(sources_folder, newfolder); else sources_uri = g_list_append(sources_uri, g_strdup(sourceuri)); } + + g_free(curi); } /* check the remote/local uri lists for any other uri's that should be looked at */ @@ -591,14 +624,17 @@ rule_changed(FilterRule *rule, CamelFolder *folder) l = NULL; while (l) { - if (mail_note_get_folder_from_uri(l->data, &newfolder)) { + char *curi = em_uri_to_camel(l->data); + + if (mail_note_get_folder_from_uri(curi, &newfolder)) { if (newfolder) sources_folder = g_list_append(sources_folder, newfolder); else - sources_uri = g_list_append(sources_uri, g_strdup(l->data)); + sources_uri = g_list_append(sources_uri, g_strdup(curi)); } else { d(printf(" -> No such folder?\n")); } + g_free(curi); l = l->next; } } |