blob: 011ca716faef1839a1227daaa14bd74ad50cab7b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
|
/*
Copyright (C) 2012 Carl Hetherington <cth@carlh.net>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
/** @file src/config.h
* @brief Class holding configuration.
*/
#ifndef DVDOMATIC_CONFIG_H
#define DVDOMATIC_CONFIG_H
#include <vector>
#include <boost/shared_ptr.hpp>
#include <boost/signals2.hpp>
#include "dci_metadata.h"
class ServerDescription;
class Scaler;
class Filter;
class SoundProcessor;
/** @class Config
* @brief A singleton class holding configuration.
*/
class Config
{
public:
/** @return number of threads to use for J2K encoding on the local machine */
int num_local_encoding_threads () const {
return _num_local_encoding_threads;
}
std::string default_directory () const {
return _default_directory;
}
std::string default_directory_or (std::string a) const;
/** @return port to use for J2K encoding servers */
int server_port () const {
return _server_port;
}
/** @return J2K encoding servers to use */
std::vector<ServerDescription*> servers () const {
return _servers;
}
Scaler const * reference_scaler () const {
return _reference_scaler;
}
std::vector<Filter const *> reference_filters () const {
return _reference_filters;
}
/** @return The IP address of a TMS that we can copy DCPs to */
std::string tms_ip () const {
return _tms_ip;
}
/** @return The path on a TMS that we should write DCPs to */
std::string tms_path () const {
return _tms_path;
}
/** @return User name to log into the TMS with */
std::string tms_user () const {
return _tms_user;
}
/** @return Password to log into the TMS with */
std::string tms_password () const {
return _tms_password;
}
/** @return The sound processor that we are using */
SoundProcessor const * sound_processor () const {
return _sound_processor;
}
std::list<int> allowed_dcp_frame_rates () const {
return _allowed_dcp_frame_rates;
}
DCIMetadata default_dci_metadata () const {
return _default_dci_metadata;
}
boost::optional<std::string> language () const {
return _language;
}
/** @param n New number of local encoding threads */
void set_num_local_encoding_threads (int n) {
_num_local_encoding_threads = n;
}
void set_default_directory (std::string d) {
_default_directory = d;
}
/** @param p New server port */
void set_server_port (int p) {
_server_port = p;
}
/** @param s New list of servers */
void set_servers (std::vector<ServerDescription*> s) {
_servers = s;
}
void set_reference_scaler (Scaler const * s) {
_reference_scaler = s;
}
void set_reference_filters (std::vector<Filter const *> const & f) {
_reference_filters = f;
}
/** @param i IP address of a TMS that we can copy DCPs to */
void set_tms_ip (std::string i) {
_tms_ip = i;
}
/** @param p Path on a TMS that we should write DCPs to */
void set_tms_path (std::string p) {
_tms_path = p;
}
/** @param u User name to log into the TMS with */
void set_tms_user (std::string u) {
_tms_user = u;
}
/** @param p Password to log into the TMS with */
void set_tms_password (std::string p) {
_tms_password = p;
}
void set_allowed_dcp_frame_rates (std::list<int> const & r) {
_allowed_dcp_frame_rates = r;
}
void set_default_dci_metadata (DCIMetadata d) {
_default_dci_metadata = d;
}
void set_language (std::string l) {
_language = l;
}
void unset_language () {
_language = boost::none;
}
void write () const;
static Config* instance ();
static void drop ();
private:
Config ();
std::string file () const;
/** number of threads to use for J2K encoding on the local machine */
int _num_local_encoding_threads;
/** default directory to put new films in */
std::string _default_directory;
/** port to use for J2K encoding servers */
int _server_port;
/** J2K encoding servers to use */
std::vector<ServerDescription *> _servers;
/** Scaler to use for the "A" part of A/B comparisons */
Scaler const * _reference_scaler;
/** Filters to use for the "A" part of A/B comparisons */
std::vector<Filter const *> _reference_filters;
/** The IP address of a TMS that we can copy DCPs to */
std::string _tms_ip;
/** The path on a TMS that we should write DCPs to */
std::string _tms_path;
/** User name to log into the TMS with */
std::string _tms_user;
/** Password to log into the TMS with */
std::string _tms_password;
/** Our sound processor */
SoundProcessor const * _sound_processor;
std::list<int> _allowed_dcp_frame_rates;
/** Default DCI metadata for newly-created Films */
DCIMetadata _default_dci_metadata;
boost::optional<std::string> _language;
/** Singleton instance, or 0 */
static Config* _instance;
};
#endif
|