diff options
Diffstat (limited to 'mail/mail-format.c')
-rw-r--r-- | mail/mail-format.c | 101 |
1 files changed, 63 insertions, 38 deletions
diff --git a/mail/mail-format.c b/mail/mail-format.c index 480a3fbcdc..b1e3f9b5d1 100644 --- a/mail/mail-format.c +++ b/mail/mail-format.c @@ -872,30 +872,53 @@ write_address (MailDisplay *md, const CamelInternetAddress *addr, const char *fi mail_html_write (md->html, md->stream, "</td></tr>"); } +/* order of these must match write_header code */ +static char *default_headers[] = { + "From", "Reply-To", "To", "Cc", "Subject", "Date", +}; + +/* return index of header in default_headers array */ +static int +default_header_index(const char *name) +{ + int i; + for (i=0;i<sizeof(default_headers)/sizeof(default_headers[0]);i++) + if (!g_strcasecmp(name, default_headers[i])) + return i; + + return -1; +} + +/* index is index of header in default_headers array */ static void -write_header (CamelMimeMessage *message, MailDisplay *md, - const char *name, const char *value, int flags) +write_default_header(CamelMimeMessage *message, MailDisplay *md, int index, int flags) { - if (!g_strcasecmp (name, "From")) { - write_address (md, camel_mime_message_get_from (message), - _("From"), flags | WRITE_BOLD); - } else if (!g_strcasecmp (name, "Reply-To")) { - write_address (md, camel_mime_message_get_reply_to (message), - _("Reply-To"), flags); - } else if (!g_strcasecmp (name, "To")) { - write_address (md, camel_mime_message_get_recipients (message, CAMEL_RECIPIENT_TYPE_TO), - _("To"), flags | WRITE_BOLD); - } else if (!g_strcasecmp (name, "Cc")) { + switch(index) { + case 0: + write_address (md, camel_mime_message_get_from (message), _("From"), flags | WRITE_BOLD); + break; + case 1: + write_address (md, camel_mime_message_get_reply_to (message), _("Reply-To"), flags); + break; + case 2: + write_address(md, camel_mime_message_get_recipients(message, CAMEL_RECIPIENT_TYPE_TO), + _("To"), flags | WRITE_BOLD); + break; + case 3: write_address (md, camel_mime_message_get_recipients (message, CAMEL_RECIPIENT_TYPE_CC), _("Cc"), flags | WRITE_BOLD); - } else if (!g_strcasecmp (name, "Subject")) { + break; + case 4: write_text_header (_("Subject"), camel_mime_message_get_subject (message), flags | WRITE_BOLD, md->html, md->stream); - } else if (!g_strcasecmp (name, "Date")) { + break; + case 5: write_date (message, flags | WRITE_BOLD, md->html, md->stream); - } else - write_text_header (name, value, flags, md->html, md->stream); + break; + default: + g_assert_not_reached(); + } } #define COLOR_IS_LIGHT(r, g, b) ((r + g + b) > (128 * 3)) @@ -904,16 +927,10 @@ static void write_headers (CamelMimeMessage *message, MailDisplay *md) { gboolean full = (md->display_style == MAIL_CONFIG_DISPLAY_FULL_HEADERS); - CamelMediumHeader *headers, default_headers[] = { - { "From", NULL }, { "Reply-To", NULL }, - { "To", NULL }, { "Cc" , NULL }, { "Subject", NULL }, - { "Date", NULL } - }; char bgcolor[7], fontcolor[7]; GtkStyle *style = NULL; - int i, len, flags; - GArray *gheaders; - + int i; + /* My favorite thing to do...much around with colors so we respect people's stupid themes */ style = gtk_widget_get_style (GTK_WIDGET (md->html)); if (style) { @@ -958,23 +975,31 @@ write_headers (CamelMimeMessage *message, MailDisplay *md) "<tr><td><table>\n", fontcolor, bgcolor); if (full) { - gheaders = camel_medium_get_headers (CAMEL_MEDIUM (message)); - headers = (CamelMediumHeader *)gheaders->data; - len = gheaders->len; - flags = WRITE_NOCOLUMNS; + struct _header_raw *header; + const char *charset; + CamelContentType *ct; + char *value; + + ct = camel_mime_part_get_content_type(CAMEL_MIME_PART(message)); + charset = header_content_type_param(ct, "charset"); + charset = camel_charset_to_iconv(charset); + + header = CAMEL_MIME_PART(message)->headers; + while (header) { + i = default_header_index(header->name); + if (i == -1) { + value = header_decode_string(header->value, charset); + write_text_header(header->name, value, WRITE_NOCOLUMNS, md->html, md->stream); + g_free(value); + } else + write_default_header(message, md, i, WRITE_NOCOLUMNS); + header = header->next; + } } else { - gheaders = NULL; - headers = default_headers; - len = sizeof (default_headers) / sizeof (default_headers[0]); - flags = 0; + for (i=0;i<sizeof(default_headers)/sizeof(default_headers[0]);i++) + write_default_header(message, md, i, 0); } - for (i = 0; i < len; i++) - write_header (message, md, headers[i].name, headers[i].value, flags); - - if (gheaders) - camel_medium_free_headers (CAMEL_MEDIUM (message), gheaders); - mail_html_write (md->html, md->stream, "</table></td></tr></table></td></tr></table></font></td>" "<td><table width=10 cellpadding=0 cellspacing=0><tr><td></td></tr></table></td></tr>" |