X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Flib%2Fscreen_kdm.cc;h=5d8409ea746b6e30ff1cf4667f4d20f6e0aecb9e;hb=1460bda6f80b6529e31a1a63029dc0ec5f7d0ae8;hp=5cdf1c77bd420464136301753dd20046554de715;hpb=3828baf56467224f5d44049bf1e7a7ed11f43a05;p=dcpomatic.git diff --git a/src/lib/screen_kdm.cc b/src/lib/screen_kdm.cc index 5cdf1c77b..5d8409ea7 100644 --- a/src/lib/screen_kdm.cc +++ b/src/lib/screen_kdm.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2015 Carl Hetherington + Copyright (C) 2013-2016 Carl Hetherington This file is part of DCP-o-matic. @@ -34,18 +34,27 @@ operator== (ScreenKDM const & a, ScreenKDM const & b) return a.screen == b.screen && a.kdm == b.kdm; } -string -ScreenKDM::filename (string film_name) const +int +ScreenKDM::write_files ( + list screen_kdms, + boost::filesystem::path directory, + dcp::NameFormat name_format, + dcp::NameFormat::Map name_values, + boost::function confirm_overwrite + ) { - return tidy_for_filename (film_name) + "_" + tidy_for_filename (screen->cinema->name) + "_" + tidy_for_filename (screen->name) + ".kdm.xml"; -} + int written = 0; -void -ScreenKDM::write_files (string film_name, list screen_kdms, boost::filesystem::path directory) -{ /* Write KDMs to the specified directory */ BOOST_FOREACH (ScreenKDM const & i, screen_kdms) { - boost::filesystem::path out = directory / i.filename(film_name); - i.kdm.as_xml (out); + name_values['c'] = i.screen->cinema->name; + name_values['s'] = i.screen->name; + 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; }