aboutsummaryrefslogtreecommitdiffstats
path: root/src/empathy-call-window.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/empathy-call-window.c')
-rw-r--r--src/empathy-call-window.c74
1 files changed, 18 insertions, 56 deletions
diff --git a/src/empathy-call-window.c b/src/empathy-call-window.c
index 6ba257ba1..04da28780 100644
--- a/src/empathy-call-window.c
+++ b/src/empathy-call-window.c
@@ -101,7 +101,6 @@ struct _EmpathyCallWindowPriv
gboolean dispose_has_run;
EmpathyCallHandler *handler;
- GArray *members;
EmpathyContact *contact;
guint call_state;
@@ -1289,45 +1288,22 @@ empathy_call_window_setup_avatars (EmpathyCallWindow *self,
EmpathyCallHandler *handler)
{
EmpathyCallWindowPriv *priv = GET_PRIV (self);
+ TpConnection *connection;
- g_object_get (handler, "members", &(priv->members), NULL);
+ g_signal_connect (priv->contact, "notify::name",
+ G_CALLBACK (contact_name_changed_cb), self);
+ g_signal_connect (priv->contact, "notify::avatar",
+ G_CALLBACK (contact_avatar_changed_cb),
+ priv->remote_user_avatar_widget);
- if (priv->members != NULL)
- {
- TpConnection *connection;
-
- if (priv->members->len == 1)
- {
- priv->contact = g_array_index (priv->members, EmpathyContact *, 0);
- g_signal_connect (priv->contact, "notify::name",
- G_CALLBACK (contact_name_changed_cb), self);
- g_signal_connect (priv->contact, "notify::avatar",
- G_CALLBACK (contact_avatar_changed_cb),
- priv->remote_user_avatar_widget);
-
- /* Retreiving the self avatar */
- connection = empathy_contact_get_connection (priv->contact);
- empathy_tp_contact_factory_get_from_handle (connection,
- tp_connection_get_self_handle (connection),
- empathy_call_window_got_self_contact_cb, self, NULL,
- G_OBJECT (self));
- }
-
- set_window_title (self);
- }
- else
- {
- g_warning ("call handler doesn't have a contact");
- /* translators: Call is a noun. This string is used in the window
- * title */
- gtk_window_set_title (GTK_WINDOW (self), _("Call"));
+ /* Retrieving the self avatar */
+ connection = empathy_contact_get_connection (priv->contact);
+ empathy_tp_contact_factory_get_from_handle (connection,
+ tp_connection_get_self_handle (connection),
+ empathy_call_window_got_self_contact_cb, self, NULL,
+ G_OBJECT (self));
- /* Since we can't access the remote contact, we can't get a connection
- to it and can't get the self contact (and its avatar). This means
- that we have to manually set the self avatar. */
- init_contact_avatar_with_size (NULL, priv->self_user_avatar_widget,
- MIN (SELF_VIDEO_SECTION_WIDTH, SELF_VIDEO_SECTION_HEIGTH));
- }
+ set_window_title (self);
init_contact_avatar_with_size (priv->contact,
priv->remote_user_avatar_widget,
@@ -1562,6 +1538,9 @@ empathy_call_window_constructed (GObject *object)
if (call != NULL)
g_object_unref (call);
+ g_object_get (priv->handler, "target-contact", &priv->contact, NULL);
+ g_assert (priv->contact != NULL);
+
empathy_call_window_setup_avatars (self, priv->handler);
empathy_call_window_set_state_connecting (self);
@@ -1699,13 +1678,6 @@ empathy_call_window_dispose (GObject *object)
priv->contact = NULL;
}
-#if 0
- if (priv->members != NULL)
- {
- g_list_free_full (priv->members, g_object_unref);
- priv->members = NULL;
- }
-#endif
G_OBJECT_CLASS (empathy_call_window_parent_class)->dispose (object);
}
@@ -2419,7 +2391,8 @@ empathy_call_window_connected (gpointer user_data)
empathy_sound_stop (EMPATHY_SOUND_PHONE_OUTGOING);
- can_send_video = priv->video_input != NULL && priv->members != NULL &&
+
+ can_send_video = priv->video_input != NULL &&
empathy_contact_can_voip_video (priv->contact);
g_object_get (priv->handler, "call-channel", &call, NULL);
@@ -2768,14 +2741,6 @@ call_handler_notify_call_cb (EmpathyCallHandler *handler,
}
static void
-on_call_members_changed_cb (EmpathyCallHandler *handler,
- GParamSpec *spec,
- EmpathyCallWindow *self)
-{
- empathy_call_window_setup_avatars (self, handler);
-}
-
-static void
empathy_call_window_realized_cb (GtkWidget *widget, EmpathyCallWindow *window)
{
EmpathyCallWindowPriv *priv = GET_PRIV (window);
@@ -2794,9 +2759,6 @@ empathy_call_window_realized_cb (GtkWidget *widget, EmpathyCallWindow *window)
g_signal_connect (priv->handler, "sink-pad-removed",
G_CALLBACK (empathy_call_window_sink_removed_cb), window);
- g_signal_connect (priv->handler, "notify::members",
- G_CALLBACK (on_call_members_changed_cb), window);
-
g_object_get (priv->handler, "call-channel", &call, NULL);
if (call != NULL)
{