type = modest_tny_folder_get_local_or_mmc_folder_type (folder);
else
type = tny_folder_get_folder_type (TNY_FOLDER (folder));
+
+ /* Fallback code, some servers (Dovecot in some versions)
+ report incorrectly that the INBOX folder is a normal
+ folder. Really ugly code but... */
+ if (type == TNY_FOLDER_TYPE_NORMAL) {
+ TnyFolderStore *parent = tny_folder_get_folder_store (folder);
+ if (parent) {
+ if (TNY_IS_ACCOUNT (parent)) {
+ gchar *downcase =
+ g_ascii_strdown (tny_camel_folder_get_full_name (TNY_CAMEL_FOLDER (folder)),
+ -1);
+
+ if ((strlen (downcase) == 5) &&
+ !strncmp (downcase, "inbox", 5))
+ type = TNY_FOLDER_TYPE_INBOX;
+ g_free (downcase);
+ }
+ g_object_unref (parent);
+ }
+ }
if (type == TNY_FOLDER_TYPE_UNKNOWN) {
const gchar *folder_name =
return FALSE;
const gchar* account_id = tny_account_get_id (account);
- if (!account_id)
+ if (!account_id) {
+ g_object_unref (account);
return FALSE;
+ }
- g_object_unref (G_OBJECT(account));
+ g_object_unref (account);
return (strcmp (account_id, MODEST_MMC_ACCOUNT_ID) == 0);
}
{
gboolean is_local = TRUE;
- g_return_val_if_fail (folder, FALSE);
+ g_return_val_if_fail (TNY_IS_FOLDER(folder), FALSE);
is_local = ((modest_tny_folder_is_local_folder(folder)) ||
(modest_tny_folder_is_memory_card_folder(folder)));
{
TnyFolder *folder;
gchar *url, *retval;
- const gchar *uid;
+ gchar *uid;
g_return_val_if_fail (TNY_IS_HEADER (header), NULL);
return NULL;
url = tny_folder_get_url_string (folder);
- uid = tny_header_get_uid (header);
+ uid = tny_header_dup_uid (header);
retval = g_strjoin ("/", url, uid, NULL);
+ g_free (uid);
g_free (url);
g_object_unref (folder);
modest_tny_folder_get_account (TnyFolder *folder)
{
TnyAccount *account = NULL;
+
+ g_return_val_if_fail (TNY_IS_FOLDER(folder), NULL);
if (TNY_IS_MERGE_FOLDER (folder)) {
/* TnyMergeFolder does not support get_account(),