diff options
author | Srinivasa Ragavan <sragavan@src.gnome.org> | 2006-08-19 02:50:11 +0800 |
---|---|---|
committer | Srinivasa Ragavan <sragavan@src.gnome.org> | 2006-08-19 02:50:11 +0800 |
commit | 13b58cb84e3fd9c4ab2e3196699bb0681e4d0912 (patch) | |
tree | 8a02ff483ce9d2d1957dd2b4d79f31f8e1ffcc14 /mail | |
parent | 0cad073b736cf31af522dee889767957885b9ef7 (diff) | |
download | gsoc2013-evolution-13b58cb84e3fd9c4ab2e3196699bb0681e4d0912.tar gsoc2013-evolution-13b58cb84e3fd9c4ab2e3196699bb0681e4d0912.tar.gz gsoc2013-evolution-13b58cb84e3fd9c4ab2e3196699bb0681e4d0912.tar.bz2 gsoc2013-evolution-13b58cb84e3fd9c4ab2e3196699bb0681e4d0912.tar.lz gsoc2013-evolution-13b58cb84e3fd9c4ab2e3196699bb0681e4d0912.tar.xz gsoc2013-evolution-13b58cb84e3fd9c4ab2e3196699bb0681e4d0912.tar.zst gsoc2013-evolution-13b58cb84e3fd9c4ab2e3196699bb0681e4d0912.zip |
Fix for bug #350884 (GMail like thread sorting)
svn path=/trunk/; revision=32587
Diffstat (limited to 'mail')
-rw-r--r-- | mail/ChangeLog | 7 | ||||
-rw-r--r-- | mail/message-list.c | 35 |
2 files changed, 32 insertions, 10 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 85261016d3..49724141a7 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,10 @@ +2006-08-19 Srinivasa Ragavan <sragavan@novell.com> + + ** Fix for bug #350884 + + * message-list.c: (subtree_latest), (ml_tree_value_at): Sort thread + based on the date of last message received. + 2006-08-17 Kjartan Maraas <kmaraas@gnome.org> * message-list.c: (create_composite_cell): Plug a leak. diff --git a/mail/message-list.c b/mail/message-list.c index fe7e9026a4..710c520e55 100644 --- a/mail/message-list.c +++ b/mail/message-list.c @@ -1133,10 +1133,10 @@ subtree_size(MessageList *ml, ETreePath node) } static time_t -subtree_earliest(MessageList *ml, ETreePath node, int sent) +subtree_latest(MessageList *ml, ETreePath node, int sent) { CamelMessageInfo *info; - time_t earliest = 0, date; + time_t latest = 0, date; ETreePath *child; while (node) { @@ -1148,19 +1148,19 @@ subtree_earliest(MessageList *ml, ETreePath node, int sent) else date = camel_message_info_date_received(info); - if (earliest == 0 || date < earliest) - earliest = date; + if (latest == 0 || date > latest) + latest = date; if ((child = e_tree_model_node_get_first_child (ml->model, node))) { - date = subtree_earliest(ml, child, sent); - if (earliest == 0 || (date != 0 && date < earliest)) - earliest = date; + date = subtree_latest(ml, child, sent); + if (latest == 0 || (date != 0 && date > latest)) + latest = date; } node = e_tree_model_node_get_next (ml->model, node); } - return earliest; + return latest; } static gchar * @@ -1288,10 +1288,25 @@ ml_tree_value_at (ETreeModel *etm, ETreePath path, int col, void *model_data) return (void *)(str ? str : ""); case COL_SUBJECT_NORM: return (void *) get_normalised_string (message_list, msg_info, col); - case COL_SENT: + case COL_SENT: { + ETreePath child; + + child = e_tree_model_node_get_first_child(etm, path); + if (child && !e_tree_node_is_expanded(message_list->tree, path)) { + return GINT_TO_POINTER (subtree_latest (message_list, child, 1)); + } + return GINT_TO_POINTER (camel_message_info_date_sent(msg_info)); - case COL_RECEIVED: + } + case COL_RECEIVED: { + ETreePath child; + + child = e_tree_model_node_get_first_child(etm, path); + if (child && !e_tree_node_is_expanded(message_list->tree, path)) { + return GINT_TO_POINTER (subtree_latest (message_list, child, 0)); + } return GINT_TO_POINTER (camel_message_info_date_received(msg_info)); + } case COL_TO: str = camel_message_info_to (msg_info); return (void *)(str ? str : ""); |