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-contact-selector-dialog.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-contact-selector-dialog.c')
-rw-r--r-- | libempathy-gtk/empathy-contact-selector-dialog.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/libempathy-gtk/empathy-contact-selector-dialog.c b/libempathy-gtk/empathy-contact-selector-dialog.c index 62b902746..3ed7f30e5 100644 --- a/libempathy-gtk/empathy-contact-selector-dialog.c +++ b/libempathy-gtk/empathy-contact-selector-dialog.c @@ -243,8 +243,10 @@ entry_activate_cb (GtkEntry *entry, gtk_dialog_response (GTK_DIALOG (self), GTK_RESPONSE_ACCEPT); } -static gboolean +static void account_chooser_filter (TpAccount *account, + EmpathyAccountChooserFilterResultCallback callback, + gpointer callback_data, gpointer user_data) { EmpathyContactSelectorDialog *self = user_data; @@ -252,9 +254,13 @@ account_chooser_filter (TpAccount *account, EMPATHY_CONTACT_SELECTOR_DIALOG_GET_CLASS (self); if (class->account_filter == NULL) - return empathy_account_chooser_filter_is_connected (account, user_data); + { + empathy_account_chooser_filter_is_connected ( + account,callback, callback_data, user_data); + return; + } - return class->account_filter (self, account); + class->account_filter (self, callback, callback_data, account); } static gboolean |