X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fmodest-tny-mime-part.c;h=67cde71832474082bcde225798acf8c1db8f5656;hb=ec26585a72a0853160fd88313bc6b77c19304d99;hp=15001207bf5a4dff7fb406382679428bc1361b29;hpb=4e501493efaac0d9331e924a2ea569497abff1bf;p=modest diff --git a/src/modest-tny-mime-part.c b/src/modest-tny-mime-part.c index 1500120..67cde71 100644 --- a/src/modest-tny-mime-part.c +++ b/src/modest-tny-mime-part.c @@ -85,7 +85,7 @@ modest_tny_mime_part_is_attachment_for_modest (TnyMimePart *part) g_return_val_if_fail (part && TNY_IS_MIME_PART(part), FALSE); /* if tinymail thinks it's an attachment, it definitely is */ - if (tny_mime_part_is_attachment (part)) + if (tny_mime_part_is_attachment (part) || tny_mime_part_is_purged (part)) return TRUE; /* if the mime part is a message itself (ie. embedded), it's an attachment */ @@ -94,9 +94,22 @@ modest_tny_mime_part_is_attachment_for_modest (TnyMimePart *part) tmp = modest_tny_mime_part_get_header_value (part, "Content-Disposition"); if (tmp) { + /* If the Content-Disposition header contains a "name" + * parameter, treat the mime part as an attachment */ gchar *content_disp = g_ascii_strdown(tmp, -1); + gint len = strlen (content_disp); + const gchar *substr = g_strstr_len (content_disp, len, "name"); + if (substr != NULL) { + gint substrlen = len - (substr - content_disp); + /* The parameter can appear in muliple + * ways. See RFC 2231 for details */ + has_content_disp_name = + g_strstr_len (substr, substrlen, "name=") != NULL || + g_strstr_len (substr, substrlen, "name*=") != NULL || + g_strstr_len (substr, substrlen, "name*0=") != NULL || + g_strstr_len (substr, substrlen, "name*0*=") != NULL; + } g_free (tmp); - has_content_disp_name = g_strstr_len (content_disp, strlen(content_disp), "name=") != NULL; g_free (content_disp); }