X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_decoder.h;h=496d95740d63cf26e9c74024dd43f506416cbf7b;hb=96f7dd41a2c8627bc1ea0d24d84142eb04b4ffef;hp=d3c5c57eddc368ba65f68c77b37713bf1f52fffb;hpb=254b3044d72de6b033d7c584f5abd2b9aa70aad5;p=dcpomatic.git diff --git a/src/lib/dcp_decoder.h b/src/lib/dcp_decoder.h index d3c5c57ed..496d95740 100644 --- a/src/lib/dcp_decoder.h +++ b/src/lib/dcp_decoder.h @@ -40,7 +40,13 @@ struct dcp_subtitle_within_dcp_test; class DCPDecoder : public DCP, public Decoder { public: - DCPDecoder (boost::shared_ptr, bool fast); + DCPDecoder ( + boost::shared_ptr film, + boost::shared_ptr, + bool fast, + bool tolerant, + boost::shared_ptr old + ); std::list > reels () const { return _reels; @@ -49,27 +55,31 @@ public: void set_decode_referenced (bool r); void set_forced_reduction (boost::optional reduction); - bool pass (boost::shared_ptr film); - void seek (boost::shared_ptr film, ContentTime t, bool accurate); + bool pass (); + void seek (dcpomatic::ContentTime t, bool accurate); + + std::string lazy_digest () const { + return _lazy_digest; + } private: friend struct dcp_subtitle_within_dcp_test; void next_reel (); void get_readers (); - void pass_texts (boost::shared_ptr film, ContentTime next, dcp::Size size); + void pass_texts (dcpomatic::ContentTime next, dcp::Size size); void pass_texts ( - boost::shared_ptr film, - ContentTime next, + dcpomatic::ContentTime next, boost::shared_ptr asset, bool reference, int64_t entry_point, boost::shared_ptr decoder, dcp::Size size ); + std::string calculate_lazy_digest (boost::shared_ptr) const; /** Time of next thing to return from pass relative to the start of _reel */ - ContentTime _next; + dcpomatic::ContentTime _next; std::list > _reels; std::list >::iterator _reel; @@ -84,4 +94,6 @@ private: bool _decode_referenced; boost::optional _forced_reduction; + + std::string _lazy_digest; };