aboutsummaryrefslogtreecommitdiffstats
path: root/mail/message-list.c
diff options
context:
space:
mode:
authorMilan Crha <mcrha@redhat.com>2011-12-22 23:38:51 +0800
committerMilan Crha <mcrha@redhat.com>2011-12-22 23:38:51 +0800
commit0cd98f1a85724293e2583180b8d8dc4b2284647f (patch)
treef7bda6377ad95c40ed5cf8d5a79590f2a9094344 /mail/message-list.c
parent987fb91d5ec4b61d1283acdb9cf02960cc47b74d (diff)
downloadgsoc2013-evolution-0cd98f1a85724293e2583180b8d8dc4b2284647f.tar
gsoc2013-evolution-0cd98f1a85724293e2583180b8d8dc4b2284647f.tar.gz
gsoc2013-evolution-0cd98f1a85724293e2583180b8d8dc4b2284647f.tar.bz2
gsoc2013-evolution-0cd98f1a85724293e2583180b8d8dc4b2284647f.tar.lz
gsoc2013-evolution-0cd98f1a85724293e2583180b8d8dc4b2284647f.tar.xz
gsoc2013-evolution-0cd98f1a85724293e2583180b8d8dc4b2284647f.tar.zst
gsoc2013-evolution-0cd98f1a85724293e2583180b8d8dc4b2284647f.zip
Bug #661087 - Add ability to remove localized "Re:" prefixes in subject
Diffstat (limited to 'mail/message-list.c')
-rw-r--r--mail/message-list.c26
1 files changed, 10 insertions, 16 deletions
diff --git a/mail/message-list.c b/mail/message-list.c
index 79b6875328..b2fb46e9e1 100644
--- a/mail/message-list.c
+++ b/mail/message-list.c
@@ -499,20 +499,16 @@ get_normalised_string (MessageList *message_list,
}
if (col == COL_SUBJECT_NORM) {
+ EShell *shell = e_shell_get_default ();
+ gint skip_len;
const guchar *subject;
gboolean found_re = TRUE;
subject = (const guchar *) string;
while (found_re) {
- found_re = FALSE;
-
- if (g_ascii_strncasecmp ((gchar *) subject, "Re:", 3) == 0) {
- found_re = TRUE;
- subject += 3;
- } else if (g_ascii_strncasecmp ((gchar *) subject, "Re :", 4) == 0) {
- found_re = TRUE;
- subject += 4;
- }
+ found_re = em_utils_is_re_in_subject (shell, (const gchar *) subject, &skip_len) && skip_len > 0;
+ if (found_re)
+ subject += skip_len;
/* jump over any spaces */
while (*subject && isspace ((gint) *subject))
@@ -1553,6 +1549,8 @@ get_trimmed_subject (CamelMessageInfo *info)
}
do {
+ EShell *shell = e_shell_get_default ();
+ gint skip_len;
gboolean found_re = TRUE;
found_mlist = FALSE;
@@ -1560,13 +1558,9 @@ get_trimmed_subject (CamelMessageInfo *info)
while (found_re) {
found_re = FALSE;
- if (g_ascii_strncasecmp ((gchar *) subject, "Re:", 3) == 0) {
- found_re = TRUE;
- subject += 3;
- } else if (g_ascii_strncasecmp ((gchar *) subject, "Re :", 4) == 0) {
- found_re = TRUE;
- subject += 4;
- }
+ found_re = em_utils_is_re_in_subject (shell, (const gchar *) subject, &skip_len) && skip_len > 0;
+ if (found_re)
+ subject += skip_len;
/* jump over any spaces */
while (*subject && isspace ((gint) *subject))