X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_decoder.h;h=898b84e5d570de2c79ea0bf6bc4813f5eb699dd1;hb=dffc146e5387a0b3f7a671d845d6c3051b0e7067;hp=97a1847946a6f677985824893a9096b7ab2c9971;hpb=76f83b97c401c24b3c93baee0665e84be05f43ea;p=dcpomatic.git diff --git a/src/lib/dcp_decoder.h b/src/lib/dcp_decoder.h index 97a184794..898b84e5d 100644 --- a/src/lib/dcp_decoder.h +++ b/src/lib/dcp_decoder.h @@ -23,39 +23,43 @@ */ #include "decoder.h" +#include "dcp.h" +#include +#include +#include +#include namespace dcp { class Reel; - class MonoPictureAssetReader; - class StereoPictureAssetReader; - class SoundAssetReader; } 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); + DCPDecoder (boost::shared_ptr, boost::shared_ptr log, bool fast); std::list > reels () const { return _reels; } + void set_decode_referenced (bool r); + void set_forced_reduction (boost::optional reduction); + + bool pass (); + void seek (ContentTime t, bool accurate); + 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 (); + void pass_captions (ContentTime next); + void pass_captions (ContentTime next, boost::shared_ptr asset, bool reference, int64_t entry_point, boost::shared_ptr decoder); - 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; @@ -69,4 +73,7 @@ private: boost::shared_ptr _stereo_reader; /** Reader for current sound asset, if applicable */ boost::shared_ptr _sound_reader; + + bool _decode_referenced; + boost::optional _forced_reduction; };