using std::list;
using std::string;
using boost::shared_ptr;
+using boost::dynamic_pointer_cast;
dcp::DecryptedKDM
DCP::decrypted_kdm () const
LOG_GENERAL ("Reading %1 DCP directories", _dcp_content->directories().size());
BOOST_FOREACH (boost::filesystem::path i, _dcp_content->directories()) {
shared_ptr<dcp::DCP> dcp (new dcp::DCP (i));
- dcp->read (_tolerant, 0, true);
+ list<dcp::VerificationNote> notes;
+ dcp->read (¬es, true);
+ if (!_tolerant) {
+ /** We accept and ignore EmptyAssetPathError but everything else is bad */
+ BOOST_FOREACH (dcp::VerificationNote j, notes) {
+ if (j.code() == dcp::VerificationNote::EMPTY_ASSET_PATH) {
+ LOG_WARNING("Empty path in ASSETMAP of %1", i.string());
+ } else {
+ boost::throw_exception(dcp::DCPReadError(dcp::note_to_string(j)));
+ }
+ }
+ }
dcps.push_back (dcp);
LOG_GENERAL ("Reading DCP %1: %2 CPLs", i.string(), dcp->cpls().size());
BOOST_FOREACH (shared_ptr<dcp::CPL> i, dcp->cpls()) {