X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fscreen.cc;h=504504c8c8cf34e23c0003e87f4705d87103b016;hp=8e1e83e36697f0e802d05fafc8b1fd2605cff529;hb=da44da6f31f97d39ca91c35955e573e76371f2c2;hpb=a5d004b0773f633401528392fc28e66d70e13ac8 diff --git a/src/lib/screen.cc b/src/lib/screen.cc index 8e1e83e36..504504c8c 100644 --- a/src/lib/screen.cc +++ b/src/lib/screen.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2020 Carl Hetherington + Copyright (C) 2013-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,6 +18,7 @@ */ + #include "screen.h" #include "kdm_with_metadata.h" #include "film.h" @@ -26,13 +27,16 @@ #include #include -using std::string; -using std::vector; + using std::list; +using std::make_shared; using std::shared_ptr; +using std::string; +using std::vector; using boost::optional; using namespace dcpomatic; + Screen::Screen (cxml::ConstNodePtr node) : KDMRecipient (node) { @@ -45,6 +49,7 @@ Screen::Screen (cxml::ConstNodePtr node) } } + void Screen::as_xml (xmlpp::Element* parent) const { @@ -54,6 +59,7 @@ Screen::as_xml (xmlpp::Element* parent) const } } + vector Screen::trusted_device_thumbprints () const { @@ -78,14 +84,14 @@ kdm_for_screen ( ) { if (!screen->recipient) { - return KDMWithMetadataPtr(); + return {}; } - shared_ptr cinema = screen->cinema; + auto cinema = screen->cinema; dcp::LocalTime const begin(valid_from, cinema ? cinema->utc_offset_hour() : 0, cinema ? cinema->utc_offset_minute() : 0); dcp::LocalTime const end (valid_to, cinema ? cinema->utc_offset_hour() : 0, cinema ? cinema->utc_offset_minute() : 0); - dcp::EncryptedKDM const kdm = film->make_kdm ( + auto const kdm = film->make_kdm ( screen->recipient.get(), screen->trusted_device_thumbprints(), cpl, @@ -106,6 +112,6 @@ kdm_for_screen ( name_values['e'] = end.date() + " " + end.time_of_day(true, false); name_values['i'] = kdm.cpl_id(); - return KDMWithMetadataPtr(new KDMWithMetadata(name_values, cinema.get(), cinema ? cinema->emails : list(), kdm)); + return make_shared(name_values, cinema.get(), cinema ? cinema->emails : list(), kdm); }