#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>
{
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));
-
- if (strcmp (folder, "inbox") == 0 ||
- strcmp (folder, _("inbox")) == 0 ||
- strcmp (folder, _("mcen_me_folder_inbox")) == 0)
- type = TNY_FOLDER_TYPE_INBOX;
- else if (strcmp (folder, "outbox") == 0 ||
- strcmp (folder, _("outbox")) == 0 ||
- strcmp (folder, _("mcen_me_folder_outbox")) == 0)
+ 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, dc_outbox) == 0)
type = TNY_FOLDER_TYPE_OUTBOX;
- else if (g_str_has_prefix(folder, "junk") ||
- g_str_has_prefix(folder, _("junk")))
- type = TNY_FOLDER_TYPE_JUNK;
- else if (g_str_has_prefix(folder, "trash") ||
- g_str_has_prefix(folder, _("trash")))
- type = TNY_FOLDER_TYPE_TRASH;
- else if (g_str_has_prefix(folder, "sent") ||
- g_str_has_prefix(folder, _("sent")) ||
- strcmp (folder, _("mcen_me_folder_sent")) == 0)
+// else if (g_str_has_prefix(folder, "junk") ||
+// g_str_has_prefix(folder, _("junk")))
+// type = TNY_FOLDER_TYPE_JUNK;
+// else if (g_str_has_prefix(folder, "trash") ||
+// g_str_has_prefix(folder, _("trash")))
+// type = TNY_FOLDER_TYPE_TRASH;
+ else if (strcmp (folder, dc_sent) == 0)
type = TNY_FOLDER_TYPE_SENT;
- else if (g_str_has_prefix(folder, "draft") ||
- g_str_has_prefix(folder, _("draft")) ||
- 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")))
- type = TNY_FOLDER_TYPE_NOTES;
- else if (g_str_has_prefix(folder, "contacts") ||
- g_str_has_prefix(folder, _("contacts")))
- type = TNY_FOLDER_TYPE_CONTACTS;
- else if (g_str_has_prefix(folder, "calendar") ||
- g_str_has_prefix(folder, _("calendar")))
- type = TNY_FOLDER_TYPE_CALENDAR;
+// else if (g_str_has_prefix(folder, "notes") ||
+// g_str_has_prefix(folder, _("notes")))
+// type = TNY_FOLDER_TYPE_NOTES;
+// else if (g_str_has_prefix(folder, "contacts") ||
+// g_str_has_prefix(folder, _("contacts")))
+// type = TNY_FOLDER_TYPE_CONTACTS;
+// else if (g_str_has_prefix(folder, "calendar") ||
+// g_str_has_prefix(folder, _("calendar")))
+// type = TNY_FOLDER_TYPE_CALENDAR;
g_free (folder);
+ g_free (dc_outbox);
+ g_free (dc_sent);
+ g_free (dc_drafts);
return type;
}
modest_tny_folder_guess_folder_type (const TnyFolder *folder)
{
TnyFolderType type;
+
+ g_return_val_if_fail (TNY_IS_FOLDER(folder), TNY_FOLDER_TYPE_UNKNOWN);
- g_return_val_if_fail (folder, TNY_FOLDER_TYPE_UNKNOWN);
-
- type = tny_folder_get_folder_type (TNY_FOLDER (folder));
+ if (modest_tny_folder_is_local_folder ((TnyFolder*)folder))
+ type = modest_tny_folder_get_local_or_mmc_folder_type ((TnyFolder*)folder);
+ else
+ type = tny_folder_get_folder_type (TNY_FOLDER (folder));
if (type == TNY_FOLDER_TYPE_UNKNOWN) {
const gchar *folder_name;
-
folder_name = tny_folder_get_name (TNY_FOLDER (folder));
type = modest_tny_folder_guess_folder_type_from_name (folder_name);
}
if (modest_tny_folder_is_local_folder (folder) ||
modest_tny_folder_is_memory_card_folder (folder)) {
- type = modest_tny_folder_get_local_folder_type (folder);
+ type = modest_tny_folder_get_local_or_mmc_folder_type (folder);
switch (type) {
case TNY_FOLDER_TYPE_OUTBOX:
case TNY_FOLDER_TYPE_SENT:
- rules |= MODEST_FOLDER_RULES_FOLDER_NON_WRITEABLE;
case TNY_FOLDER_TYPE_DRAFTS:
+ rules |= MODEST_FOLDER_RULES_FOLDER_NON_WRITEABLE;
case TNY_FOLDER_TYPE_INBOX:
case TNY_FOLDER_TYPE_JUNK:
case TNY_FOLDER_TYPE_TRASH:
}
} else {
ModestTransportStoreProtocol proto;
- TnyAccount *account =
- modest_tny_folder_get_account ((TnyFolder*)folder);
+ TnyFolderType folder_type;
+ TnyAccount *account;
+
+ account = modest_tny_folder_get_account ((TnyFolder*)folder);
if (!account)
return -1; /* no account: nothing is allowed */
}
g_object_unref (G_OBJECT(account));
+
+ /* Neither INBOX nor ROOT, nor ARCHIVE folders should me moveable */
+ folder_type = modest_tny_folder_guess_folder_type (folder);
+ if ((folder_type == TNY_FOLDER_TYPE_INBOX) ||
+ (folder_type == TNY_FOLDER_TYPE_ROOT) ||
+ (folder_type == TNY_FOLDER_TYPE_ARCHIVE)) {
+ rules |= MODEST_FOLDER_RULES_FOLDER_NON_DELETABLE;
+ rules |= MODEST_FOLDER_RULES_FOLDER_NON_MOVEABLE;
+ rules |= MODEST_FOLDER_RULES_FOLDER_NON_RENAMEABLE;
+ }
}
return rules;
}
+
gboolean
modest_tny_folder_is_local_folder (TnyFolder *folder)
{
- g_return_val_if_fail (folder, FALSE);
+ g_return_val_if_fail (TNY_IS_FOLDER (folder), FALSE);
/* The merge folder is a special case,
* used to merge the per-account local outbox folders.
* We should do something more sophisticated if we
* ever use TnyMergeFolder for anything else.
*/
- if (TNY_IS_MERGE_FOLDER (folder))
+ if (TNY_IS_MERGE_FOLDER (folder)) {
return TRUE;
-
+ }
+
TnyAccount* account = tny_folder_get_account ((TnyFolder*)folder);
- if (!account)
+ if (!account) {
+ g_warning ("folder without account");
return FALSE;
-
+ }
+
/* Outbox is a special case, using a derived TnyAccount: */
if (MODEST_IS_TNY_OUTBOX_ACCOUNT (account)) {
- g_object_unref (account);
- return TRUE;
+ //g_warning ("BUG: should not be reached");
+ /* should be handled with the MERGE_FOLDER above*/
+ g_object_unref (G_OBJECT(account));
+ return TRUE;
}
const gchar* account_id = tny_account_get_id (account);
- if (!account_id)
+ if (!account_id) {
+ g_warning ("BUG: account without account id");
+ g_object_unref (G_OBJECT(account));
return FALSE;
-
- g_object_unref (G_OBJECT(account));
+ }
+ g_object_unref (G_OBJECT(account));
return (strcmp (account_id, MODEST_LOCAL_FOLDERS_ACCOUNT_ID) == 0);
}
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_folder_type (TnyFolder *folder)
+modest_tny_folder_get_local_or_mmc_folder_type (TnyFolder *folder)
{
g_return_val_if_fail (folder, TNY_FOLDER_TYPE_UNKNOWN);
-
+ g_return_val_if_fail (modest_tny_folder_is_local_folder(folder)||
+ modest_tny_folder_is_memory_card_folder(folder),
+ TNY_FOLDER_TYPE_UNKNOWN);
+
/* The merge folder is a special case,
* used to merge the per-account local outbox folders.
* and can have no get_account() implementation.
g_object_unref (parent_account);
parent_account = NULL;
}
-
-
- g_return_val_if_fail (modest_tny_folder_is_local_folder(folder),
- TNY_FOLDER_TYPE_UNKNOWN);
-
+
/* we need to use the camel functions, because we want the
* _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;
g_return_val_if_fail(folder, FALSE);
g_return_val_if_fail(account, FALSE);
- if (modest_tny_folder_get_local_folder_type (folder) != TNY_FOLDER_TYPE_OUTBOX)
+ if (modest_tny_folder_get_local_or_mmc_folder_type (folder) != TNY_FOLDER_TYPE_OUTBOX)
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*
return retval;
}
-TnyAccount *modest_tny_folder_get_account (TnyFolder *folder)
+TnyAccount *
+modest_tny_folder_get_account (TnyFolder *folder)
{
TnyAccount *account = NULL;
* because it could be merging folders from multiple accounts.
* So we assume that this is the local folders account: */
- account = modest_tny_account_store_get_local_folders_account (
- TNY_ACCOUNT_STORE (modest_runtime_get_account_store()));
+ account = modest_tny_account_store_get_local_folders_account (modest_runtime_get_account_store());
} else {
account = tny_folder_get_account (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;
+}