diff options
-rw-r--r-- | libempathy-gtk/empathy-contact-chooser.c | 23 | ||||
-rw-r--r-- | libempathy/empathy-utils.c | 32 | ||||
-rw-r--r-- | libempathy/empathy-utils.h | 3 |
3 files changed, 38 insertions, 20 deletions
diff --git a/libempathy-gtk/empathy-contact-chooser.c b/libempathy-gtk/empathy-contact-chooser.c index 6d93e6813..cba419bea 100644 --- a/libempathy-gtk/empathy-contact-chooser.c +++ b/libempathy-gtk/empathy-contact-chooser.c @@ -14,6 +14,8 @@ #include "empathy-contact-chooser.h" +#include <libempathy/empathy-utils.h> + #include <libempathy-gtk/empathy-individual-store-manager.h> #include <libempathy-gtk/empathy-individual-view.h> #include <libempathy-gtk/empathy-ui-utils.h> @@ -209,11 +211,7 @@ get_contacts_cb (TpConnection *connection, EmpathyContactChooser *self = (EmpathyContactChooser *) weak_object; AddTemporaryIndividualCtx *ctx = user_data; - TpAccount *account; - TpfPersonaStore *store; FolksIndividual *individual; - TpfPersona *persona; - GeeSet *personas; if (self->priv->add_temp_ctx != ctx) /* another request has been started */ @@ -222,18 +220,7 @@ get_contacts_cb (TpConnection *connection, if (n_contacts != 1) return; - account = tp_connection_get_account (connection); - - store = tpf_persona_store_new (account); - personas = GEE_SET ( - gee_hash_set_new (FOLKS_TYPE_PERSONA, g_object_ref, g_object_unref, - g_direct_hash, g_direct_equal)); - - persona = tpf_persona_new (contacts[0], store); - - gee_collection_add (GEE_COLLECTION (personas), persona); - - individual = folks_individual_new (personas); + individual = empathy_create_individual_from_tp_contact (contacts[0]); /* listen for updates to the capabilities */ tp_g_signal_connect_object (contacts[0], "notify::capabilities", @@ -249,10 +236,6 @@ get_contacts_cb (TpConnection *connection, gtk_tree_view_get_selection (GTK_TREE_VIEW (self->priv->view)), NULL, NULL)) empathy_individual_view_select_first (self->priv->view); - - g_clear_object (&persona); - g_clear_object (&personas); - g_object_unref (store); } static void diff --git a/libempathy/empathy-utils.c b/libempathy/empathy-utils.c index 83fe4ce7e..972abe65e 100644 --- a/libempathy/empathy-utils.c +++ b/libempathy/empathy-utils.c @@ -1163,3 +1163,35 @@ empathy_sasl_channel_supports_mechanism (TpChannel *channel, return tp_strv_contains (available_mechanisms, mechanism); } + +FolksIndividual * +empathy_create_individual_from_tp_contact (TpContact *contact) +{ + TpAccount *account; + TpConnection *connection; + TpfPersonaStore *store; + GeeSet *personas; + TpfPersona *persona; + FolksIndividual *individual; + + connection = tp_contact_get_connection (contact); + account = tp_connection_get_account (connection); + + store = tpf_persona_store_new (account); + + personas = GEE_SET ( + gee_hash_set_new (FOLKS_TYPE_PERSONA, g_object_ref, g_object_unref, + g_direct_hash, g_direct_equal)); + + persona = tpf_persona_new (contact, store); + + gee_collection_add (GEE_COLLECTION (personas), persona); + + individual = folks_individual_new (personas); + + g_clear_object (&persona); + g_clear_object (&personas); + g_object_unref (store); + + return individual; +} diff --git a/libempathy/empathy-utils.h b/libempathy/empathy-utils.h index f8d47ec8a..ac5fef820 100644 --- a/libempathy/empathy-utils.h +++ b/libempathy/empathy-utils.h @@ -121,6 +121,9 @@ void empathy_individual_can_audio_video_call (FolksIndividual *individual, gboolean empathy_sasl_channel_supports_mechanism (TpChannel *channel, const gchar *mechanism); +FolksIndividual * empathy_create_individual_from_tp_contact ( + TpContact *contact); + /* Copied from wocky/wocky-utils.h */ #define empathy_implement_finish_void(source, tag) \ |