From 902b24c56151985da6eadedc748803d686a07a62 Mon Sep 17 00:00:00 2001 From: Guillaume Desmottes Date: Tue, 19 Jan 2010 14:54:46 +0000 Subject: [PATCH] Don't pass managers to create_salut_account_if_needed It can dup it itself. --- src/empathy-auto-salut-account-helper.c | 24 +++++++++++++++++++++--- src/empathy-auto-salut-account-helper.h | 2 +- src/empathy.c | 3 +-- 3 files changed, 23 insertions(+), 6 deletions(-) diff --git a/src/empathy-auto-salut-account-helper.c b/src/empathy-auto-salut-account-helper.c index a6bbf88d..30842dd4 100644 --- a/src/empathy-auto-salut-account-helper.c +++ b/src/empathy-auto-salut-account-helper.c @@ -201,15 +201,33 @@ create_salut_account_am_ready_cb (GObject *source_object, g_object_unref (managers); } -void -create_salut_account_if_needed (EmpathyConnectionManagers *managers) +static void +create_salut_account_cms_ready_cb (EmpathyConnectionManagers *managers) { TpAccountManager *manager; manager = tp_account_manager_dup (); tp_account_manager_prepare_async (manager, NULL, - create_salut_account_am_ready_cb, g_object_ref (managers)); + create_salut_account_am_ready_cb, managers); g_object_unref (manager); } + +void +create_salut_account_if_needed (void) +{ + EmpathyConnectionManagers *managers; + + managers = empathy_connection_managers_dup_singleton (); + + if (empathy_connection_managers_is_ready (managers)) + { + create_salut_account_cms_ready_cb (managers); + } + else + { + g_signal_connect (managers, "notify::ready", + G_CALLBACK (create_salut_account_cms_ready_cb), NULL); + } +} diff --git a/src/empathy-auto-salut-account-helper.h b/src/empathy-auto-salut-account-helper.h index 6e934500..8cec7b8f 100644 --- a/src/empathy-auto-salut-account-helper.h +++ b/src/empathy-auto-salut-account-helper.h @@ -28,7 +28,7 @@ #include -void create_salut_account_if_needed (EmpathyConnectionManagers *managers); +void create_salut_account_if_needed (void); gboolean should_create_salut_account (TpAccountManager *manager); diff --git a/src/empathy.c b/src/empathy.c index 60ff6c0c..1d25e924 100644 --- a/src/empathy.c +++ b/src/empathy.c @@ -208,9 +208,8 @@ check_connection_managers_ready (EmpathyConnectionManagers *managers) if (!empathy_import_mc4_accounts (managers) && !start_hidden) maybe_show_account_assistant (); - create_salut_account_if_needed (managers); + create_salut_account_if_needed (); g_object_unref (managers); - managers = NULL; return TRUE; } return FALSE; -- 2.39.2