* src/widgets/modest-header-view-render.c:
[modest] / src / modest-tny-folder.c
index a5973b1..c913436 100644 (file)
@@ -32,6 +32,7 @@
 #include <string.h>
 #include <modest-tny-folder.h>
 #include <modest-tny-outbox-account.h>
+#include <tny-simple-list.h>
 #include <tny-camel-folder.h>
 #include <tny-merge-folder.h>
 #include <camel/camel-folder.h>
@@ -44,17 +45,23 @@ modest_tny_folder_guess_folder_type_from_name (const gchar* name)
 {
        gint  type;
        gchar *folder;
+       gchar *dc_outbox = NULL;
+       gchar *dc_sent = NULL;
+       gchar *dc_drafts = NULL;
 
        g_return_val_if_fail (name, TNY_FOLDER_TYPE_UNKNOWN);
        
        type = TNY_FOLDER_TYPE_UNKNOWN;
        folder = g_utf8_strdown (name, strlen(name));
+       dc_outbox = g_utf8_strdown (_("mcen_me_folder_outbox"), -1);
+       dc_sent = g_utf8_strdown (_("mcen_me_folder_sent"), -1);
+       dc_drafts = g_utf8_strdown (_("mcen_me_folder_drafts"), -1);
 
 //     if (strcmp (folder, "inbox") == 0 ||
 //         strcmp (folder, _("inbox")) == 0 ||
 //         strcmp (folder, _("mcen_me_folder_inbox")) == 0)
 //             type = TNY_FOLDER_TYPE_INBOX;
-       if (strcmp (folder, _("mcen_me_folder_outbox")) == 0)
+       if (strcmp (folder, dc_outbox) == 0)
                type = TNY_FOLDER_TYPE_OUTBOX;
 //     else if (g_str_has_prefix(folder, "junk") ||
 //              g_str_has_prefix(folder, _("junk")))
@@ -62,9 +69,9 @@ modest_tny_folder_guess_folder_type_from_name (const gchar* name)
 //     else if (g_str_has_prefix(folder, "trash") ||
 //              g_str_has_prefix(folder, _("trash")))
 //             type = TNY_FOLDER_TYPE_TRASH;
-       else if (strcmp (folder, _("mcen_me_folder_sent")) == 0)
+       else if (strcmp (folder, dc_sent) == 0)
                type = TNY_FOLDER_TYPE_SENT;
-       else if (strcmp (folder, _("mcen_me_folder_drafts")) == 0)
+       else if (strcmp (folder, dc_drafts) == 0)
                type = TNY_FOLDER_TYPE_DRAFTS;
 //     else if (g_str_has_prefix(folder, "notes") ||
 //              g_str_has_prefix(folder, _("notes")))
@@ -77,6 +84,9 @@ modest_tny_folder_guess_folder_type_from_name (const gchar* name)
 //             type = TNY_FOLDER_TYPE_CALENDAR;
        
        g_free (folder);
+       g_free (dc_outbox);
+       g_free (dc_sent);
+       g_free (dc_drafts);
        return type;
 }
 
@@ -243,6 +253,19 @@ modest_tny_folder_is_memory_card_folder   (TnyFolder *folder)
        return (strcmp (account_id, MODEST_MMC_ACCOUNT_ID) == 0);
 }      
 
+gboolean
+modest_tny_folder_is_remote_folder   (TnyFolder *folder)
+{
+       gboolean is_local = TRUE;
+
+       g_return_val_if_fail (folder, FALSE);
+       
+       is_local = ((modest_tny_folder_is_local_folder(folder)) ||
+                   (modest_tny_folder_is_memory_card_folder(folder)));
+
+
+       return !is_local;
+}
 
 TnyFolderType
 modest_tny_folder_get_local_or_mmc_folder_type  (TnyFolder *folder)
@@ -277,13 +300,9 @@ modest_tny_folder_get_local_or_mmc_folder_type  (TnyFolder *folder)
         * _full name_, that is, the full path name of the folder,
         * to distinguish between 'Outbox' and 'myfunkyfolder/Outbox'
         */
-       CamelFolder *camel_folder = tny_camel_folder_get_folder (TNY_CAMEL_FOLDER(folder));
-       if (!camel_folder)
-               return TNY_FOLDER_TYPE_UNKNOWN;
 
-       const gchar *full_name = camel_folder_get_full_name (camel_folder);
+       const gchar *full_name = tny_camel_folder_get_full_name (TNY_CAMEL_FOLDER (folder));
        /* printf ("DEBUG: %s: full_name=%s\n", __FUNCTION__, full_name); */
-       camel_object_unref (CAMEL_OBJECT(camel_folder));
        
        if (!full_name) 
                return TNY_FOLDER_TYPE_UNKNOWN;
@@ -301,25 +320,6 @@ modest_tny_folder_is_outbox_for_account (TnyFolder *folder, TnyAccount *account)
                return FALSE;
                
        return TRUE;
-#if 0  
-       /* we need to use the camel functions, because we want the
-        * _full name_, that is, the full path name of the folder,
-        * to distinguis between 'Outbox' and 'myfunkyfolder/Outbox'
-        */
-       CamelFolder *camel_folder = tny_camel_folder_get_folder (TNY_CAMEL_FOLDER(folder));
-       if (!camel_folder)
-               return FALSE;
-
-       const gchar *full_name = camel_folder_get_full_name (camel_folder);
-       camel_object_unref (CAMEL_OBJECT(camel_folder));
-       
-       if (!full_name) 
-               return TNY_FOLDER_TYPE_UNKNOWN;
-       else 
-               return modest_local_folder_info_get_type (full_name);
-               
-       return FALSE;
-#endif
 }
 
 gchar* 
@@ -363,3 +363,51 @@ modest_tny_folder_get_account (TnyFolder *folder)
        
        return account;
 }
+
+/*
+ * It's probably better to use a query to get the folders that match
+ * new_name but currently tinymail only provides a match by name using
+ * regular expressions and we want an exact matching. We're not using
+ * a regular expression for the exact name because we'd need first to
+ * escape @new_name and it's not easy sometimes. 
+ *
+ * The code that uses the query is available in revision 3152.
+ */
+gboolean 
+modest_tny_folder_has_subfolder_with_name (TnyFolderStore *parent,
+                                          const gchar *new_name)
+{
+       TnyList *subfolders = NULL;
+       TnyIterator *iter = NULL;
+       TnyFolder *folder = NULL;
+       GError *err = NULL;
+       gboolean same_subfolder = FALSE;
+
+       g_return_val_if_fail (TNY_IS_FOLDER_STORE (parent), FALSE);
+
+       /* Get direct subfolders */
+       subfolders = tny_simple_list_new ();
+       tny_folder_store_get_folders (parent, subfolders, NULL, &err);
+
+       /* Check names */
+       iter = tny_list_create_iterator (subfolders);
+       while (!tny_iterator_is_done (iter) && !same_subfolder) {
+               const gchar *name = NULL;
+
+               folder = TNY_FOLDER(tny_iterator_get_current (iter));
+               name = tny_folder_get_name (folder);
+               
+               same_subfolder = !strcmp(name, new_name);
+
+               g_object_unref (folder);
+               tny_iterator_next(iter);
+       }
+       
+       /* free */
+       if (iter != NULL)
+               g_object_unref (iter);
+       if (subfolders != NULL)
+               g_object_unref (subfolders);
+               
+       return same_subfolder;
+}