From 4fd6e00afa491bd490f5c44f5abe6858b860e5ff Mon Sep 17 00:00:00 2001 From: Sankarasivasubramanian Pasupathilingam Date: Tue, 30 Sep 2008 07:59:12 +0000 Subject: Added new column "Subject - Trimmed". Patch by hpj. svn path=/trunk/; revision=36498 --- mail/ChangeLog | 12 ++++++++++ mail/message-list.c | 61 ++++++++++++++++++++++++++++++++++++++++++++++++ mail/message-list.etspec | 8 ++++--- mail/message-list.h | 3 +++ 4 files changed, 81 insertions(+), 3 deletions(-) diff --git a/mail/ChangeLog b/mail/ChangeLog index 7284c865c8..0d818ce883 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,15 @@ +2008-09-30 Sankar P + + ** Committed on behalf of Hans Petter Jansson + + ** Fix for bug #554107 + + * message-list.c (get_trimmed_subject), (ml_tree_value_at): + * message-list.etspec: + * message-list.h: + Add "Subject - Trimmed" column which enables to read + mailing list mails in a better way. + 2008-09-29 Gabor Kelemen * mail-config.glade: Mark some forgotten strings for translation. Fixes bug #553067 diff --git a/mail/message-list.c b/mail/message-list.c index ab3b1c0922..4819528945 100644 --- a/mail/message-list.c +++ b/mail/message-list.c @@ -1269,6 +1269,61 @@ get_all_labels (CamelMessageInfo *msg_info, char **label_str, gboolean get_tags) return count; } +static const char * +get_trimmed_subject (CamelMessageInfo *info) +{ + const char *subject; + const char *mlist; + int mlist_len = 0; + gboolean found_mlist; + + subject = camel_message_info_subject (info); + if (!subject || !*subject) + return subject; + + mlist = camel_message_info_mlist (info); + + if (mlist && *mlist) { + const char *mlist_end; + + mlist_end = strchr (mlist, '@'); + if (mlist_end) + mlist_len = mlist_end - mlist; + else + mlist_len = strlen (mlist); + } + + do { + found_mlist = FALSE; + + while (!g_ascii_strncasecmp ((char *) subject, "Re:", 3)) { + subject += 3; + + /* jump over any spaces */ + while (*subject && isspace ((int) *subject)) + subject++; + } + + if (mlist_len && + *subject == '[' && + !g_ascii_strncasecmp ((char *) subject + 1, mlist, mlist_len) && + subject [1 + mlist_len] == ']') { + subject += 1 + mlist_len + 1; /* jump over "[mailing-list]" */ + found_mlist = TRUE; + + /* jump over any spaces */ + while (*subject && isspace ((int) *subject)) + subject++; + } + } while (found_mlist); + + /* jump over any spaces */ + while (*subject && isspace ((int) *subject)) + subject++; + + return subject; +} + static void * ml_tree_value_at (ETreeModel *etm, ETreePath path, int col, void *model_data) { @@ -1353,6 +1408,12 @@ ml_tree_value_at (ETreeModel *etm, ETreePath path, int col, void *model_data) case COL_SUBJECT: str = camel_message_info_subject (msg_info); return (void *)(str ? str : ""); + case COL_SUBJECT_TRIMMED: + /* FIXME: "Trimmed subject" is not normalized yet. + I do not find a way in evo gui to configure the normalized columns like from_norm + Hence this FIXME should remain until we have a COL_SUBJECT_TRIMMED_NORM. */ + str = get_trimmed_subject (msg_info); + return (void *)(str ? str : ""); case COL_SUBJECT_NORM: return (void *) get_normalised_string (message_list, msg_info, col); case COL_SENT: { diff --git a/mail/message-list.etspec b/mail/message-list.etspec index 84fc12fafb..c8d438b90c 100644 --- a/mail/message-list.etspec +++ b/mail/message-list.etspec @@ -7,15 +7,15 @@ - + - + - + @@ -33,6 +33,8 @@ + + diff --git a/mail/message-list.h b/mail/message-list.h index b144708208..cc58e1e798 100644 --- a/mail/message-list.h +++ b/mail/message-list.h @@ -60,6 +60,9 @@ enum { COL_MIXED_RECIPIENTS, COL_LABELS, + /* subject with junk removed */ + COL_SUBJECT_TRIMMED, + /* normalised strings */ COL_FROM_NORM, COL_SUBJECT_NORM, -- cgit v1.2.3