X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_processor.cc;h=6f3b96145708356438353f16b7b80fe2ab83f86e;hb=182b9d2e2feb6545592868606aaf0f0146095481;hp=0d3f2b6d7ecc2b0a0259a8018e2964c1f19ae9fa;hpb=3828baf56467224f5d44049bf1e7a7ed11f43a05;p=dcpomatic.git diff --git a/src/lib/audio_processor.cc b/src/lib/audio_processor.cc index 0d3f2b6d7..6f3b96145 100644 --- a/src/lib/audio_processor.cc +++ b/src/lib/audio_processor.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,38 +18,81 @@ */ + #include "audio_processor.h" +#include "config.h" #include "mid_side_decoder.h" #include "upmixer_a.h" #include "upmixer_b.h" + using std::string; -using std::list; +using std::unique_ptr; +using std::vector; + + +vector> AudioProcessor::_experimental; +vector> AudioProcessor::_non_experimental; -list AudioProcessor::_all; void AudioProcessor::setup_audio_processors () { - _all.push_back (new MidSideDecoder ()); - _all.push_back (new UpmixerA (48000)); - _all.push_back (new UpmixerB (48000)); + _non_experimental.push_back (unique_ptr(new MidSideDecoder())); + + _experimental.push_back (unique_ptr(new UpmixerA(48000))); + _experimental.push_back (unique_ptr(new UpmixerB(48000))); } + AudioProcessor const * AudioProcessor::from_id (string id) { - for (list::const_iterator i = _all.begin(); i != _all.end(); ++i) { - if ((*i)->id() == id) { - return *i; + for (auto& i: _non_experimental) { + if (i->id() == id) { + return i.get(); } } - return 0; + for (auto& i: _experimental) { + if (i->id() == id) { + return i.get(); + } + } + + return nullptr; } -list + +vector +AudioProcessor::visible () +{ + vector raw; + if (Config::instance()->show_experimental_audio_processors()) { + for (auto& processor: _experimental) { + raw.push_back (processor.get()); + } + } + + for (auto& processor: _non_experimental) { + raw.push_back (processor.get()); + } + + return raw; +} + + +vector AudioProcessor::all () { - return _all; + vector raw; + for (auto& processor: _experimental) { + raw.push_back (processor.get()); + } + + for (auto& processor: _non_experimental) { + raw.push_back (processor.get()); + } + + return raw; }