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>
30 #include <libdcp/metadata.h>
31 #include "dci_metadata.h"
33 class ServerDescription;
41 * @brief A singleton class holding configuration.
47 /** @return number of threads to use for J2K encoding on the local machine */
48 int num_local_encoding_threads () const {
49 return _num_local_encoding_threads;
52 std::string default_directory () const {
53 return _default_directory;
56 std::string default_directory_or (std::string a) const;
58 /** @return port to use for J2K encoding servers */
59 int server_port () const {
63 /** @return J2K encoding servers to use */
64 std::vector<ServerDescription*> servers () const {
68 Scaler const * reference_scaler () const {
69 return _reference_scaler;
72 std::vector<Filter const *> reference_filters () const {
73 return _reference_filters;
76 /** @return The IP address of a TMS that we can copy DCPs to */
77 std::string tms_ip () const {
81 /** @return The path on a TMS that we should write DCPs to */
82 std::string tms_path () const {
86 /** @return User name to log into the TMS with */
87 std::string tms_user () const {
91 /** @return Password to log into the TMS with */
92 std::string tms_password () const {
96 /** @return The sound processor that we are using */
97 SoundProcessor const * sound_processor () const {
98 return _sound_processor;
101 std::list<int> allowed_dcp_frame_rates () const {
102 return _allowed_dcp_frame_rates;
105 DCIMetadata default_dci_metadata () const {
106 return _default_dci_metadata;
109 boost::optional<std::string> language () const {
113 Format const * default_format () const {
114 return _default_format;
117 DCPContentType const * default_dcp_content_type () const {
118 return _default_dcp_content_type;
121 libdcp::XMLMetadata dcp_metadata () const {
122 return _dcp_metadata;
125 /** @param n New number of local encoding threads */
126 void set_num_local_encoding_threads (int n) {
127 _num_local_encoding_threads = n;
130 void set_default_directory (std::string d) {
131 _default_directory = d;
134 /** @param p New server port */
135 void set_server_port (int p) {
139 /** @param s New list of servers */
140 void set_servers (std::vector<ServerDescription*> s) {
144 void set_reference_scaler (Scaler const * s) {
145 _reference_scaler = s;
148 void set_reference_filters (std::vector<Filter const *> const & f) {
149 _reference_filters = f;
152 /** @param i IP address of a TMS that we can copy DCPs to */
153 void set_tms_ip (std::string i) {
157 /** @param p Path on a TMS that we should write DCPs to */
158 void set_tms_path (std::string p) {
162 /** @param u User name to log into the TMS with */
163 void set_tms_user (std::string u) {
167 /** @param p Password to log into the TMS with */
168 void set_tms_password (std::string p) {
172 void set_allowed_dcp_frame_rates (std::list<int> const & r) {
173 _allowed_dcp_frame_rates = r;
176 void set_default_dci_metadata (DCIMetadata d) {
177 _default_dci_metadata = d;
180 void set_language (std::string l) {
184 void unset_language () {
185 _language = boost::none;
188 void set_default_format (Format const * f) {
192 void set_default_dcp_content_type (DCPContentType const * t) {
193 _default_dcp_content_type = t;
196 void set_dcp_metadata (libdcp::XMLMetadata m) {
202 static Config* instance ();
207 std::string file () const;
209 /** number of threads to use for J2K encoding on the local machine */
210 int _num_local_encoding_threads;
211 /** default directory to put new films in */
212 std::string _default_directory;
213 /** port to use for J2K encoding servers */
216 /** J2K encoding servers to use */
217 std::vector<ServerDescription *> _servers;
218 /** Scaler to use for the "A" part of A/B comparisons */
219 Scaler const * _reference_scaler;
220 /** Filters to use for the "A" part of A/B comparisons */
221 std::vector<Filter const *> _reference_filters;
222 /** The IP address of a TMS that we can copy DCPs to */
224 /** The path on a TMS that we should write DCPs to */
225 std::string _tms_path;
226 /** User name to log into the TMS with */
227 std::string _tms_user;
228 /** Password to log into the TMS with */
229 std::string _tms_password;
230 /** Our sound processor */
231 SoundProcessor const * _sound_processor;
232 std::list<int> _allowed_dcp_frame_rates;
233 /** Default DCI metadata for newly-created Films */
234 DCIMetadata _default_dci_metadata;
235 boost::optional<std::string> _language;
236 Format const * _default_format;
237 DCPContentType const * _default_dcp_content_type;
238 libdcp::XMLMetadata _dcp_metadata;
240 /** Singleton instance, or 0 */
241 static Config* _instance;