X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fdecoder_factory.cc;h=f68a443b5cf4014f5c47d50619d151fcfdc237a7;hp=5d758956d76071fffe172229578b6efb83ad94b8;hb=dd9be86db6cde0afa5da0d1d1ac43b42e05dca26;hpb=57f112a2bd073123a686141be6c16ba997349056 diff --git a/src/lib/decoder_factory.cc b/src/lib/decoder_factory.cc index 5d758956d..f68a443b5 100644 --- a/src/lib/decoder_factory.cc +++ b/src/lib/decoder_factory.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2016-2019 Carl Hetherington + Copyright (C) 2016-2020 Carl Hetherington This file is part of DCP-o-matic. @@ -18,6 +18,8 @@ */ +#include "atmos_mxf_content.h" +#include "atmos_mxf_decoder.h" #include "ffmpeg_content.h" #include "ffmpeg_decoder.h" #include "dcp_content.h" @@ -34,8 +36,8 @@ #include using std::list; -using boost::shared_ptr; -using boost::dynamic_pointer_cast; +using std::shared_ptr; +using std::dynamic_pointer_cast; template shared_ptr @@ -47,9 +49,12 @@ maybe_cast (shared_ptr d) return dynamic_pointer_cast (d); } -/** @param old_decoder A `used' decoder that has been previously made for this piece of content, or 0 */ +/** + @param tolerant true to proceed in the face of `survivable' errors, otherwise false. + @param old_decoder A `used' decoder that has been previously made for this piece of content, or 0 +*/ shared_ptr -decoder_factory (shared_ptr film, shared_ptr content, bool fast, shared_ptr old_decoder) +decoder_factory (shared_ptr film, shared_ptr content, bool fast, bool tolerant, shared_ptr old_decoder) { shared_ptr fc = dynamic_pointer_cast (content); if (fc) { @@ -59,7 +64,7 @@ decoder_factory (shared_ptr film, shared_ptr content, shared_ptr dc = dynamic_pointer_cast (content); if (dc) { try { - return shared_ptr (new DCPDecoder(film, dc, fast, maybe_cast(old_decoder))); + return shared_ptr (new DCPDecoder(film, dc, fast, tolerant, maybe_cast(old_decoder))); } catch (KDMError& e) { /* This will be found and reported to the user when the content is examined */ return shared_ptr(); @@ -86,5 +91,10 @@ decoder_factory (shared_ptr film, shared_ptr content, return shared_ptr (new VideoMXFDecoder(film, vmc)); } + shared_ptr amc = dynamic_pointer_cast (content); + if (amc) { + return shared_ptr (new AtmosMXFDecoder(film, amc)); + } + return shared_ptr (); }