X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fkdm_with_metadata.h;h=fbeeffbc13403614ed5c1a7439975b5c16edefd9;hp=b6bec1c4c200693b5932619e9f0b7497ef9aa2c2;hb=9f125fddff88bf62d36381f9d3f09e5240b033d5;hpb=47e29203daec51d313ed8ab8ef759752bce18d45 diff --git a/src/lib/kdm_with_metadata.h b/src/lib/kdm_with_metadata.h index b6bec1c4c..fbeeffbc1 100644 --- a/src/lib/kdm_with_metadata.h +++ b/src/lib/kdm_with_metadata.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2019 Carl Hetherington + Copyright (C) 2013-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,31 +18,35 @@ */ + #ifndef DCPOMATIC_KDM_WITH_METADATA_H #define DCPOMATIC_KDM_WITH_METADATA_H -#ifdef DCPOMATIC_VARIANT_SWAROOP -#include "encrypted_ecinema_kdm.h" -#endif + #include #include -#include + class Cinema; + class KDMWithMetadata { public: - KDMWithMetadata (dcp::NameFormat::Map const& name_values, void const* group, std::list emails) + KDMWithMetadata(dcp::NameFormat::Map const& name_values, void const* group, std::vector emails, dcp::EncryptedKDM kdm) : _name_values (name_values) , _group (group) , _emails (emails) + , _kdm (kdm) {} - virtual ~KDMWithMetadata () {} + std::string kdm_as_xml () const { + return _kdm.as_xml (); + } - virtual std::string kdm_as_xml () const = 0; - virtual void kdm_as_xml (boost::filesystem::path out) const = 0; + void kdm_as_xml (boost::filesystem::path out) const { + return _kdm.as_xml (out); + } dcp::NameFormat::Map const& name_values () const { return _name_values; @@ -54,82 +58,58 @@ public: return _group; } - std::list emails () const { + std::vector emails() const { return _emails; } private: dcp::NameFormat::Map _name_values; void const* _group; - std::list _emails; + std::vector _emails; + dcp::EncryptedKDM _kdm; }; -typedef boost::shared_ptr KDMWithMetadataPtr; +typedef std::shared_ptr KDMWithMetadataPtr; int write_files ( std::list screen_kdms, boost::filesystem::path directory, - dcp::NameFormat name_format, boost::function confirm_overwrite + dcp::NameFormat name_format, std::function confirm_overwrite ); void make_zip_file (std::list kdms, boost::filesystem::path zip_file, dcp::NameFormat name_format); -std::list > collect (std::list kdms); +std::list> collect (std::list kdms); int write_directories ( - std::list > kdms, + std::list> kdms, boost::filesystem::path directory, dcp::NameFormat container_name_format, dcp::NameFormat filename_format, - boost::function confirm_overwrite + std::function confirm_overwrite ); int write_zip_files ( - std::list > kdms, + std::list> kdms, boost::filesystem::path directory, dcp::NameFormat container_name_format, dcp::NameFormat filename_format, - boost::function confirm_overwrite + std::function confirm_overwrite ); -void email ( - std::list > kdms, +void send_emails ( + std::list> kdms, dcp::NameFormat container_name_format, dcp::NameFormat filename_format, - std::string cpl_name + std::string cpl_name, + std::vector extra_addresses ); - -template -class SpecialKDMWithMetadata : public KDMWithMetadata -{ -public: - SpecialKDMWithMetadata (dcp::NameFormat::Map const& name_values, void const* group, std::list emails, T k) - : KDMWithMetadata (name_values, group, emails) - , kdm (k) - {} - - std::string kdm_as_xml () const { - return kdm.as_xml (); - } - - void kdm_as_xml (boost::filesystem::path out) const { - return kdm.as_xml (out); - } - - T kdm; -}; - -typedef SpecialKDMWithMetadata DCPKDMWithMetadata; -#ifdef DCPOMATIC_VARIANT_SWAROOP -typedef SpecialKDMWithMetadata ECinemaKDMWithMetadata; -#endif - #endif