From 1f88a38a2a607c21988a403e76f315444c4be36b Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Fri, 30 Aug 2019 23:16:21 +0100 Subject: Make player more tolerant of some DCP errors. --- src/lib/decoder_factory.cc | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'src/lib/decoder_factory.cc') diff --git a/src/lib/decoder_factory.cc b/src/lib/decoder_factory.cc index 5d758956d..2ded95fef 100644 --- a/src/lib/decoder_factory.cc +++ b/src/lib/decoder_factory.cc @@ -47,9 +47,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 +62,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(); -- cgit v1.2.3