aboutsummaryrefslogtreecommitdiffstats
path: root/camel
diff options
context:
space:
mode:
Diffstat (limited to 'camel')
-rw-r--r--camel/ChangeLog7
-rw-r--r--camel/camel-mime-part.c17
2 files changed, 22 insertions, 2 deletions
diff --git a/camel/ChangeLog b/camel/ChangeLog
index b029bbcb0f..d421ac2c8c 100644
--- a/camel/ChangeLog
+++ b/camel/ChangeLog
@@ -1,3 +1,10 @@
+2002-09-13 Jeffrey Stedfast <fejj@ximian.com>
+
+ * camel-mime-part.c (process_header): If header_msgid_decode fails
+ for the content-id field, just grab whatever is between the <>'s
+ (yes, this means that the content-id is invalid - but what can ya
+ do?). Addresses bug #21027.
+
2002-09-11 Jeffrey Stedfast <fejj@ximian.com>
* camel-mime-utils.c (header_encode_string): Revert a patch that I
diff --git a/camel/camel-mime-part.c b/camel/camel-mime-part.c
index 3ebd45e6aa..c7545a6a9c 100644
--- a/camel/camel-mime-part.c
+++ b/camel/camel-mime-part.c
@@ -212,7 +212,7 @@ process_header(CamelMedium *medium, const char *header_name, const char *header_
{
CamelMimePart *mime_part = CAMEL_MIME_PART (medium);
CamelHeaderType header_type;
- const char *charset;
+ const char *charset, *p;
char *text;
/* Try to parse the header pair. If it corresponds to something */
@@ -234,7 +234,20 @@ process_header(CamelMedium *medium, const char *header_name, const char *header_
break;
case HEADER_CONTENT_ID:
g_free (mime_part->content_id);
- mime_part->content_id = header_msgid_decode (header_value);
+ if (!(mime_part->content_id = header_msgid_decode (header_value))) {
+ header_decode_lwsp (&header_value);
+ if (*header_value == '<') {
+ p = header_value;
+ while (*p && *p != '>')
+ p++;
+ mime_part->content_id = g_strndup (header_value, p - header_value);
+ } else if (*header_value) {
+ mime_part->content_id = g_strdup (header_value);
+ }
+
+ if (mime_part->header_value)
+ g_strstrip (mime_part->header_value);
+ }
break;
case HEADER_ENCODING:
text = header_token_decode (header_value);