This patch doesn't only fix the problem described in bug #1121620 but also resolves the problems with displaying RTL messages on Gaim's IMHtml Widget.
Before my patch MSN conversation used to look like this:
data:image/s3,"s3://crabby-images/ae1a2/ae1a2c25b877427793fd17c639c1f97725f763b0" alt=""
Notice that the direction of the text was automatically (and correctly) detected in the text input field on the bottom. However, the conversation window displays all lines aligned to the left and the text direction is always LTR - therefore RTL text which includes embedded English words (LTR) becomes unreadable because the words are displayed in the wrong order.
The MSN Messenger user will also see the text displayed using the wrong alignment and the wrong direction:
data:image/s3,"s3://crabby-images/9e864/9e8647ad8d02cac6343ddcd82310663bc3b63522" alt=""
data:image/s3,"s3://crabby-images/07219/07219fc8b256efcb79f0be5cf6749bc24f1c83db" alt=""
data:image/s3,"s3://crabby-images/eecb2/eecb2188f7d77dddb8da69c2c51d1b5eaa5501e7" alt=""
The Code
Writing the patch was a little tricky - some of the code in there may seem like an ugly hack and there's probably a better way of doing some things. But that's the best I could do with my basic knowledge in GTK and Gaim API.
In this patch I implemented the following:
* Added support for [SPAN dir="rtl"] tag in the parser of the IMHtml Widget. (AFAIK this HTML tag is deprecated, but most browsers implement it and it beats coding CSS support)
* Added text direction detection to outgoing messages and send it with the correct SPAN tag.
* Added support for the "RL=1" flag in Messenger protocol implementation, both in sending and receiving messages.
* Fixed some display issues: Insert RLM and RLE Unicode characters to the conversation display according to the expected alignment and direction.
UPDATE:
Now timestamps will show up on the right side:
data:image/s3,"s3://crabby-images/c085b/c085b5bfc7ddba1c3c5649bbbfad38a28823a280" alt=""
Hebrew alias + English text
Hebrew alias + Hebrew text
English alias + English text
English alias + Hebrew text