Extract common code out into kdm_for_screen()
[dcpomatic.git] / src / lib / audio_processor.cc
1 /*
2     Copyright (C) 2014 Carl Hetherington <cth@carlh.net>
3
4     This file is part of DCP-o-matic.
5
6     DCP-o-matic is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     DCP-o-matic is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
18
19 */
20
21 #include "audio_processor.h"
22 #include "mid_side_decoder.h"
23 #include "upmixer_a.h"
24 #include "upmixer_b.h"
25 #include "config.h"
26
27 using std::string;
28 using std::list;
29
30 list<AudioProcessor const *> AudioProcessor::_all;
31 list<AudioProcessor const *> AudioProcessor::_non_experimental;
32
33 void
34 AudioProcessor::setup_audio_processors ()
35 {
36         AudioProcessor* mid_side = new MidSideDecoder ();
37         _all.push_back (mid_side);
38         _non_experimental.push_back (mid_side);
39
40         _all.push_back (new UpmixerA (48000));
41         _all.push_back (new UpmixerB (48000));
42 }
43
44 AudioProcessor const *
45 AudioProcessor::from_id (string id)
46 {
47         for (list<AudioProcessor const *>::const_iterator i = _all.begin(); i != _all.end(); ++i) {
48                 if ((*i)->id() == id) {
49                         return *i;
50                 }
51         }
52
53         return 0;
54 }
55
56 list<AudioProcessor const *>
57 AudioProcessor::visible ()
58 {
59         if (Config::instance()->show_experimental_audio_processors()) {
60                 return _all;
61         }
62
63         return _non_experimental;
64 }
65
66 list<AudioProcessor const *>
67 AudioProcessor::all ()
68 {
69         return _all;
70 }