X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fscreen_kdm.cc;h=3515af8a6644f1b6ed70377e1474652577b0fc88;hb=35992b8f2c9d58a08d1ecb08a39d7c99362fd2c0;hp=129e64aeee5b7e88de8bcccd512cdfa8b98c796d;hpb=1d022220899c63e2cae0a2a9a81f6c6db955a23d;p=dcpomatic.git diff --git a/src/lib/screen_kdm.cc b/src/lib/screen_kdm.cc index 129e64aee..3515af8a6 100644 --- a/src/lib/screen_kdm.cc +++ b/src/lib/screen_kdm.cc @@ -25,6 +25,7 @@ #include using std::string; +using std::cout; using std::list; using boost::shared_ptr; @@ -34,14 +35,42 @@ operator== (ScreenKDM const & a, ScreenKDM const & b) return a.screen == b.screen && a.kdm == b.kdm; } -void -ScreenKDM::write_files (list screen_kdms, boost::filesystem::path directory, dcp::NameFormat name_format, dcp::NameFormat::Map name_values) +int +ScreenKDM::write_files ( + list screen_kdms, + boost::filesystem::path directory, + dcp::NameFormat name_format, + dcp::NameFormat::Map name_values, + boost::function confirm_overwrite + ) { + int written = 0; + + if (directory == "-") { + /* Write KDMs to the stdout */ + BOOST_FOREACH (ScreenKDM const & i, screen_kdms) { + cout << i.kdm.as_xml (); + ++written; + } + + return written; + } + + if (!boost::filesystem::exists (directory)) { + boost::filesystem::create_directories (directory); + } + /* Write KDMs to the specified directory */ BOOST_FOREACH (ScreenKDM const & i, screen_kdms) { name_values['c'] = i.screen->cinema->name; name_values['s'] = i.screen->name; - boost::filesystem::path out = directory / (name_format.get(name_values) + ".xml"); - i.kdm.as_xml (out); + name_values['i'] = i.kdm.id (); + boost::filesystem::path out = directory / (name_format.get(name_values, ".xml")); + if (!boost::filesystem::exists (out) || confirm_overwrite (out)) { + i.kdm.as_xml (out); + ++written; + } } + + return written; }