2 Copyright (C) 2012 Carl Hetherington <cth@carlh.net>
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 /** @file src/config.h
21 * @brief Class holding configuration.
24 #ifndef DVDOMATIC_CONFIG_H
25 #define DVDOMATIC_CONFIG_H
28 #include <boost/shared_ptr.hpp>
29 #include <boost/signals2.hpp>
31 class ServerDescription;
38 * @brief A singleton class holding configuration.
44 /** @return number of threads to use for J2K encoding on the local machine */
45 int num_local_encoding_threads () const {
46 return _num_local_encoding_threads;
49 std::string default_directory () const {
50 return _default_directory;
53 std::string default_directory_or (std::string a) const;
55 /** @return port to use for J2K encoding servers */
56 int server_port () const {
60 /** @return J2K encoding servers to use */
61 std::vector<ServerDescription*> servers () const {
65 Scaler const * reference_scaler () const {
66 return _reference_scaler;
69 std::vector<Filter const *> reference_filters () const {
70 return _reference_filters;
73 /** @return The IP address of a TMS that we can copy DCPs to */
74 std::string tms_ip () const {
78 /** @return The path on a TMS that we should write DCPs to */
79 std::string tms_path () const {
83 /** @return User name to log into the TMS with */
84 std::string tms_user () const {
88 /** @return Password to log into the TMS with */
89 std::string tms_password () const {
93 /** @return The sound processor that we are using */
94 SoundProcessor const * sound_processor () const {
95 return _sound_processor;
98 std::list<boost::shared_ptr<Cinema> > cinemas () const {
102 /** @param n New number of local encoding threads */
103 void set_num_local_encoding_threads (int n) {
104 _num_local_encoding_threads = n;
107 void set_default_directory (std::string d) {
108 _default_directory = d;
111 /** @param p New server port */
112 void set_server_port (int p) {
116 /** @param s New list of servers */
117 void set_servers (std::vector<ServerDescription*> s) {
121 void set_reference_scaler (Scaler const * s) {
122 _reference_scaler = s;
125 void set_reference_filters (std::vector<Filter const *> const & f) {
126 _reference_filters = f;
129 /** @param i IP address of a TMS that we can copy DCPs to */
130 void set_tms_ip (std::string i) {
134 /** @param p Path on a TMS that we should write DCPs to */
135 void set_tms_path (std::string p) {
139 /** @param u User name to log into the TMS with */
140 void set_tms_user (std::string u) {
144 /** @param p Password to log into the TMS with */
145 void set_tms_password (std::string p) {
149 void add_cinema (boost::shared_ptr<Cinema> c) {
150 _cinemas.push_back (c);
153 void remove_cinema (boost::shared_ptr<Cinema> c) {
159 std::string crypt_chain_directory () const;
161 static Config* instance ();
165 std::string read_file () const;
166 std::string write_file () const;
168 /** number of threads to use for J2K encoding on the local machine */
169 int _num_local_encoding_threads;
170 /** default directory to put new films in */
171 std::string _default_directory;
172 /** port to use for J2K encoding servers */
175 /** J2K encoding servers to use */
176 std::vector<ServerDescription *> _servers;
177 /** Scaler to use for the "A" part of A/B comparisons */
178 Scaler const * _reference_scaler;
179 /** Filters to use for the "A" part of A/B comparisons */
180 std::vector<Filter const *> _reference_filters;
181 /** The IP address of a TMS that we can copy DCPs to */
183 /** The path on a TMS that we should write DCPs to */
184 std::string _tms_path;
185 /** User name to log into the TMS with */
186 std::string _tms_user;
187 /** Password to log into the TMS with */
188 std::string _tms_password;
189 /** Our sound processor */
190 SoundProcessor const * _sound_processor;
192 std::list<boost::shared_ptr<Cinema> > _cinemas;
194 /** Singleton instance, or 0 */
195 static Config* _instance;