Bug 259591 - Umlauts in the subject aren't displayed correctly in the message list
Summary: Umlauts in the subject aren't displayed correctly in the message list
Status: RESOLVED FIXED
Alias: None
Product: kmail2
Classification: Applications
Component: message list (show other bugs)
Version: 2.0.89
Platform: Unlisted Binaries Linux
: NOR normal
Target Milestone: ---
Assignee: kdepim bugs
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2010-12-12 12:01 UTC by Andreas Schneider
Modified: 2011-06-29 10:15 UTC (History)
1 user (show)

See Also:
Latest Commit:
Version Fixed In:
Sentry Crash Report:


Attachments
example with buggy 'ä' and correct 'Ü' (49.43 KB, image/png)
2010-12-13 17:47 UTC, Hans-Rudi Denzler
Details

Note You need to log in before you can comment on or make changes to this bug.
Description Andreas Schneider 2010-12-12 12:01:35 UTC
Version:           2.0.89 (using KDE 4.5.85) 
OS:                Linux

Umlauts in the subject aren't displayed correctly in the message list. If I view the mail or the raw source it is displayed correctly.

Reproducible: Always
Comment 1 Hans-Rudi Denzler 2010-12-13 17:47:29 UTC
Created attachment 54513 [details]
example with buggy 'ä' and correct 'Ü'
Comment 2 Tobias Koenig 2010-12-31 15:10:04 UTC
Hej Andreas,

the mail that is display 'wrong' in KMail message list is actually broken. The raw message is not allowed to contain 8-Bit values, they must be RFC2047 encoded like the second mail that is displayed correctly.
So the real problem is the application that created the broken message.

Ciao,
Tobias
Comment 3 Thomas McGuire 2010-12-31 17:40:47 UTC
If the header contains 8 bit values, KMail should use the fallback/override codec which is specified in the configuration. Looks like that happens in the messageviewer, but not in the messagelist.
Comment 4 Tobias Koenig 2011-01-01 16:55:13 UTC
Hej Thomas,

how shall the messageviewer/messagelist find out whether the header is stored in 8Bit?

Ciao,
Tobias
Comment 5 Thomas McGuire 2011-01-01 18:06:45 UTC
Test mail at http://www.kdab.com/~thomas/stuff/8bitsubject.mbox
Comment 6 Thomas McGuire 2011-01-01 19:54:53 UTC
Ok, the problem is that the mail is incorrectly stored in the Akonadi database.
If you have a look at parttable, you'll see the ENVELOPE is stored as:
> ("Thu, 23 Jul 2009 04:55:33 -0600" "****SPAM(20.2)**** =?UTF-
> 8?B?UmU6UG9wdWzvv71yZW4gUHJvZ3JhbW1lIGbvv71y?= PC und MAC" (("Erfahrung der 
> Spezialisten" NIL "AnthonyLatham" "morelos.com")) NIL NIL ((NIL NIL "sa_fi" 
> "gmx.net")) NIL NIL NIL "<WH4076vcvmawr@omniscient.info>" NIL)

Whereas the HEAD and RFC822 payloads are stored as:
> [..]
> Subject: ****SPAM(20.2)**** Re:Populären Programme für PC und MAC
> [..]

This is because SerializerPluginMail::serialize() actually parses the subject in the ENVELOPE case, but not in the HEAD and RFC822 cases. Parsing here is wrong, since it can't possible use the correct fallback charset.
Not quite sure what to do here, we need some way to get the raw header field out of the mail, without any parsing.
Comment 7 Thomas McGuire 2011-01-01 20:16:23 UTC
The mail is usually parsed before even passing it on to ItemCreateJob.
We still have the raw head of the mail though, which we could use for parsing out the raw header field.
Normally, headers are parsed in KMime::Types::parseHeaders(), but that interprets the header field already, while we need the raw value. We'd need something similar to that, which gives us a list of raw header fields, and use that in SerializerPluginMail::serialize()
Comment 8 Andreas Schneider 2011-06-29 10:15:46 UTC
This is fixed with KMail 2.1.0 (kdepim 4.6.0) for me. Thanks.