]> git.0d.be Git - empathy.git/commitdiff
roster-model now catches notify::top-individuals
authorLaurent Contzen <lcontzen@gmail.com>
Sat, 4 Aug 2012 11:19:44 +0000 (13:19 +0200)
committerLaurent Contzen <lcontzen@gmail.com>
Mon, 6 Aug 2012 09:02:18 +0000 (11:02 +0200)
empathy-roster-model: catches notify::top-individuals and emits top-individuals-changed
empathy-roster-model-manager: implemented this
empathy-roster-view: now catches top-individuals-changed from the model

libempathy-gtk/empathy-roster-model-manager.c
libempathy-gtk/empathy-roster-model.c
libempathy-gtk/empathy-roster-model.h
libempathy-gtk/empathy-roster-view.c

index be41aceca1453a2f51075fa40a944b3debbf8ece..b9e993aead88c6d1e3db1e70da08bfecd6c9c87d 100644 (file)
@@ -115,6 +115,15 @@ groups_changed_cb (EmpathyIndividualManager *manager,
       individual, group, is_member);
 }
 
+static void
+top_individuals_changed_cb (EmpathyIndividualManager *manager,
+    GParamSpec *spec,
+    EmpathyRosterModelManager *self)
+{
+  empathy_roster_model_fire_top_individuals_changed (
+      EMPATHY_ROSTER_MODEL (self));
+}
+
 static void
 empathy_roster_model_manager_get_property (GObject *object,
     guint property_id,
@@ -170,6 +179,8 @@ empathy_roster_model_manager_constructed (GObject *object)
       G_CALLBACK (members_changed_cb), self, 0);
   tp_g_signal_connect_object (self->priv->manager, "groups-changed",
       G_CALLBACK (groups_changed_cb), self, 0);
+  tp_g_signal_connect_object (self->priv->manager, "notify::top-individuals",
+      G_CALLBACK (top_individuals_changed_cb), self, 0);
 }
 
 static void
index 37ca594fe69a03485141fdab6269627e41a3678c..198c644c5736ca81eaaf4a2c12bbda264b07cc22 100644 (file)
@@ -28,6 +28,7 @@ enum
   SIG_INDIVIDUAL_ADDED,
   SIG_INDIVIDUAL_REMOVED,
   SIG_GROUPS_CHANGED,
+  SIG_TOP_INDIVIDUALS_CHANGED,
   LAST_SIGNAL
 };
 
@@ -61,6 +62,13 @@ empathy_roster_model_default_init (EmpathyRosterModelInterface *iface)
         FOLKS_TYPE_INDIVIDUAL,
         G_TYPE_STRING,
         G_TYPE_BOOLEAN);
+
+  signals[SIG_TOP_INDIVIDUALS_CHANGED] =
+    g_signal_new ("top-individuals-changed",
+        EMPATHY_TYPE_ROSTER_MODEL,
+        G_SIGNAL_RUN_LAST,
+        0, NULL, NULL, NULL,
+        G_TYPE_NONE, 0);
 }
 
 /***** Restricted *****/
@@ -88,6 +96,12 @@ empathy_roster_model_fire_groups_changed (EmpathyRosterModel *self,
   g_signal_emit (self, signals[SIG_GROUPS_CHANGED], 0, individual, group, is_member);
 }
 
+void
+empathy_roster_model_fire_top_individuals_changed (EmpathyRosterModel *self)
+{
+  g_signal_emit (self, signals[SIG_TOP_INDIVIDUALS_CHANGED], 0);
+}
+
 /***** Public *****/
 
 /**
index 860efd77f6f78abe09930e5e4196636874076122..507f49d187e0cd208ef60a1e10eb18bd87dbd4e9 100644 (file)
@@ -71,6 +71,9 @@ void empathy_roster_model_fire_groups_changed (EmpathyRosterModel *self,
     const gchar *group,
     gboolean is_member);
 
+void empathy_roster_model_fire_top_individuals_changed (
+    EmpathyRosterModel *self);
+
 /* Public API */
 GList * empathy_roster_model_get_individuals (EmpathyRosterModel *self);
 
index 0b50b0d39601d586045a163c1aafe642aade1955..c157a12d018929992534421757f2927d6f64ae0d 100644 (file)
@@ -1028,8 +1028,7 @@ groups_changed_cb (EmpathyRosterModel *model,
 }
 
 static void
-top_individuals_changed_cb (EmpathyIndividualManager *manager,
-    GParamSpec *spec,
+top_individuals_changed_cb (EmpathyRosterModel *model,
     EmpathyRosterView *self)
 {
   update_top_contacts (self);
@@ -1088,7 +1087,7 @@ empathy_roster_view_constructed (GObject *object)
       G_CALLBACK (individual_removed_cb), self, 0);
   tp_g_signal_connect_object (self->priv->model, "groups-changed",
       G_CALLBACK (groups_changed_cb), self, 0);
-  tp_g_signal_connect_object (self->priv->manager, "notify::top-individuals",
+  tp_g_signal_connect_object (self->priv->model, "top-individuals-changed",
       G_CALLBACK (top_individuals_changed_cb), self, 0);
   tp_g_signal_connect_object (self->priv->manager, "notify::favourites-changed",
       G_CALLBACK (favourites_changed_cb), self, 0);