[empathy: 5/12] Connected the aggregator to individuals-changed signal
- From: Guillaume Desmottes <gdesmott src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [empathy: 5/12] Connected the aggregator to individuals-changed signal
- Date: Fri, 10 Aug 2012 15:24:27 +0000 (UTC)
commit c2d9e976cd89f923c01eaf3801ff57d85889a57f
Author: Laurent Contzen <lcontzen gmail com>
Date: Wed Aug 8 12:29:11 2012 +0200
Connected the aggregator to individuals-changed signal
libempathy-gtk/empathy-roster-model-aggregator.c | 39 ++++++++++++++++++++++
1 files changed, 39 insertions(+), 0 deletions(-)
---
diff --git a/libempathy-gtk/empathy-roster-model-aggregator.c b/libempathy-gtk/empathy-roster-model-aggregator.c
index 8aa20f9..f40b025 100644
--- a/libempathy-gtk/empathy-roster-model-aggregator.c
+++ b/libempathy-gtk/empathy-roster-model-aggregator.c
@@ -83,6 +83,40 @@ struct _EmpathyRosterModelAggregatorPriv
};
static void
+aggregator_individuals_changed_cb (FolksIndividualAggregator *aggregator,
+ GeeSet *added,
+ GeeSet *removed,
+ gchar *message,
+ FolksPersona *actor,
+ FolksGroupDetailsChangeReason reason,
+ EmpathyRosterModelAggregator *self)
+{
+ if (gee_collection_get_size (GEE_COLLECTION (added)) > 0)
+ {
+ GeeIterator *iter = gee_iterable_iterator (GEE_ITERABLE (added));
+
+ while (iter != NULL && gee_iterator_next (iter))
+ {
+ empathy_roster_model_fire_individual_added (
+ EMPATHY_ROSTER_MODEL (self), gee_iterator_get (iter));
+ }
+ g_clear_object (&iter);
+ }
+
+ if (gee_collection_get_size (GEE_COLLECTION (removed)) > 0)
+ {
+ GeeIterator *iter = gee_iterable_iterator (GEE_ITERABLE (removed));
+
+ while (iter != NULL && gee_iterator_next (iter))
+ {
+ empathy_roster_model_fire_individual_removed (
+ EMPATHY_ROSTER_MODEL (self), gee_iterator_get (iter));
+ }
+ g_clear_object (&iter);
+ }
+}
+
+static void
empathy_roster_model_aggregator_get_property (GObject *object,
guint property_id,
GValue *value,
@@ -134,6 +168,11 @@ empathy_roster_model_aggregator_constructed (GObject *object)
if (self->priv->aggregator == NULL)
self->priv->aggregator = folks_individual_aggregator_new ();
+ tp_g_signal_connect_object (self->priv->aggregator, "individuals-changed",
+ G_CALLBACK (aggregator_individuals_changed_cb), self, 0);
+
+ folks_individual_aggregator_prepare (self->priv->aggregator, NULL, NULL);
+
g_assert (FOLKS_IS_INDIVIDUAL_AGGREGATOR (self->priv->aggregator));
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]