]> git.0d.be Git - empathy.git/blobdiff - libempathy-gtk/empathy-roster-model-manager.c
empathy-roster-model-manager: deal with members-changed signals empathy-roster-view...
[empathy.git] / libempathy-gtk / empathy-roster-model-manager.c
index b76a7a384f6667f1c17973102ea1932f221e8140..ed414aa856645871c9803d015bbbb181721558d3 100644 (file)
@@ -54,6 +54,29 @@ struct _EmpathyRosterModelManagerPriv
   EmpathyIndividualManager *manager;
 };
 
+static void
+members_changed_cb (EmpathyIndividualManager *manager,
+    const gchar *message,
+    GList *added,
+    GList *removed,
+    TpChannelGroupChangeReason reason,
+    EmpathyRosterModelManager *self)
+{
+  GList *l;
+
+  for (l = added; l != NULL; l = g_list_next (l))
+    {
+      empathy_roster_model_fire_individual_added (EMPATHY_ROSTER_MODEL (self),
+          l->data);
+    }
+
+  for (l = removed; l != NULL; l = g_list_next (l))
+    {
+      empathy_roster_model_fire_individual_removed (EMPATHY_ROSTER_MODEL (self),
+          l->data);
+    }
+}
+
 static void
 empathy_roster_model_manager_get_property (GObject *object,
     guint property_id,
@@ -104,6 +127,9 @@ empathy_roster_model_manager_constructed (GObject *object)
     chain_up (object);
 
   g_assert (EMPATHY_IS_INDIVIDUAL_MANAGER (self->priv->manager));
+
+  tp_g_signal_connect_object (self->priv->manager, "members-changed",
+      G_CALLBACK (members_changed_cb), self, 0);
 }
 
 static void