diff options
author | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2011-08-15 17:23:35 +0800 |
---|---|---|
committer | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2011-08-15 20:38:12 +0800 |
commit | be5274444c54eb5c529e592d130e362fd1728b4d (patch) | |
tree | 3bc8d766c10532db66761b963864b2c379980fa2 /src/empathy-audio-src.c | |
parent | 7e9166e6711d15a28bb679a1aeed3223134f2388 (diff) | |
download | gsoc2013-empathy-be5274444c54eb5c529e592d130e362fd1728b4d.tar gsoc2013-empathy-be5274444c54eb5c529e592d130e362fd1728b4d.tar.gz gsoc2013-empathy-be5274444c54eb5c529e592d130e362fd1728b4d.tar.bz2 gsoc2013-empathy-be5274444c54eb5c529e592d130e362fd1728b4d.tar.lz gsoc2013-empathy-be5274444c54eb5c529e592d130e362fd1728b4d.tar.xz gsoc2013-empathy-be5274444c54eb5c529e592d130e362fd1728b4d.tar.zst gsoc2013-empathy-be5274444c54eb5c529e592d130e362fd1728b4d.zip |
Use gst_parse_bin_from_description() when EMPATHY_AUDIO_* vars are set
Also factor out empathy_call_set_stream_properties().
Diffstat (limited to 'src/empathy-audio-src.c')
-rw-r--r-- | src/empathy-audio-src.c | 47 |
1 files changed, 33 insertions, 14 deletions
diff --git a/src/empathy-audio-src.c b/src/empathy-audio-src.c index 98ff24eca..5da424810 100644 --- a/src/empathy-audio-src.c +++ b/src/empathy-audio-src.c @@ -26,6 +26,7 @@ #include <pulse/glib-mainloop.h> #include <libempathy/empathy-utils.h> +#include <libempathy-gtk/empathy-call-utils.h> #include "empathy-audio-src.h" @@ -377,32 +378,50 @@ empathy_audio_src_source_output_index_notify (GObject *object, empathy_audio_src_source_output_info_cb, self); } +static GstElement * +create_src (const gchar *description) +{ + GstElement *src; + + if (description != NULL) + { + GError *error = NULL; + + src = gst_parse_bin_from_description (description, TRUE, &error); + if (src == NULL) + { + DEBUG ("Failed to create bin %s: %s", description, error->message); + g_error_free (error); + } + + return src; + } + + /* Use pulsesrc as default */ + src = gst_element_factory_make ("pulsesrc", NULL); + if (src == NULL) + return NULL; + + empathy_call_set_stream_properties (src); + + return src; +} + static void empathy_audio_src_init (EmpathyGstAudioSrc *obj) { EmpathyGstAudioSrcPrivate *priv = EMPATHY_GST_AUDIO_SRC_GET_PRIVATE (obj); GstPad *ghost, *src; - const gchar *src_element; priv->peak_level = -G_MAXDOUBLE; priv->lock = g_mutex_new (); - src_element = g_getenv ("EMPATHY_AUDIO_SRC"); - if (src_element == NULL) - src_element = "pulsesrc"; + priv->src = create_src (g_getenv ("EMPATHY_AUDIO_SRC")); + if (priv->src == NULL) + return; - priv->src = gst_element_factory_make (src_element, NULL); gst_bin_add (GST_BIN (obj), priv->src); - if (!tp_strdiff (src_element, "pulsesrc")) - { - GstStructure *props; - - props = gst_structure_from_string ("props,media.role=phone", NULL); - g_object_set (priv->src, "stream-properties", props, NULL); - gst_structure_free (props); - } - priv->volume = gst_element_factory_make ("volume", NULL); g_object_ref (priv->volume); |