X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_decoder.h;h=12e37104e599b76f7e272d212bef9fdfb1683b7d;hb=3dd6717ebb8766fd9ca2a9983e9d0bed69312d1e;hp=b7141f91643d645e76a034e2a0e7d7b1e91bf050;hpb=7a0c2256cbf94d2434ba6e7485517df0a7f894af;p=dcpomatic.git diff --git a/src/lib/dcp_decoder.h b/src/lib/dcp_decoder.h index b7141f916..12e37104e 100644 --- a/src/lib/dcp_decoder.h +++ b/src/lib/dcp_decoder.h @@ -26,6 +26,9 @@ namespace dcp { class Reel; + class MonoPictureAssetReader; + class StereoPictureAssetReader; + class SoundAssetReader; } class DCPContent; @@ -35,27 +38,39 @@ struct dcp_subtitle_within_dcp_test; class DCPDecoder : public Decoder { public: - DCPDecoder (boost::shared_ptr, boost::shared_ptr log, bool fast); + DCPDecoder (boost::shared_ptr, boost::shared_ptr log); std::list > reels () const { return _reels; } + void set_decode_referenced (); + private: friend struct dcp_subtitle_within_dcp_test; bool pass (PassReason, bool accurate); void seek (ContentTime t, bool accurate); void next_reel (); + void get_readers (); std::list image_subtitles_during (ContentTimePeriod, bool starting) const; std::list text_subtitles_during (ContentTimePeriod, bool starting) const; + boost::shared_ptr _dcp_content; /** Time of next thing to return from pass relative to the start of _reel */ ContentTime _next; std::list > _reels; + std::list >::iterator _reel; /** Offset of _reel from the start of the content in frames */ int64_t _offset; - boost::shared_ptr _dcp_content; + /** 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; };