aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-individual-dialogs.c
diff options
context:
space:
mode:
authorVitaly Minko <vitaly.minko@gmail.com>2010-11-11 01:23:39 +0800
committerEmilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk>2011-01-28 18:26:03 +0800
commit5be47bde51c996bbb0be0d90f87e86ae982286a4 (patch)
tree283499ce10fd7f900df90c4fb57f3fef888f8198 /libempathy-gtk/empathy-individual-dialogs.c
parent6bad52391b6cc7a0c0d5c8e011fc9d6f2df973dd (diff)
downloadgsoc2013-empathy-5be47bde51c996bbb0be0d90f87e86ae982286a4.tar
gsoc2013-empathy-5be47bde51c996bbb0be0d90f87e86ae982286a4.tar.gz
gsoc2013-empathy-5be47bde51c996bbb0be0d90f87e86ae982286a4.tar.bz2
gsoc2013-empathy-5be47bde51c996bbb0be0d90f87e86ae982286a4.tar.lz
gsoc2013-empathy-5be47bde51c996bbb0be0d90f87e86ae982286a4.tar.xz
gsoc2013-empathy-5be47bde51c996bbb0be0d90f87e86ae982286a4.tar.zst
gsoc2013-empathy-5be47bde51c996bbb0be0d90f87e86ae982286a4.zip
Make AccountChooser filters asynchronous to let them handle newly connected accounts properly (#633481).
Diffstat (limited to 'libempathy-gtk/empathy-individual-dialogs.c')
-rw-r--r--libempathy-gtk/empathy-individual-dialogs.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/libempathy-gtk/empathy-individual-dialogs.c b/libempathy-gtk/empathy-individual-dialogs.c
index edfb3fd48..f262772c6 100644
--- a/libempathy-gtk/empathy-individual-dialogs.c
+++ b/libempathy-gtk/empathy-individual-dialogs.c
@@ -43,8 +43,10 @@ static GtkWidget *new_individual_dialog = NULL;
* New contact dialog
*/
-static gboolean
+static void
can_add_contact_to_account (TpAccount *account,
+ EmpathyAccountChooserFilterResultCallback callback,
+ gpointer callback_data,
gpointer user_data)
{
EmpathyIndividualManager *individual_manager;
@@ -53,14 +55,17 @@ can_add_contact_to_account (TpAccount *account,
connection = tp_account_get_connection (account);
if (connection == NULL)
- return FALSE;
+ {
+ callback (FALSE, callback_data);
+ return;
+ }
individual_manager = empathy_individual_manager_dup_singleton ();
result = empathy_individual_manager_get_flags_for_connection (
individual_manager, connection) & EMPATHY_INDIVIDUAL_MANAGER_CAN_ADD;
g_object_unref (individual_manager);
- return result;
+ callback (result, callback_data);
}
static void