aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-call-utils.c
diff options
context:
space:
mode:
authorGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2011-09-20 22:40:03 +0800
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2011-09-26 17:56:23 +0800
commitb6b5e35d96ac4d2bc2cb070d2bb0613992008f5d (patch)
tree63a0d0bf8006a3acc6922932f9cca3b076ef9a0c /libempathy-gtk/empathy-call-utils.c
parent09ccdc338176ede800dc7891129356e7232eb7d9 (diff)
downloadgsoc2013-empathy-b6b5e35d96ac4d2bc2cb070d2bb0613992008f5d.tar
gsoc2013-empathy-b6b5e35d96ac4d2bc2cb070d2bb0613992008f5d.tar.gz
gsoc2013-empathy-b6b5e35d96ac4d2bc2cb070d2bb0613992008f5d.tar.bz2
gsoc2013-empathy-b6b5e35d96ac4d2bc2cb070d2bb0613992008f5d.tar.lz
gsoc2013-empathy-b6b5e35d96ac4d2bc2cb070d2bb0613992008f5d.tar.xz
gsoc2013-empathy-b6b5e35d96ac4d2bc2cb070d2bb0613992008f5d.tar.zst
gsoc2013-empathy-b6b5e35d96ac4d2bc2cb070d2bb0613992008f5d.zip
Factor out call_new_with_streams()
https://bugzilla.gnome.org/show_bug.cgi?id=659594
Diffstat (limited to 'libempathy-gtk/empathy-call-utils.c')
-rw-r--r--libempathy-gtk/empathy-call-utils.c27
1 files changed, 22 insertions, 5 deletions
diff --git a/libempathy-gtk/empathy-call-utils.c b/libempathy-gtk/empathy-call-utils.c
index eb01fe25b..a30e0808f 100644
--- a/libempathy-gtk/empathy-call-utils.c
+++ b/libempathy-gtk/empathy-call-utils.c
@@ -163,8 +163,9 @@ create_call_channel_cb (GObject *source,
NULL);
}
-void
-empathy_call_new_with_streams (const gchar *contact,
+/* Try to request a Call channel and fallback to StreamedMedia if that fails */
+static void
+call_new_with_streams (const gchar *contact,
TpAccount *account,
gboolean initial_audio,
gboolean initial_video,
@@ -173,29 +174,45 @@ empathy_call_new_with_streams (const gchar *contact,
GHashTable *call_request, *streamed_media_request;
TpAccountChannelRequest *call_req, *streamed_media_req;
+ /* Call */
call_request = empathy_call_create_call_request (contact,
initial_audio,
initial_video);
+ call_req = tp_account_channel_request_new (account, call_request, timestamp);
+
+ g_hash_table_unref (call_request);
+
+ /* StreamedMedia */
streamed_media_request = empathy_call_create_streamed_media_request (
contact, initial_audio, initial_video);
- call_req = tp_account_channel_request_new (account, call_request, timestamp);
streamed_media_req = tp_account_channel_request_new (account,
streamed_media_request,
timestamp);
+ g_hash_table_unref (streamed_media_request);
+
tp_account_channel_request_create_channel_async (call_req,
EMPATHY_CALL_BUS_NAME, NULL,
create_call_channel_cb,
streamed_media_req);
- g_hash_table_unref (call_request);
- g_hash_table_unref (streamed_media_request);
g_object_unref (call_req);
}
void
+empathy_call_new_with_streams (const gchar *contact,
+ TpAccount *account,
+ gboolean initial_audio,
+ gboolean initial_video,
+ gint64 timestamp)
+{
+ call_new_with_streams (contact, account, initial_audio, initial_video,
+ timestamp);
+}
+
+void
empathy_call_set_stream_properties (GstElement *element)
{
GstStructure *props;