aboutsummaryrefslogtreecommitdiffstats
path: root/src/GSTInput.cpp
diff options
context:
space:
mode:
authorMatthias P. Braendli <matthias.braendli@mpb.li>2022-11-18 16:02:06 +0100
committerMatthias P. Braendli <matthias.braendli@mpb.li>2022-11-18 16:02:06 +0100
commit734166da289ac4a5ebbc0b1c845c2b9681d41afc (patch)
treeeddfd317d98fc4435941a7b77f4e7697ef3afd83 /src/GSTInput.cpp
parentfff72cb8c17c2ff7f2c0a87f3e5e741009945a7b (diff)
downloadODR-AudioEnc-734166da289ac4a5ebbc0b1c845c2b9681d41afc.tar.gz
ODR-AudioEnc-734166da289ac4a5ebbc0b1c845c2b9681d41afc.tar.bz2
ODR-AudioEnc-734166da289ac4a5ebbc0b1c845c2b9681d41afc.zip
Add --gst-pipeline option for custom nput pipelines
Diffstat (limited to 'src/GSTInput.cpp')
-rw-r--r--src/GSTInput.cpp72
1 files changed, 49 insertions, 23 deletions
diff --git a/src/GSTInput.cpp b/src/GSTInput.cpp
index 5c63147..6c437d7 100644
--- a/src/GSTInput.cpp
+++ b/src/GSTInput.cpp
@@ -41,10 +41,12 @@ GSTData::GSTData(SampleQueue<uint8_t>& samplequeue) :
{ }
GSTInput::GSTInput(const std::string& uri,
+ const std::string& pipeline,
int rate,
unsigned channels,
SampleQueue<uint8_t>& queue) :
m_uri(uri),
+ m_pipeline(pipeline),
m_channels(channels),
m_rate(rate),
m_gst_data(queue)
@@ -110,25 +112,34 @@ void GSTInput::prepare()
{
gst_init(nullptr, nullptr);
- m_gst_data.uridecodebin = gst_element_factory_make("uridecodebin", "uridecodebin");
- assert(m_gst_data.uridecodebin != nullptr);
- g_object_set(m_gst_data.uridecodebin, "uri", m_uri.c_str(), nullptr);
- g_signal_connect(m_gst_data.uridecodebin, "pad-added", G_CALLBACK(cb_newpad), &m_gst_data);
+ if (not m_uri.empty()) {
+ m_gst_data.uridecodebin = gst_element_factory_make("uridecodebin", "uridecodebin");
+ assert(m_gst_data.uridecodebin != nullptr);
+ g_object_set(m_gst_data.uridecodebin, "uri", m_uri.c_str(), nullptr);
+ g_signal_connect(m_gst_data.uridecodebin, "pad-added", G_CALLBACK(cb_newpad), &m_gst_data);
- m_gst_data.audio_convert = gst_element_factory_make("audioconvert", "audio_convert");
- assert(m_gst_data.audio_convert != nullptr);
+ m_gst_data.audio_convert = gst_element_factory_make("audioconvert", "audio_convert");
+ assert(m_gst_data.audio_convert != nullptr);
- m_gst_data.audio_resample = gst_element_factory_make("audioresample", "audio_resample");
- assert(m_gst_data.audio_resample != nullptr);
- g_object_set(m_gst_data.audio_resample,
+ m_gst_data.audio_resample = gst_element_factory_make("audioresample", "audio_resample");
+ assert(m_gst_data.audio_resample != nullptr);
+ g_object_set(m_gst_data.audio_resample,
#if (GST_VERSION_MAJOR == 1 && GST_VERSION_MINOR >= 10) || GST_VERSION_MAJOR > 1
- "sinc-filter-mode", GST_AUDIO_RESAMPLER_FILTER_MODE_FULL,
+ "sinc-filter-mode", GST_AUDIO_RESAMPLER_FILTER_MODE_FULL,
#else
#warning "GStreamer version is too old to set GST_AUDIO_RESAMPLER_FILTER_MODE_FULL" GST_VERSION_MAJOR
#endif
- "quality", 6, // between 0 and 10, 10 being best
- /* default audio-resampler-method: GST_AUDIO_RESAMPLER_METHOD_KAISER */
- NULL);
+ "quality", 6, // between 0 and 10, 10 being best
+ /* default audio-resampler-method: GST_AUDIO_RESAMPLER_METHOD_KAISER */
+ NULL);
+
+ }
+ else if (not m_pipeline.empty()) {
+ m_gst_data.custom_bin = gst_parse_bin_from_description(m_pipeline.c_str(), true, nullptr);
+ if (m_gst_data.custom_bin == nullptr) {
+ throw runtime_error("Could not instantiate pipeline");
+ }
+ }
m_gst_data.caps_filter = gst_element_factory_make("capsfilter", "caps_filter");
assert(m_gst_data.caps_filter != nullptr);
@@ -149,19 +160,34 @@ void GSTInput::prepare()
g_signal_connect(m_gst_data.app_sink, "new-sample", G_CALLBACK(new_sample), &m_gst_data);
gst_caps_unref(audio_caps);
- gst_bin_add_many(GST_BIN(m_gst_data.pipeline),
- m_gst_data.uridecodebin,
- m_gst_data.audio_convert,
- m_gst_data.audio_resample,
- m_gst_data.caps_filter,
- m_gst_data.app_sink, NULL);
-
- if (gst_element_link_many(
+ if (not m_uri.empty()) {
+ gst_bin_add_many(GST_BIN(m_gst_data.pipeline),
+ m_gst_data.uridecodebin,
m_gst_data.audio_convert,
m_gst_data.audio_resample,
m_gst_data.caps_filter,
- m_gst_data.app_sink, NULL) != true) {
- throw runtime_error("Could not link GST elements");
+ m_gst_data.app_sink, NULL);
+
+ if (gst_element_link_many(
+ m_gst_data.audio_convert,
+ m_gst_data.audio_resample,
+ m_gst_data.caps_filter,
+ m_gst_data.app_sink, NULL) != true) {
+ throw runtime_error("Could not link GST elements");
+ }
+ }
+ else if (not m_pipeline.empty()) {
+ gst_bin_add_many(GST_BIN(m_gst_data.pipeline),
+ m_gst_data.custom_bin,
+ m_gst_data.caps_filter,
+ m_gst_data.app_sink, NULL);
+
+ if (gst_element_link_many(
+ m_gst_data.custom_bin,
+ m_gst_data.caps_filter,
+ m_gst_data.app_sink, NULL) != true) {
+ throw runtime_error("Could not link GST elements");
+ }
}
m_gst_data.bus = gst_element_get_bus(m_gst_data.pipeline);