aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLaurent Contzen <lcontzen@gmail.com>2012-08-09 16:54:06 +0800
committerLaurent Contzen <lcontzen@gmail.com>2012-08-10 21:13:43 +0800
commit8ace92204ecc0e898ad7286deeb702238b47a8be (patch)
tree01afe60b31c5e94980d9261a6f7958c1211be735
parentecdeb95cfa385ab0f8b7595a676dc22aecc7a49e (diff)
downloadgsoc2013-empathy-8ace92204ecc0e898ad7286deeb702238b47a8be.tar
gsoc2013-empathy-8ace92204ecc0e898ad7286deeb702238b47a8be.tar.gz
gsoc2013-empathy-8ace92204ecc0e898ad7286deeb702238b47a8be.tar.bz2
gsoc2013-empathy-8ace92204ecc0e898ad7286deeb702238b47a8be.tar.lz
gsoc2013-empathy-8ace92204ecc0e898ad7286deeb702238b47a8be.tar.xz
gsoc2013-empathy-8ace92204ecc0e898ad7286deeb702238b47a8be.tar.zst
gsoc2013-empathy-8ace92204ecc0e898ad7286deeb702238b47a8be.zip
Connected notify on individuals to refilter if needed
-rw-r--r--libempathy-gtk/empathy-roster-model-aggregator.c67
1 files changed, 54 insertions, 13 deletions
diff --git a/libempathy-gtk/empathy-roster-model-aggregator.c b/libempathy-gtk/empathy-roster-model-aggregator.c
index 5ef310b66..b0b68449a 100644
--- a/libempathy-gtk/empathy-roster-model-aggregator.c
+++ b/libempathy-gtk/empathy-roster-model-aggregator.c
@@ -80,7 +80,7 @@ static guint signals[LAST_SIGNAL];
struct _EmpathyRosterModelAggregatorPriv
{
FolksIndividualAggregator *aggregator;
- GHashTable *individuals; /* Individual -> Individual */
+ GHashTable *filtered_individuals; /* Individual -> Individual */
EmpathyRosterModelAggregatorFilterFunc filter_func;
gpointer filter_data;
@@ -97,37 +97,77 @@ individual_group_changed_cb (FolksIndividual *individual,
}
static void
-add_individual (EmpathyRosterModelAggregator *self,
+add_to_filtered_individuals (EmpathyRosterModelAggregator *self,
FolksIndividual *individual)
{
- if (self->priv->filter_func != NULL && !self->priv->filter_func (
- EMPATHY_ROSTER_MODEL (self), individual, self))
- return;
-
- g_hash_table_add (self->priv->individuals,
+ g_hash_table_add (self->priv->filtered_individuals,
g_object_ref (individual));
- g_signal_connect (individual, "group-changed",
- G_CALLBACK (individual_group_changed_cb), self);
+ tp_g_signal_connect_object (individual, "group-changed",
+ G_CALLBACK (individual_group_changed_cb), self, 0);
empathy_roster_model_fire_individual_added (EMPATHY_ROSTER_MODEL (self),
individual);
}
static void
-remove_individual (EmpathyRosterModelAggregator *self,
+remove_from_filtered_individuals (EmpathyRosterModelAggregator *self,
FolksIndividual *individual)
{
g_signal_handlers_disconnect_by_func (individual,
individual_group_changed_cb, self);
- g_hash_table_remove (self->priv->individuals, individual);
+ g_hash_table_remove (self->priv->filtered_individuals, individual);
empathy_roster_model_fire_individual_removed (EMPATHY_ROSTER_MODEL (self),
individual);
}
static void
+individual_notify_cb (FolksIndividual *individual,
+ GParamSpec *param,
+ EmpathyRosterModelAggregator *self)
+{
+ if (!self->priv->filter_func (EMPATHY_ROSTER_MODEL (self), individual, self)
+ && g_hash_table_contains (self->priv->filtered_individuals, individual))
+ remove_from_filtered_individuals (self, individual);
+
+ if (self->priv->filter_func (EMPATHY_ROSTER_MODEL (self), individual, self)
+ && !g_hash_table_contains (self->priv->filtered_individuals, individual))
+ add_to_filtered_individuals (self, individual);
+}
+
+static void
+add_individual (EmpathyRosterModelAggregator *self,
+ FolksIndividual *individual)
+{
+ if (self->priv->filter_func != NULL)
+ {
+ tp_g_signal_connect_object (individual, "notify",
+ G_CALLBACK (individual_notify_cb), self, 0);
+
+ if (!self->priv->filter_func (EMPATHY_ROSTER_MODEL (self), individual,
+ self))
+ return;
+ }
+
+ add_to_filtered_individuals (self, individual);
+}
+
+static void
+remove_individual (EmpathyRosterModelAggregator *self,
+ FolksIndividual *individual)
+{
+ if (self->priv->filter_func != NULL)
+ g_signal_handlers_disconnect_by_func (individual,
+ individual_notify_cb, self);
+
+ if (g_hash_table_contains (self->priv->filtered_individuals,
+ individual))
+ remove_from_filtered_individuals (self, individual);
+}
+
+static void
populate_individuals (EmpathyRosterModelAggregator *self)
{
GeeMap *individuals;
@@ -259,6 +299,7 @@ empathy_roster_model_aggregator_dispose (GObject *object)
((GObjectClass *) empathy_roster_model_aggregator_parent_class)->dispose;
g_clear_object (&self->priv->aggregator);
+ g_clear_pointer (&self->priv->filtered_individuals, g_hash_table_unref);
if (chain_up != NULL)
chain_up (object);
@@ -313,7 +354,7 @@ empathy_roster_model_aggregator_init (EmpathyRosterModelAggregator *self)
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
EMPATHY_TYPE_ROSTER_MODEL_AGGREGATOR, EmpathyRosterModelAggregatorPriv);
- self->priv->individuals = g_hash_table_new_full (NULL, NULL, NULL,
+ self->priv->filtered_individuals = g_hash_table_new_full (NULL, NULL, NULL,
g_object_unref);
}
@@ -348,7 +389,7 @@ empathy_roster_model_aggregator_get_individuals (EmpathyRosterModel *model)
{
EmpathyRosterModelAggregator *self = EMPATHY_ROSTER_MODEL_AGGREGATOR (model);
- return g_hash_table_get_values (self->priv->individuals);
+ return g_hash_table_get_values (self->priv->filtered_individuals);
}
static GList *