aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libempathy-gtk/empathy-contact-chooser.c23
-rw-r--r--libempathy/empathy-utils.c32
-rw-r--r--libempathy/empathy-utils.h3
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) \