aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog6
-rw-r--r--mail/mail-format.c7
2 files changed, 11 insertions, 2 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 1da0a85eed..3fb203c98b 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,5 +1,11 @@
2003-03-21 Jeffrey Stedfast <fejj@ximian.com>
+ * mail-format.c (mail_format_data_wrapper_write_to_stream):
+ Default to the charset provied in the MimePart's Content-Type over
+ that of the user's mailer charset. Fixes bug #39204.
+
+2003-03-21 Jeffrey Stedfast <fejj@ximian.com>
+
* mail-composer-prefs.c (spell_load_values): "en_us" should not be
translated. Fixes bug #40088.
diff --git a/mail/mail-format.c b/mail/mail-format.c
index 9d4423c1af..562776da16 100644
--- a/mail/mail-format.c
+++ b/mail/mail-format.c
@@ -1099,19 +1099,20 @@ mail_format_data_wrapper_write_to_stream (CamelDataWrapper *wrapper, MailDisplay
if (wrapper->rawtext || (mail_display && mail_display->charset)) {
CamelMimeFilterCharset *filter;
+ CamelContentType *content_type;
GConfClient *gconf;
char *charset;
gconf = gconf_client_get_default ();
+ content_type = camel_data_wrapper_get_mime_type_field (wrapper);
+
if (!wrapper->rawtext) {
/* data wrapper had been successfully converted to UTF-8 using the mime
part's charset, but the user thinks he knows best so we'll let him
shoot himself in the foot here... */
- CamelContentType *content_type;
/* get the original charset of the mime part */
- content_type = camel_data_wrapper_get_mime_type_field (wrapper);
charset = (char *) (content_type ? header_content_type_param (content_type, "charset") : NULL);
if (!charset)
charset = gconf_client_get_string (gconf, "/apps/evolution/mail/format/charset", NULL);
@@ -1132,6 +1133,8 @@ mail_format_data_wrapper_write_to_stream (CamelDataWrapper *wrapper, MailDisplay
/* find out the charset the user wants to override to */
if (mail_display && mail_display->charset)
charset = g_strdup (mail_display->charset);
+ else if (content_type && (charset = (char *) header_content_type_param (content_type, "charset")))
+ charset = g_strdup (charset);
else
charset = gconf_client_get_string (gconf, "/apps/evolution/mail/format/charset", NULL);