aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPhilip Withnall <philip.withnall@collabora.co.uk>2010-08-23 18:41:48 +0800
committerPhilip Withnall <philip.withnall@collabora.co.uk>2010-08-30 17:33:14 +0800
commite1d5083710cbafe299f37ce280e48005eaf85dca (patch)
tree9c09e6a209ccfbe2ee3ea74e3390a8b8ec71ed46
parent09116852afa9a1379d1dac957f787918432c1767 (diff)
downloadgsoc2013-empathy-e1d5083710cbafe299f37ce280e48005eaf85dca.tar
gsoc2013-empathy-e1d5083710cbafe299f37ce280e48005eaf85dca.tar.gz
gsoc2013-empathy-e1d5083710cbafe299f37ce280e48005eaf85dca.tar.bz2
gsoc2013-empathy-e1d5083710cbafe299f37ce280e48005eaf85dca.tar.lz
gsoc2013-empathy-e1d5083710cbafe299f37ce280e48005eaf85dca.tar.xz
gsoc2013-empathy-e1d5083710cbafe299f37ce280e48005eaf85dca.tar.zst
gsoc2013-empathy-e1d5083710cbafe299f37ce280e48005eaf85dca.zip
Port EmpathyPersonaStore to use Individual.personas_changed
This makes the notification of changed Personas a lot more efficient in the store. Closes: bgo#627706
-rw-r--r--libempathy-gtk/empathy-persona-store.c44
1 files changed, 11 insertions, 33 deletions
diff --git a/libempathy-gtk/empathy-persona-store.c b/libempathy-gtk/empathy-persona-store.c
index 7997150bc..31cd34caa 100644
--- a/libempathy-gtk/empathy-persona-store.c
+++ b/libempathy-gtk/empathy-persona-store.c
@@ -524,42 +524,20 @@ update_persona (EmpathyPersonaStore *self,
}
static void
-individual_notify_personas_cb (GObject *object,
- GParamSpec *pspec,
+individual_personas_changed_cb (GObject *object,
+ GList *added,
+ GList *removed,
EmpathyPersonaStore *self)
{
- EmpathyPersonaStorePriv *priv = GET_PRIV (self);
- GList *old_personas, *new_personas, *removed_personas, *l;
-
- /* Remove old personas which are no longer in the individual.
- * Build a list of such personas to remove from our hash table.
- * This is slow. */
- old_personas = g_hash_table_get_keys (priv->personas);
- new_personas = folks_individual_get_personas (FOLKS_INDIVIDUAL (object));
- removed_personas = NULL;
+ GList *l;
- for (l = old_personas; l != NULL; l = l->next)
- {
- GList *i = g_list_find (new_personas, l->data);
- if (i == NULL)
- removed_personas = g_list_prepend (removed_personas, l->data);
- }
- g_list_free (old_personas);
-
- /* Remove the removed personas. We can't do this from inside the above loop,
- * as old_personas is only valid until the hash table is modified. */
- for (l = removed_personas; l != NULL; l = l->next)
+ /* Remove the old personas. */
+ for (l = removed; l != NULL; l = l->next)
remove_persona_and_disconnect (self, FOLKS_PERSONA (l->data));
- g_list_free (removed_personas);
/* Add each of the new personas to the tree model */
- for (l = new_personas; l != NULL; l = l->next)
- {
- FolksPersona *persona = FOLKS_PERSONA (l->data);
-
- if (g_hash_table_lookup (priv->personas, persona) == NULL)
- add_persona_and_connect (self, persona);
- }
+ for (l = added; l != NULL; l = l->next)
+ add_persona_and_connect (self, FOLKS_PERSONA (l->data));
}
static gint
@@ -1009,7 +987,7 @@ empathy_persona_store_set_individual (EmpathyPersonaStore *self,
GList *personas, *l;
g_signal_handlers_disconnect_by_func (priv->individual,
- (GCallback) individual_notify_personas_cb, self);
+ (GCallback) individual_personas_changed_cb, self);
/* Disconnect from and remove all personas belonging to this individual */
personas = folks_individual_get_personas (priv->individual);
@@ -1028,8 +1006,8 @@ empathy_persona_store_set_individual (EmpathyPersonaStore *self,
g_object_ref (individual);
- g_signal_connect (individual, "notify::personas",
- (GCallback) individual_notify_personas_cb, self);
+ g_signal_connect (individual, "personas-changed",
+ (GCallback) individual_personas_changed_cb, self);
/* Add pre-existing Personas */
personas = folks_individual_get_personas (individual);