aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEmilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk>2011-04-27 06:52:20 +0800
committerEmilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk>2011-04-27 17:33:01 +0800
commitd53ade97340b30b47a93e6936a4967863b86d666 (patch)
tree166a527fd5f34d910b1a1371c93806f611677c14
parenta6469216a75489e0919270045e7e970732f67007 (diff)
downloadgsoc2013-empathy-d53ade97340b30b47a93e6936a4967863b86d666.tar
gsoc2013-empathy-d53ade97340b30b47a93e6936a4967863b86d666.tar.gz
gsoc2013-empathy-d53ade97340b30b47a93e6936a4967863b86d666.tar.bz2
gsoc2013-empathy-d53ade97340b30b47a93e6936a4967863b86d666.tar.lz
gsoc2013-empathy-d53ade97340b30b47a93e6936a4967863b86d666.tar.xz
gsoc2013-empathy-d53ade97340b30b47a93e6936a4967863b86d666.tar.zst
gsoc2013-empathy-d53ade97340b30b47a93e6936a4967863b86d666.zip
LogWindow: group MUC events properly
-rw-r--r--libempathy-gtk/empathy-log-window.c31
1 files changed, 30 insertions, 1 deletions
diff --git a/libempathy-gtk/empathy-log-window.c b/libempathy-gtk/empathy-log-window.c
index f4935ffd8..d77858c7e 100644
--- a/libempathy-gtk/empathy-log-window.c
+++ b/libempathy-gtk/empathy-log-window.c
@@ -554,6 +554,34 @@ entity_equal (TplEntity *a,
tpl_entity_get_identifier (b));
}
+static gboolean
+is_same_confroom (TplEvent *e1,
+ TplEvent *e2)
+{
+ TplEntity *sender1 = tpl_event_get_sender (e1);
+ TplEntity *receiver1 = tpl_event_get_receiver (e1);
+ TplEntity *sender2 = tpl_event_get_sender (e2);
+ TplEntity *receiver2 = tpl_event_get_receiver (e2);
+ TplEntity *room1, *room2;
+
+ if (tpl_entity_get_entity_type (sender1) == TPL_ENTITY_ROOM)
+ room1 = sender1;
+ else if (tpl_entity_get_entity_type (receiver1) == TPL_ENTITY_ROOM)
+ room1 = receiver1;
+ else
+ return FALSE;
+
+ if (tpl_entity_get_entity_type (sender2) == TPL_ENTITY_ROOM)
+ room2 = sender2;
+ else if (tpl_entity_get_entity_type (receiver2) == TPL_ENTITY_ROOM)
+ room2 = receiver2;
+ else
+ return FALSE;
+
+ return g_str_equal (tpl_entity_get_identifier (room1),
+ tpl_entity_get_identifier (room1));
+}
+
static TplEntity *
event_get_target (TplEvent *event)
{
@@ -595,7 +623,8 @@ model_is_parent (GtkTreeModel *model,
if (is_toplevel &&
G_OBJECT_TYPE (event) == G_OBJECT_TYPE (stored_event) &&
account_equal (account, tpl_event_get_account (event)) &&
- entity_equal (target, event_get_target (event)))
+ (entity_equal (target, event_get_target (event)) ||
+ is_same_confroom (event, stored_event)))
{
gtk_tree_model_iter_nth_child (model, &child, iter,
gtk_tree_model_iter_n_children (model, iter) - 1);