aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy
diff options
context:
space:
mode:
Diffstat (limited to 'libempathy')
-rw-r--r--libempathy/empathy-contact-manager.c37
1 files changed, 18 insertions, 19 deletions
diff --git a/libempathy/empathy-contact-manager.c b/libempathy/empathy-contact-manager.c
index d60e47b18..f39248908 100644
--- a/libempathy/empathy-contact-manager.c
+++ b/libempathy/empathy-contact-manager.c
@@ -35,8 +35,7 @@
#define GET_PRIV(obj) EMPATHY_GET_PRIV (obj, EmpathyContactManager)
typedef struct {
GHashTable *lists;
- MissionControl *mc;
- gpointer token;
+ EmpathyAccountManager *account_manager;
} EmpathyContactManagerPriv;
static void contact_manager_iface_init (EmpathyContactListIface *iface);
@@ -159,23 +158,19 @@ contact_manager_add_account (EmpathyContactManager *manager,
}
static void
-contact_manager_status_changed_cb (MissionControl *mc,
- TpConnectionStatus status,
- McPresence presence,
- TpConnectionStatusReason reason,
- const gchar *unique_name,
- EmpathyContactManager *manager)
+contact_manager_connection_changed_cb (EmpathyAccountManager *account_manager,
+ McAccount *account,
+ TpConnectionStatusReason reason,
+ TpConnectionStatus current,
+ TpConnectionStatus previous,
+ EmpathyContactManager *manager)
{
- McAccount *account;
-
- if (status != TP_CONNECTION_STATUS_CONNECTED) {
+ if (current != TP_CONNECTION_STATUS_CONNECTED) {
/* We only care about newly connected accounts */
return;
}
- account = mc_account_lookup (unique_name);
contact_manager_add_account (manager, account);
- g_object_unref (account);
}
static void
@@ -183,12 +178,11 @@ contact_manager_finalize (GObject *object)
{
EmpathyContactManagerPriv *priv = GET_PRIV (object);
- empathy_disconnect_account_status_changed (priv->token);
g_hash_table_foreach (priv->lists,
contact_manager_disconnect_foreach,
object);
g_hash_table_destroy (priv->lists);
- g_object_unref (priv->mc);
+ g_object_unref (priv->account_manager);
}
static void
@@ -205,6 +199,7 @@ static void
empathy_contact_manager_init (EmpathyContactManager *manager)
{
GSList *accounts, *l;
+ MissionControl *mc;
EmpathyContactManagerPriv *priv = G_TYPE_INSTANCE_GET_PRIVATE (manager,
EMPATHY_TYPE_CONTACT_MANAGER, EmpathyContactManagerPriv);
@@ -213,11 +208,13 @@ empathy_contact_manager_init (EmpathyContactManager *manager)
empathy_account_equal,
(GDestroyNotify) g_object_unref,
(GDestroyNotify) g_object_unref);
+ priv->account_manager = empathy_account_manager_new ();
+
+ g_signal_connect (priv->account_manager,
+ "account-connection-changed",
+ G_CALLBACK (contact_manager_connection_changed_cb), manager);
- priv->mc = empathy_mission_control_new ();
- priv->token = empathy_connect_to_account_status_changed (priv->mc,
- G_CALLBACK (contact_manager_status_changed_cb),
- manager, NULL);
+ mc = empathy_mission_control_new ();
/* Get ContactList for existing connections */
accounts = mission_control_get_online_connections (priv->mc, NULL);
@@ -225,7 +222,9 @@ empathy_contact_manager_init (EmpathyContactManager *manager)
contact_manager_add_account (manager, l->data);
g_object_unref (l->data);
}
+
g_slist_free (accounts);
+ g_object_unref (mc);
}
EmpathyContactManager *