X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp.cc;h=e40a9496dd678897e8fa3d7f1abd6fec8fd6a74a;hb=624141eca78ad5d349322fd4cc38bdeea99a8d49;hp=fa9f5f721d04d09bd76eb5729b402dbe7cee554c;hpb=0e06203fb85887dc5ead6a10773bfa1ca57ef19c;p=dcpomatic.git diff --git a/src/lib/dcp.cc b/src/lib/dcp.cc index fa9f5f721..e40a9496d 100644 --- a/src/lib/dcp.cc +++ b/src/lib/dcp.cc @@ -22,6 +22,7 @@ #include "config.h" #include "film.h" #include "log.h" +#include "dcpomatic_log.h" #include "compose.hpp" #include "dcp_content.h" #include @@ -34,8 +35,7 @@ using std::list; using std::string; using boost::shared_ptr; - -#define LOG_GENERAL(...) _dcp_content->film()->log()->log (String::compose (__VA_ARGS__), LogEntry::TYPE_GENERAL); +using boost::dynamic_pointer_cast; /** Find all the CPLs in our directories, cross-add assets and return the CPLs */ list > @@ -43,10 +43,19 @@ DCP::cpls () const { list > dcps; list > cpls; - + LOG_GENERAL ("Reading %1 DCP directories", _dcp_content->directories().size()); BOOST_FOREACH (boost::filesystem::path i, _dcp_content->directories()) { shared_ptr dcp (new dcp::DCP (i)); - dcp->read (false, 0, true); + list > errors; + dcp->read (true, &errors, true); + /** We accept and ignore EmptyAssetPathError but everything else is bad */ + BOOST_FOREACH (shared_ptr j, errors) { + if (dynamic_pointer_cast(j)) { + LOG_WARNING("Empty path in ASSETMAP of %1", i.string()); + } else { + boost::throw_exception(*j.get()); + } + } dcps.push_back (dcp); LOG_GENERAL ("Reading DCP %1: %2 CPLs", i.string(), dcp->cpls().size()); BOOST_FOREACH (shared_ptr i, dcp->cpls()) {