diff options
author | Jeffrey Stedfast <fejj@ximian.com> | 2004-02-24 04:59:29 +0800 |
---|---|---|
committer | Jeffrey Stedfast <fejj@src.gnome.org> | 2004-02-24 04:59:29 +0800 |
commit | 3185a971257950fafe7d4f5c5cb41ce0b18b60e4 (patch) | |
tree | 03237e22ccc73df4825a97cc7dc44ce13e13cdd4 /mail/em-utils.c | |
parent | b37ec6dbdfb25c455442bf60598e0931c157b130 (diff) | |
download | gsoc2013-evolution-3185a971257950fafe7d4f5c5cb41ce0b18b60e4.tar.gz gsoc2013-evolution-3185a971257950fafe7d4f5c5cb41ce0b18b60e4.tar.zst gsoc2013-evolution-3185a971257950fafe7d4f5c5cb41ce0b18b60e4.zip |
Fix for bug #54057
2004-02-23 Jeffrey Stedfast <fejj@ximian.com>
Fix for bug #54057
* em-utils.c (em_utils_folder_is_sent): Use provider->url_equal()
rather than camel_store_uri_cmp() since that function did not do
anything close to what it claimed to do. Also use
em_uri_to_camel() here on the account sent_folder_uri.
(em_utils_folder_is_drafts): Same.
svn path=/trunk/; revision=24837
Diffstat (limited to 'mail/em-utils.c')
-rw-r--r-- | mail/em-utils.c | 71 |
1 files changed, 59 insertions, 12 deletions
diff --git a/mail/em-utils.c b/mail/em-utils.c index 1ac9aeb50f..dd8aed5444 100644 --- a/mail/em-utils.c +++ b/mail/em-utils.c @@ -2116,6 +2116,28 @@ em_utils_temp_save_part(GtkWidget *parent, CamelMimePart *part) return path; } +static int +emu_provider_uri_equal (CamelProvider *provider, const char *uri0, const char *uri1) +{ + CamelURL *url0, *url1; + int equal; + + if (!(url0 = camel_url_new (uri0, NULL))) + return FALSE; + + if (!(url1 = camel_url_new (uri1, NULL))) { + camel_url_free (url0); + return FALSE; + } + + equal = provider->url_equal (url0, url1); + + camel_url_free (url0); + camel_url_free (url1); + + return equal; +} + /** * em_utils_folder_is_drafts: * @folder: folder @@ -2128,25 +2150,35 @@ em_utils_temp_save_part(GtkWidget *parent, CamelMimePart *part) gboolean em_utils_folder_is_drafts(CamelFolder *folder, const char *uri) { + CamelProvider *provider; EAccountList *accounts; EAccount *account; EIterator *iter; int is = FALSE; - + char *drafts_uri; + if (folder == mail_component_get_folder(NULL, MAIL_COMPONENT_FOLDER_DRAFTS)) return TRUE; if (uri == NULL) return FALSE; - + + if (!(provider = ((CamelService *) folder->parent_store)->provider)) + return FALSE; + accounts = mail_config_get_accounts(); iter = e_list_get_iterator((EList *)accounts); while (e_iterator_is_valid(iter)) { account = (EAccount *)e_iterator_get(iter); - if (account->drafts_folder_uri && - camel_store_uri_cmp(folder->parent_store, account->drafts_folder_uri, uri)) { - is = TRUE; - break; + + if (account->drafts_folder_uri) { + drafts_uri = em_uri_to_camel (account->drafts_folder_uri); + if (emu_provider_uri_equal (provider, drafts_uri, uri)) { + g_free (drafts_uri); + is = TRUE; + break; + } + g_free (drafts_uri); } e_iterator_next(iter); @@ -2169,25 +2201,38 @@ em_utils_folder_is_drafts(CamelFolder *folder, const char *uri) gboolean em_utils_folder_is_sent(CamelFolder *folder, const char *uri) { + CamelProvider *provider; EAccountList *accounts; EAccount *account; EIterator *iter; int is = FALSE; - + char *sent_uri; + + printf ("checking if %s is a Sent folder\n", uri); + if (folder == mail_component_get_folder(NULL, MAIL_COMPONENT_FOLDER_SENT)) return TRUE; if (uri == NULL) return FALSE; - + + if (!(provider = ((CamelService *) folder->parent_store)->provider)) + return FALSE; + accounts = mail_config_get_accounts(); iter = e_list_get_iterator((EList *)accounts); while (e_iterator_is_valid(iter)) { account = (EAccount *)e_iterator_get(iter); - if (account->sent_folder_uri && - camel_store_uri_cmp(folder->parent_store, account->sent_folder_uri, uri)) { - is = TRUE; - break; + + if (account->sent_folder_uri) { + sent_uri = em_uri_to_camel (account->sent_folder_uri); + printf ("\tcomparing %s to %s\n", sent_uri, uri); + if (emu_provider_uri_equal (provider, sent_uri, uri)) { + g_free (sent_uri); + is = TRUE; + break; + } + g_free (sent_uri); } e_iterator_next(iter); @@ -2195,6 +2240,8 @@ em_utils_folder_is_sent(CamelFolder *folder, const char *uri) g_object_unref(iter); + printf ("%s\n", is ? "yup" : "nup"); + return is; } |