From 3e19bf7df70928442644b225c876d51f9fa413da Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Tue, 25 Sep 2018 01:28:37 +0100 Subject: Fix log display and auto-load KDMs from the configured directory. --- src/tools/dcpomatic_player.cc | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'src/tools/dcpomatic_player.cc') diff --git a/src/tools/dcpomatic_player.cc b/src/tools/dcpomatic_player.cc index 07583ccaf..db9b21d92 100644 --- a/src/tools/dcpomatic_player.cc +++ b/src/tools/dcpomatic_player.cc @@ -315,6 +315,27 @@ public: return; } + /* The DCP has been examined and loaded */ + + optional kdm_dir = Config::instance()->player_kdm_directory(); + if (dcp->needs_kdm() && kdm_dir) { + /* Look for a KDM */ + using namespace boost::filesystem; + for (directory_iterator i = directory_iterator(*kdm_dir); i != directory_iterator(); ++i) { + if (file_size(i->path()) < MAX_KDM_SIZE) { + try { + dcp::EncryptedKDM kdm(dcp::file_to_string(i->path())); + if (kdm.cpl_id() == dcp->cpl()) { + dcp->add_kdm (kdm); + dcp->examine (shared_ptr()); + } + } catch (...) { + /* Hey well */ + } + } + } + } + setup_from_dcp (dcp); if (dcp->three_d()) { -- cgit v1.2.3