X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fscreen_kdm.cc;h=f9a3fa36eb2720fa0d04d597486248ecdb68a338;hb=08f96200aacf9f91ef3e3f5b80224a5b2437f279;hp=bbe539801dbdb400ab0e15e57c79ac2d4c2dc5d0;hpb=2852855f19fadb6d7e43282e545a0bcaedc1a3f7;p=dcpomatic.git diff --git a/src/lib/screen_kdm.cc b/src/lib/screen_kdm.cc index bbe539801..f9a3fa36e 100644 --- a/src/lib/screen_kdm.cc +++ b/src/lib/screen_kdm.cc @@ -1,19 +1,20 @@ /* - Copyright (C) 2013-2015 Carl Hetherington + Copyright (C) 2013-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ @@ -24,27 +25,46 @@ #include using std::string; +using std::cout; using std::list; using boost::shared_ptr; -bool -operator== (ScreenKDM const & a, ScreenKDM const & b) +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 a.screen == b.screen && a.kdm == b.kdm; -} + int written = 0; -string -ScreenKDM::filename (string film_name) const -{ - return tidy_for_filename (film_name) + "_" + tidy_for_filename (screen->cinema->name) + "_" + tidy_for_filename (screen->name) + ".kdm.xml"; -} + if (directory == "-") { + /* Write KDMs to the stdout */ + BOOST_FOREACH (shared_ptr i, screen_kdms) { + cout << i->kdm_as_xml (); + ++written; + } + + return written; + } + + if (!boost::filesystem::exists (directory)) { + boost::filesystem::create_directories (directory); + } -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); + BOOST_FOREACH (shared_ptr i, screen_kdms) { + name_values['c'] = i->screen->cinema ? i->screen->cinema->name : ""; + name_values['s'] = i->screen->name; + name_values['i'] = i->kdm_id (); + boost::filesystem::path out = directory / careful_string_filter(name_format.get(name_values, ".xml")); + if (!boost::filesystem::exists (out) || confirm_overwrite (out)) { + i->kdm_as_xml (out); + ++written; + } } + + return written; }