aboutsummaryrefslogtreecommitdiffstats
path: root/src/empathy-call-handler.c
diff options
context:
space:
mode:
authorSjoerd Simons <sjoerd.simons@collabora.co.uk>2011-02-23 19:14:06 +0800
committerEmilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk>2011-06-09 17:20:06 +0800
commit2d6c887b9369e2db3c3bff166ee6c2c8a595faa4 (patch)
treef3aeb521b4f43daef3bf61893a4b1ff7618d8582 /src/empathy-call-handler.c
parenta6b59ff12bf5563ad4db0427c0c9e41bd8842c25 (diff)
downloadgsoc2013-empathy-2d6c887b9369e2db3c3bff166ee6c2c8a595faa4.tar
gsoc2013-empathy-2d6c887b9369e2db3c3bff166ee6c2c8a595faa4.tar.gz
gsoc2013-empathy-2d6c887b9369e2db3c3bff166ee6c2c8a595faa4.tar.bz2
gsoc2013-empathy-2d6c887b9369e2db3c3bff166ee6c2c8a595faa4.tar.lz
gsoc2013-empathy-2d6c887b9369e2db3c3bff166ee6c2c8a595faa4.tar.xz
gsoc2013-empathy-2d6c887b9369e2db3c3bff166ee6c2c8a595faa4.tar.zst
gsoc2013-empathy-2d6c887b9369e2db3c3bff166ee6c2c8a595faa4.zip
Add TargetContact property that's guaranteed to exist on CallHandler
Conflicts: src/empathy-call-factory.c
Diffstat (limited to 'src/empathy-call-handler.c')
-rw-r--r--src/empathy-call-handler.c22
1 files changed, 21 insertions, 1 deletions
diff --git a/src/empathy-call-handler.c b/src/empathy-call-handler.c
index cc94e4ad8..eca076d94 100644
--- a/src/empathy-call-handler.c
+++ b/src/empathy-call-handler.c
@@ -59,6 +59,7 @@ static guint signals[LAST_SIGNAL] = {0};
enum {
PROP_CALL_CHANNEL = 1,
PROP_GST_BUS,
+ PROP_CONTACT,
PROP_MEMBERS,
PROP_INITIAL_AUDIO,
PROP_INITIAL_VIDEO,
@@ -77,6 +78,7 @@ enum {
typedef struct {
TpyCallChannel *call;
+ EmpathyContact *contact;
/* GArray of TpContacts */
GArray *members;
TfChannel *tfchannel;
@@ -102,6 +104,7 @@ empathy_call_handler_dispose (GObject *object)
tp_clear_object (&priv->tfchannel);
tp_clear_object (&priv->call);
+ tp_clear_object (&priv->contact);
tp_clear_pointer (&priv->members, g_array_unref);
@@ -231,6 +234,9 @@ empathy_call_handler_set_property (GObject *object,
switch (property_id)
{
+ case PROP_CONTACT:
+ priv->contact = g_value_dup_object (value);
+ break;
case PROP_MEMBERS:
priv->members = g_value_get_boxed (value);
break;
@@ -256,6 +262,9 @@ empathy_call_handler_get_property (GObject *object,
switch (property_id)
{
+ case PROP_CONTACT:
+ g_value_set_object (value, priv->contact);
+ break;
case PROP_MEMBERS:
g_value_set_boxed (value, priv->members);
break;
@@ -312,6 +321,12 @@ empathy_call_handler_class_init (EmpathyCallHandlerClass *klass)
object_class->dispose = empathy_call_handler_dispose;
object_class->finalize = empathy_call_handler_finalize;
+ param_spec = g_param_spec_object ("target-contact",
+ "TargetContact", "The contact",
+ EMPATHY_TYPE_CONTACT,
+ G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY | G_PARAM_STATIC_STRINGS);
+ g_object_class_install_property (object_class, PROP_CONTACT, param_spec);
+
param_spec = g_param_spec_boxed ("members",
"call members", "The call participants",
G_TYPE_ARRAY,
@@ -448,11 +463,13 @@ empathy_call_handler_class_init (EmpathyCallHandlerClass *klass)
}
EmpathyCallHandler *
-empathy_call_handler_new_for_channel (TpyCallChannel *call)
+empathy_call_handler_new_for_channel (TpyCallChannel *call,
+ EmpathyContact *contact)
{
return EMPATHY_CALL_HANDLER (g_object_new (EMPATHY_TYPE_CALL_HANDLER,
"call-channel", call,
"initial-video", tpy_call_channel_has_initial_video (call),
+ "target-contact", contact,
NULL));
}
@@ -925,7 +942,10 @@ empathy_call_handler_stop_call (EmpathyCallHandler *handler)
tpy_call_channel_hangup_async (priv->call,
TPY_CALL_STATE_CHANGE_REASON_USER_REQUESTED,
"", "", NULL, NULL);
+ tp_channel_close_async (TP_CHANNEL (priv->call),
+ NULL, NULL);
tp_clear_object (&priv->call);
+ tp_clear_object (&priv->tfchannel);
}
}