From: Guillaume Desmottes Date: Fri, 4 Nov 2011 12:45:38 +0000 (+0100) Subject: factor out empathy_create_individual_from_tp_contact() X-Git-Url: https://git.0d.be/?p=empathy.git;a=commitdiff_plain;h=ef0d55ead126f53aa4544877d2df5ab712f00f28 factor out empathy_create_individual_from_tp_contact() https://bugzilla.gnome.org/show_bug.cgi?id=663387 --- diff --git a/libempathy-gtk/empathy-contact-chooser.c b/libempathy-gtk/empathy-contact-chooser.c index 6d93e681..cba419be 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 + #include #include #include @@ -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 83fe4ce7..972abe65 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 f8d47ec8..ac5fef82 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) \