name_values['c'] = cinema->name;
- BOOST_FOREACH (shared_ptr<KDMWithMetadata> i, screen_kdms) {
+ BOOST_FOREACH (KDMWithMetadataPtr i, screen_kdms) {
name_values['s'] = i->screen->name;
name_values['i'] = i->kdm_id ();
string const name = careful_string_filter(name_format.get(name_values, ".xml"));
* CinemaKDM contains the KDMs for its cinema.
*/
list<CinemaKDMs>
-CinemaKDMs::collect (list<shared_ptr<KDMWithMetadata> > screen_kdms)
+CinemaKDMs::collect (list<KDMWithMetadataPtr> screen_kdms)
{
list<CinemaKDMs> cinema_kdms;
CinemaKDMs ck;
- list<shared_ptr<KDMWithMetadata> >::iterator i = screen_kdms.begin ();
+ list<KDMWithMetadataPtr>::iterator i = screen_kdms.begin ();
ck.cinema = (*i)->screen->cinema;
ck.screen_kdms.push_back (*i);
- list<shared_ptr<KDMWithMetadata> >::iterator j = i;
+ list<KDMWithMetadataPtr>::iterator j = i;
++i;
screen_kdms.remove (*j);
while (i != screen_kdms.end ()) {
if ((*i)->screen->cinema == ck.cinema) {
ck.screen_kdms.push_back (*i);
- list<shared_ptr<KDMWithMetadata> >::iterator j = i;
+ list<KDMWithMetadataPtr>::iterator j = i;
++i;
screen_kdms.remove (*j);
} else {
path /= container_name_format.get(name_values, "");
if (!boost::filesystem::exists (path) || confirm_overwrite (path)) {
boost::filesystem::create_directories (path);
- KDMWithMetadata::write_files (i.screen_kdms, path, filename_format, name_values, confirm_overwrite);
+ write_files (i.screen_kdms, path, filename_format, name_values, confirm_overwrite);
}
written += i.screen_kdms.size();
}
boost::algorithm::replace_all (body, "$CINEMA_NAME", i.cinema->name);
string screens;
- BOOST_FOREACH (shared_ptr<KDMWithMetadata> j, i.screen_kdms) {
+ BOOST_FOREACH (KDMWithMetadataPtr j, i.screen_kdms) {
screens += j->screen->name + ", ";
}
boost::algorithm::replace_all (body, "$SCREENS", screens.substr (0, screens.length() - 2));
public:
void make_zip_file (boost::filesystem::path zip_file, dcp::NameFormat name_format, dcp::NameFormat::Map name_values) const;
- static std::list<CinemaKDMs> collect (std::list<boost::shared_ptr<KDMWithMetadata> > kdms);
+ static std::list<CinemaKDMs> collect (std::list<KDMWithMetadataPtr > kdms);
static int write_directories (
std::list<CinemaKDMs> cinema_kdms,
);
boost::shared_ptr<Cinema> cinema;
- std::list<boost::shared_ptr<KDMWithMetadata> > screen_kdms;
+ std::list<KDMWithMetadataPtr > screen_kdms;
};
using boost::shared_ptr;
int
-KDMWithMetadata::write_files (
- list<shared_ptr<KDMWithMetadata> > screen_kdms,
+write_files (
+ list<KDMWithMetadataPtr> screen_kdms,
boost::filesystem::path directory,
dcp::NameFormat name_format,
dcp::NameFormat::Map name_values,
if (directory == "-") {
/* Write KDMs to the stdout */
- BOOST_FOREACH (shared_ptr<KDMWithMetadata> i, screen_kdms) {
+ BOOST_FOREACH (KDMWithMetadataPtr i, screen_kdms) {
cout << i->kdm_as_xml ();
++written;
}
}
/* Write KDMs to the specified directory */
- BOOST_FOREACH (shared_ptr<KDMWithMetadata> i, screen_kdms) {
+ BOOST_FOREACH (KDMWithMetadataPtr 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 ();
virtual void kdm_as_xml (boost::filesystem::path out) const = 0;
virtual std::string kdm_id () const = 0;
- static int write_files (
- std::list<boost::shared_ptr<KDMWithMetadata> > screen_kdms, boost::filesystem::path directory,
- dcp::NameFormat name_format, dcp::NameFormat::Map name_values,
- boost::function<bool (boost::filesystem::path)> confirm_overwrite
- );
-
boost::shared_ptr<dcpomatic::Screen> screen;
};
+
+typedef boost::shared_ptr<KDMWithMetadata> KDMWithMetadataPtr;
+
+
+int write_files (
+ std::list<KDMWithMetadataPtr> screen_kdms, boost::filesystem::path directory,
+ dcp::NameFormat name_format, dcp::NameFormat::Map name_values,
+ boost::function<bool (boost::filesystem::path)> confirm_overwrite
+ );
+
+
class DCPKDMWithMetadata : public KDMWithMetadata
{
public:
return;
}
- list<shared_ptr<KDMWithMetadata> > screen_kdms;
+ list<KDMWithMetadataPtr> screen_kdms;
string title;
#ifdef DCPOMATIC_VARIANT_SWAROOP
/* Encrypt */
screen_kdms.push_back (
- shared_ptr<KDMWithMetadata>(
+ KDMWithMetadataPtr(
new ECinemaKDMWithMetadata(i, kdm.encrypt(i->recipient.get()))
)
);
/* Encrypt */
screen_kdms.push_back (
- shared_ptr<KDMWithMetadata>(
+ KDMWithMetadataPtr(
new DCPKDMWithMetadata(
i,
kdm.encrypt(
void
write_files (
- list<shared_ptr<KDMWithMetadata> > screen_kdms,
+ list<KDMWithMetadataPtr> screen_kdms,
bool zip,
boost::filesystem::path output,
dcp::NameFormat container_name_format,
cout << "Wrote " << N << " ZIP files to " << output << "\n";
}
} else {
- int const N = KDMWithMetadata::write_files (
+ int const N = write_files (
screen_kdms, output, filename_format, values,
bind (&always_overwrite)
);
values['e'] = dcp::LocalTime(valid_to).date() + " " + dcp::LocalTime(valid_to).time_of_day(true, false);
try {
- list<shared_ptr<KDMWithMetadata> > kdms;
+ list<KDMWithMetadataPtr> kdms;
BOOST_FOREACH (shared_ptr<Screen> i, screens) {
if (i->recipient) {
disable_forensic_marking_audio
);
- kdms.push_back (shared_ptr<KDMWithMetadata>(new DCPKDMWithMetadata(i, kdm)));
+ kdms.push_back (KDMWithMetadataPtr(new DCPKDMWithMetadata(i, kdm)));
}
}
values['e'] = dcp::LocalTime(valid_to).date() + " " + dcp::LocalTime(valid_to).time_of_day(true, false);
try {
- list<shared_ptr<KDMWithMetadata> > screen_kdms;
+ list<KDMWithMetadataPtr> screen_kdms;
BOOST_FOREACH (shared_ptr<Screen> i, screens) {
if (!i->recipient) {
continue;
}
screen_kdms.push_back (
- shared_ptr<KDMWithMetadata>(
+ KDMWithMetadataPtr(
new DCPKDMWithMetadata(
i,
kdm_from_dkdm(
shared_ptr<const Film> film = _film.lock ();
DCPOMATIC_ASSERT (film);
- list<shared_ptr<KDMWithMetadata> > screen_kdms;
+ list<KDMWithMetadataPtr> screen_kdms;
try {
/* Start off by enabling forensic marking for all */
optional<int> for_audio;
for_audio
);
- screen_kdms.push_back (shared_ptr<KDMWithMetadata>(new DCPKDMWithMetadata(i, kdm)));
+ screen_kdms.push_back (KDMWithMetadataPtr(new DCPKDMWithMetadata(i, kdm)));
}
}
pair<shared_ptr<Job>, int>
KDMOutputPanel::make (
- list<shared_ptr<KDMWithMetadata> > screen_kdms, string name, KDMTimingPanel* timing, function<bool (boost::filesystem::path)> confirm_overwrite
+ list<KDMWithMetadataPtr> screen_kdms, string name, KDMTimingPanel* timing, function<bool (boost::filesystem::path)> confirm_overwrite
)
{
list<CinemaKDMs> const cinema_kdms = CinemaKDMs::collect (screen_kdms);
if (_write_to->GetValue()) {
if (_write_flat->GetValue()) {
- written = KDMWithMetadata::write_files (
+ written = write_files (
screen_kdms,
directory(),
_filename_format->get(),
}
std::pair<boost::shared_ptr<Job>, int> make (
- std::list<boost::shared_ptr<KDMWithMetadata> > screen_kdms,
+ std::list<KDMWithMetadataPtr > screen_kdms,
std::string name,
KDMTimingPanel* timing,
boost::function<bool (boost::filesystem::path)> confirm_overwrite