diff options
author | Vitaly Minko <vitaly.minko@gmail.com> | 2010-11-11 01:23:39 +0800 |
---|---|---|
committer | Vitaly Minko <vitaly.minko@gmail.com> | 2010-11-11 01:23:39 +0800 |
commit | 18d649cbfd8eda7678957a3d2a76b9bb8681a981 (patch) | |
tree | c3798b5507f8bf2102d3bd6c94922a21e40c17a8 /libempathy-gtk/empathy-individual-dialogs.c | |
parent | c6cd722328a112e8f4b015ca57ffe8dc72f50cd8 (diff) | |
download | gsoc2013-empathy-18d649cbfd8eda7678957a3d2a76b9bb8681a981.tar gsoc2013-empathy-18d649cbfd8eda7678957a3d2a76b9bb8681a981.tar.gz gsoc2013-empathy-18d649cbfd8eda7678957a3d2a76b9bb8681a981.tar.bz2 gsoc2013-empathy-18d649cbfd8eda7678957a3d2a76b9bb8681a981.tar.lz gsoc2013-empathy-18d649cbfd8eda7678957a3d2a76b9bb8681a981.tar.xz gsoc2013-empathy-18d649cbfd8eda7678957a3d2a76b9bb8681a981.tar.zst gsoc2013-empathy-18d649cbfd8eda7678957a3d2a76b9bb8681a981.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.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/libempathy-gtk/empathy-individual-dialogs.c b/libempathy-gtk/empathy-individual-dialogs.c index 85ed7d1d4..2c9801059 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,13 +55,16 @@ 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_connection_can_add_personas (connection); g_object_unref (individual_manager); - return result; + callback (result, callback_data); } static void |