X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fdcp_decoder.h;h=4de8c86299a0af3fc096387f6f3ea3bab3a77033;hp=61fd91abaf6cb605eee10807be444f2e720649bc;hb=f5980767b7d1d9b39186dd13f12b9d8297a87aef;hpb=3828baf56467224f5d44049bf1e7a7ed11f43a05 diff --git a/src/lib/dcp_decoder.h b/src/lib/dcp_decoder.h index 61fd91aba..4de8c8629 100644 --- a/src/lib/dcp_decoder.h +++ b/src/lib/dcp_decoder.h @@ -23,6 +23,11 @@ */ #include "decoder.h" +#include "dcp.h" +#include +#include +#include +#include namespace dcp { class Reel; @@ -32,27 +37,65 @@ class DCPContent; class Log; struct dcp_subtitle_within_dcp_test; -class DCPDecoder : public Decoder +class DCPDecoder : public DCP, public Decoder { public: - DCPDecoder (boost::shared_ptr, boost::shared_ptr log, bool fast); + DCPDecoder ( + boost::shared_ptr film, + boost::shared_ptr, + bool fast, + bool tolerant, + boost::shared_ptr old + ); std::list > reels () const { return _reels; } + void set_decode_referenced (bool r); + void set_forced_reduction (boost::optional reduction); + + bool pass (); + void seek (dcpomatic::ContentTime t, bool accurate); + + std::string lazy_digest () const { + return _lazy_digest; + } + + dcpomatic::ContentTime position () const; + private: friend struct dcp_subtitle_within_dcp_test; - bool pass (PassReason, bool accurate); - void seek (ContentTime t, bool accurate); - - std::list image_subtitles_during (ContentTimePeriod, bool starting) const; - std::list text_subtitles_during (ContentTimePeriod, bool starting) const; + void next_reel (); + void get_readers (); + void pass_texts (dcpomatic::ContentTime next, dcp::Size size); + void pass_texts ( + 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; - boost::shared_ptr _dcp_content; + /** Offset of _reel from the start of the content in frames */ + int64_t _offset; + /** Reader for current mono picture asset, if applicable */ + boost::shared_ptr _mono_reader; + /** Reader for current stereo picture asset, if applicable */ + boost::shared_ptr _stereo_reader; + /** Reader for current sound asset, if applicable */ + boost::shared_ptr _sound_reader; + + bool _decode_referenced; + boost::optional _forced_reduction; + + std::string _lazy_digest; };