summaryrefslogtreecommitdiffstats
path: root/src/odr-audioenc.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/odr-audioenc.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/odr-audioenc.cpp')
-rw-r--r--src/odr-audioenc.cpp15
1 files changed, 12 insertions, 3 deletions
diff --git a/src/odr-audioenc.cpp b/src/odr-audioenc.cpp
index e3708c1..21abb91 100644
--- a/src/odr-audioenc.cpp
+++ b/src/odr-audioenc.cpp
@@ -162,6 +162,9 @@ static void usage(const char* name)
" For the GStreamer input:\n"
#if HAVE_GST
" -G, --gst-uri=uri Enable GStreamer input and use the URI given as source\n"
+ " --gst-pipeline=pipeline Specify a GStreamer pipeline that receives your source.\n"
+ " The last pipeline element is connected to a caps filter that specifies\n"
+ " the audio format and sample rate.\n"
#else
" The GStreamer input was disabled at compile-time\n"
#endif
@@ -427,6 +430,7 @@ public:
// For the GST input
string gst_uri;
+ string gst_pipeline;
string jack_name;
@@ -517,6 +521,7 @@ int AudioEnc::run()
#endif
#if HAVE_GST
if (not gst_uri.empty()) num_inputs++;
+ if (not gst_pipeline.empty()) num_inputs++;
#endif
if (num_inputs == 0) {
@@ -987,7 +992,7 @@ int AudioEnc::run()
}
#endif
#if HAVE_GST
- else if (not gst_uri.empty()) {
+ else if ((not gst_uri.empty()) or (not gst_pipeline.empty())) {
GSTInput *gst_input = (GSTInput*)(input.get());
text = gst_input->get_icy_text();
}
@@ -1342,8 +1347,8 @@ shared_ptr<InputInterface> AudioEnc::initialise_input()
}
#endif
#if HAVE_GST
- else if (not gst_uri.empty()) {
- input = make_shared<GSTInput>(gst_uri, sample_rate, channels, queue);
+ else if ((not gst_uri.empty()) or (not gst_pipeline.empty())) {
+ input = make_shared<GSTInput>(gst_uri, gst_pipeline, sample_rate, channels, queue);
}
#endif
#if HAVE_ALSA
@@ -1381,6 +1386,7 @@ int main(int argc, char *argv[])
{"decode", required_argument, 0, 6 },
{"format", required_argument, 0, 'f'},
{"gst-uri", required_argument, 0, 'G'},
+ {"gst-pipeline", required_argument, 0, 11 },
{"identifier", required_argument, 0, 7 },
{"input", required_argument, 0, 'i'},
{"jack", required_argument, 0, 'j'},
@@ -1543,6 +1549,9 @@ int main(int argc, char *argv[])
case 'G':
audio_enc.gst_uri = optarg;
break;
+ case 11: // --gst-pipeline
+ audio_enc.gst_pipeline = optarg;
+ break;
#endif
case 'i':
audio_enc.infile = optarg;