diff options
author | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2011-09-20 22:40:03 +0800 |
---|---|---|
committer | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2011-09-26 17:56:23 +0800 |
commit | b6b5e35d96ac4d2bc2cb070d2bb0613992008f5d (patch) | |
tree | 63a0d0bf8006a3acc6922932f9cca3b076ef9a0c | |
parent | 09ccdc338176ede800dc7891129356e7232eb7d9 (diff) | |
download | gsoc2013-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
-rw-r--r-- | libempathy-gtk/empathy-call-utils.c | 27 |
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; |