summaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2018-09-25 00:47:49 +0100
committerCarl Hetherington <cth@carlh.net>2018-09-25 00:47:49 +0100
commit8414829693900c3d6362a4f15d677bb7e1462c3e (patch)
tree6245b62b23fccdf1f0abcb3b42a0743179297b9f /src/lib
parentf1b928749ca8082ca5929d6042c5d1e6a89ef489 (diff)
Add KDM directory configuration in player.
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/config.cc5
-rw-r--r--src/lib/config.h17
2 files changed, 22 insertions, 0 deletions
diff --git a/src/lib/config.cc b/src/lib/config.cc
index 54716d849..5e953382d 100644
--- a/src/lib/config.cc
+++ b/src/lib/config.cc
@@ -168,6 +168,7 @@ Config::set_defaults ()
_respect_kdm_validity_periods = true;
_player_log_file = boost::none;
_player_dcp_directory = boost::none;
+ _player_kdm_directory = boost::none;
_allowed_dcp_frame_rates.clear ();
_allowed_dcp_frame_rates.push_back (24);
@@ -499,6 +500,7 @@ try
_respect_kdm_validity_periods = f.optional_bool_child("RespectKDMValidityPeriods").get_value_or(true);
_player_log_file = f.optional_string_child("PlayerLogFile");
_player_dcp_directory = f.optional_string_child("PlayerDCPDirectory");
+ _player_kdm_directory = f.optional_string_child("PlayerKDMDirectory");
/* Replace any cinemas from config.xml with those from the configured file */
if (boost::filesystem::exists (_cinemas_file)) {
@@ -893,6 +895,9 @@ Config::write_config () const
if (_player_dcp_directory) {
root->add_child("PlayerDCPDirectory")->add_child_text(_player_dcp_directory->string());
}
+ if (_player_kdm_directory) {
+ root->add_child("PlayerKDMDirectory")->add_child_text(_player_kdm_directory->string());
+ }
try {
doc.write_to_file_formatted(config_file().string());
diff --git a/src/lib/config.h b/src/lib/config.h
index 814f078f0..60e85c5f3 100644
--- a/src/lib/config.h
+++ b/src/lib/config.h
@@ -486,6 +486,10 @@ public:
return _player_dcp_directory;
}
+ boost::optional<boost::filesystem::path> player_kdm_directory () const {
+ return _player_kdm_directory;
+ }
+
/* SET (mostly) */
void set_master_encoding_threads (int n) {
@@ -920,6 +924,18 @@ public:
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 ();
+ }
+
void changed (Property p = OTHER);
boost::signals2::signal<void (Property)> Changed;
/** Emitted if read() failed on an existing Config file. There is nothing
@@ -1111,6 +1127,7 @@ private:
for playback.
*/
boost::optional<boost::filesystem::path> _player_dcp_directory;
+ boost::optional<boost::filesystem::path> _player_kdm_directory;
static int const _current_version;