X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fsend_kdm_email_job.cc;h=55a1718114a2566c29ec6ad5680c0be174dfcb59;hb=581797d640af1572f884ddf4395924894b745b3a;hp=3bf1887f49df2bdf12bf9bade02a2026a03fa7f8;hpb=fe9d2a290682021cd12a00bf21fa4db3012e2049;p=dcpomatic.git diff --git a/src/lib/send_kdm_email_job.cc b/src/lib/send_kdm_email_job.cc index 3bf1887f4..55a171811 100644 --- a/src/lib/send_kdm_email_job.cc +++ b/src/lib/send_kdm_email_job.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2020 Carl Hetherington This file is part of DCP-o-matic. @@ -20,8 +20,8 @@ #include "send_kdm_email_job.h" #include "compose.hpp" +#include "kdm_with_metadata.h" #include "film.h" -#include "cinema_kdms.h" #include #include "i18n.h" @@ -29,34 +29,61 @@ using std::string; using std::list; using boost::shared_ptr; +using boost::optional; -/** @param log Log to write to, or 0 */ SendKDMEmailJob::SendKDMEmailJob ( - list cinema_kdms, - KDMNameFormat name_format, - dcp::NameFormat::Map name_values, - string cpl_name, - shared_ptr log + list kdms, + dcp::NameFormat container_name_format, + dcp::NameFormat filename_format, + string cpl_name ) : Job (shared_ptr()) - , _name_format (name_format) - , _name_values (name_values) + , _container_name_format (container_name_format) + , _filename_format (filename_format) , _cpl_name (cpl_name) - , _cinema_kdms (cinema_kdms) - , _log (log) { + BOOST_FOREACH (KDMWithMetadataPtr i, kdms) { + list s; + s.push_back (i); + _kdms.push_back (s); + } +} +/** @param kdms KDMs to email. + * @param container_name_format Format to ues for folders / ZIP files. + * @param filename_format Format to use for filenames. + * @param name_values Values to substitute into \p container_name_format and \p filename_format. + * @param cpl_name Name of the CPL that the KDMs are for. + */ +SendKDMEmailJob::SendKDMEmailJob ( + list > kdms, + dcp::NameFormat container_name_format, + dcp::NameFormat filename_format, + string cpl_name + ) + : Job (shared_ptr()) + , _container_name_format (container_name_format) + , _filename_format (filename_format) + , _cpl_name (cpl_name) + , _kdms (kdms) +{ + +} + +SendKDMEmailJob::~SendKDMEmailJob () +{ + stop_thread (); } string SendKDMEmailJob::name () const { - dcp::NameFormat::Map::const_iterator i = _name_values.find ("film_name"); - if (i == _name_values.end() || i->second.empty ()) { + optional f = _kdms.front().front()->get('f'); + if (!f || f->empty()) { return _("Email KDMs"); } - return String::compose (_("Email KDMs for %1"), i->second); + return String::compose (_("Email KDMs for %2"), *f); } string @@ -69,7 +96,7 @@ void SendKDMEmailJob::run () { set_progress_unknown (); - CinemaKDMs::email (_cinema_kdms, _name_format, _name_values, _cpl_name, _log); + email (_kdms, _container_name_format, _filename_format, _cpl_name); set_progress (1); set_state (FINISHED_OK); }