From 274c56665d98a392b4488b5cbe4bf7206181c5fc Mon Sep 17 00:00:00 2001 From: "Matthias P. Braendli" Date: Sat, 7 Oct 2017 12:02:59 +0200 Subject: Only create the input we actually need --- src/AlsaInput.h | 17 ----------------- src/odr-audioenc.cpp | 31 ++++++++++--------------------- 2 files changed, 10 insertions(+), 38 deletions(-) diff --git a/src/AlsaInput.h b/src/AlsaInput.h index e90ed36..8055140 100644 --- a/src/AlsaInput.h +++ b/src/AlsaInput.h @@ -86,23 +86,6 @@ class AlsaInputDirect : public AlsaInput SampleQueue& queue) : AlsaInput(alsa_dev, channels, rate, queue) { } -#if 0 - AlsaInputDirect(AlsaInputDirect&& other) : - AlsaInput(other.m_alsa_dev, other.m_channels, other.m_rate) { - m_alsa_handle = other.m_alsa_handle; - other.m_alsa_handle = nullptr; - } - - AlsaInputDirect& operator=(AlsaInputDirect&& other) { - m_alsa_dev = other.m_alsa_dev; - m_channels = other.m_channels; - m_rate = other.m_rate; - m_alsa_handle = other.m_alsa_handle; - other.m_alsa_handle = nullptr; - return *this; - } -#endif - virtual void prepare(void) override; virtual bool fault_detected(void) const override { return false; }; diff --git a/src/odr-audioenc.cpp b/src/odr-audioenc.cpp index 098d700..e54334e 100644 --- a/src/odr-audioenc.cpp +++ b/src/odr-audioenc.cpp @@ -869,44 +869,31 @@ int main(int argc, char *argv[]) return 1; } - // We'll use one of the tree possible inputs -#if HAVE_ALSA - AlsaInputThreaded alsa_in_threaded(alsa_device, channels, sample_rate, queue); - AlsaInputDirect alsa_in_direct(alsa_device, channels, sample_rate, queue); -#endif - FileInput file_in(infile, raw_input, sample_rate, continue_after_eof, queue); -#if HAVE_JACK - JackInput jack_in(jack_name, channels, sample_rate, queue); -#endif -#if HAVE_VLC - VLCInput vlc_input(vlc_uri, sample_rate, channels, verbosity, vlc_gain, vlc_cache, vlc_additional_opts, queue); -#endif - - InputInterface *input = nullptr; + shared_ptr input; if (not infile.empty()) { - input = &file_in; + input = make_shared(infile, raw_input, sample_rate, continue_after_eof, queue); } #if HAVE_JACK else if (not jack_name.empty()) { - input = &jack_in; + input = make_shared(jack_name, channels, sample_rate, queue); } #endif #if HAVE_VLC else if (not vlc_uri.empty()) { - input = &vlc_input; + input = make_shared(vlc_uri, sample_rate, channels, verbosity, vlc_gain, vlc_cache, vlc_additional_opts, queue); } #endif #if HAVE_ALSA else if (drift_compensation) { - input = &alsa_in_threaded; + input = make_shared(alsa_device, channels, sample_rate, queue); } else { - input = &alsa_in_direct; + input = make_shared(alsa_device, channels, sample_rate, queue); } #endif - if (input == nullptr) { + if (not input) { fprintf(stderr, "No input defined\n"); return 1; } @@ -1054,7 +1041,9 @@ int main(int argc, char *argv[]) */ #if HAVE_VLC if (not vlc_uri.empty() and not vlc_icytext_file.empty()) { - vlc_input.write_icy_text(vlc_icytext_file, vlc_icytext_dlplus); + // Using std::dynamic_pointer_cast would be safer, but is C++17 + VLCInput *vlc_input = (VLCInput*)(input.get()); + vlc_input->write_icy_text(vlc_icytext_file, vlc_icytext_dlplus); } #endif -- cgit v1.2.3