SOUND,
SOUND_OUTPUT,
INTERFACE_COMPLEXITY,
+ PLAYER_DCP_DIRECTORY,
+#ifdef DCPOMATIC_VARIANT_SWAROOP
+ PLAYER_BACKGROUND_IMAGE,
+ PLAYER_WATERMARK,
+#endif
OTHER
};
return _player_mode;
}
+ int image_display () const {
+ return _image_display;
+ }
+
+ bool respect_kdm_validity_periods () const {
+ return _respect_kdm_validity_periods;
+ }
+
+ boost::optional<boost::filesystem::path> player_log_file () const {
+ return _player_log_file;
+ }
+
+ boost::optional<boost::filesystem::path> player_dcp_directory () const {
+ return _player_dcp_directory;
+ }
+
+ boost::optional<boost::filesystem::path> player_kdm_directory () const {
+ return _player_kdm_directory;
+ }
+
+#ifdef DCPOMATIC_VARIANT_SWAROOP
+ boost::optional<boost::filesystem::path> player_background_image () const {
+ return _player_background_image;
+ }
+
+ std::string kdm_server_url () const {
+ return _kdm_server_url;
+ }
+
+ boost::optional<boost::filesystem::path> player_watermark () const {
+ return _player_watermark;
+ }
+#endif
+
/* SET (mostly) */
void set_master_encoding_threads (int n) {
maybe_set (_player_mode, m);
}
+ void set_image_display (int n) {
+ maybe_set (_image_display, n);
+ }
+
+ void set_respect_kdm_validity_periods (bool r) {
+ maybe_set (_respect_kdm_validity_periods, r);
+ }
+
+ void set_player_log_file (boost::filesystem::path p) {
+ maybe_set (_player_log_file, p);
+ }
+
+ void unset_player_log_file () {
+ if (!_player_log_file) {
+ return;
+ }
+ _player_log_file = boost::none;
+ changed ();
+ }
+
+ void set_player_dcp_directory (boost::filesystem::path p) {
+ maybe_set (_player_dcp_directory, p, PLAYER_DCP_DIRECTORY);
+ }
+
+ void unset_player_dcp_directory () {
+ if (!_player_dcp_directory) {
+ return;
+ }
+ _player_dcp_directory = boost::none;
+ changed (PLAYER_DCP_DIRECTORY);
+ }
+
+ void set_player_kdm_directory (boost::filesystem::path p) {
+ maybe_set (_player_kdm_directory, p);
+ }
+
+ void unset_player_kdm_directory () {
+ if (!_player_kdm_directory) {
+ return;
+ }
+ _player_kdm_directory = boost::none;
+ changed ();
+ }
+
+#ifdef DCPOMATIC_VARIANT_SWAROOP
+ void set_player_background_image (boost::filesystem::path p) {
+ maybe_set (_player_background_image, p, PLAYER_BACKGROUND_IMAGE);
+ }
+
+ void unset_player_background_image () {
+ if (!_player_background_image) {
+ return;
+ }
+ _player_background_image = boost::none;
+ changed (PLAYER_BACKGROUND_IMAGE);
+ }
+
+ void set_kdm_server_url (std::string s) {
+ maybe_set (_kdm_server_url, s);
+ }
+
+ void set_player_watermark (boost::filesystem::path p) {
+ maybe_set (_player_watermark, p, PLAYER_WATERMARK);
+ }
+
+ void unset_player_watermark () {
+ if (!_player_watermark) {
+ return;
+ }
+ _player_watermark = boost::none;
+ changed (PLAYER_WATERMARK);
+ }
+#endif
+
void changed (Property p = OTHER);
boost::signals2::signal<void (Property)> Changed;
/** Emitted if read() failed on an existing Config file. There is nothing
void write_cinemas () const;
void link (boost::filesystem::path new_file) const;
void copy_and_link (boost::filesystem::path new_file) const;
+ bool have_write_permission () const;
void save_template (boost::shared_ptr<const Film> film, std::string name) const;
bool existing_template (std::string name) const;
boost::optional<std::string> _gdc_password;
Interface _interface_complexity;
PlayerMode _player_mode;
+ int _image_display;
+ bool _respect_kdm_validity_periods;
+ boost::optional<boost::filesystem::path> _player_log_file;
+ /** A directory containing DCPs whose contents are presented to the user
+ in the dual-screen player mode. DCPs on the list can be loaded
+ for playback.
+ */
+ boost::optional<boost::filesystem::path> _player_dcp_directory;
+ boost::optional<boost::filesystem::path> _player_kdm_directory;
+#ifdef DCPOMATIC_VARIANT_SWAROOP
+ boost::optional<boost::filesystem::path> _player_background_image;
+ std::string _kdm_server_url;
+ boost::optional<boost::filesystem::path> _player_watermark;
+#endif
static int const _current_version;