X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_decoder.h;h=0882bfd097784295e299fdd155c46fe681b284cc;hb=865316f0129c85cdd0248b87502fe97dec94b3f0;hp=12e37104e599b76f7e272d212bef9fdfb1683b7d;hpb=0cb31de2be2b51a8bc19e55ceb1b86dc26ea1c42;p=dcpomatic.git diff --git a/src/lib/dcp_decoder.h b/src/lib/dcp_decoder.h index 12e37104e..0882bfd09 100644 --- a/src/lib/dcp_decoder.h +++ b/src/lib/dcp_decoder.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2014-2016 Carl Hetherington + Copyright (C) 2014-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,59 +18,94 @@ */ + /** @file src/dcp_decoder.h * @brief A decoder of existing DCPs. */ + +#include "atmos_metadata.h" #include "decoder.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 { public: - DCPDecoder (boost::shared_ptr, boost::shared_ptr log); - - std::list > reels () const { + DCPDecoder ( + std::shared_ptr film, + std::shared_ptr content, + bool fast, + bool tolerant, + std::shared_ptr old + ); + + std::vector> reels () const { return _reels; } - void set_decode_referenced (); + void set_decode_referenced (bool r); + void set_forced_reduction (boost::optional reduction); + + bool pass () override; + void seek (dcpomatic::ContentTime t, bool accurate) override; + + std::vector fonts () const override; + + std::string lazy_digest () const { + return _lazy_digest; + } + + dcpomatic::ContentTime position () const override; 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_texts (dcpomatic::ContentTime next, dcp::Size size); + void pass_texts ( + dcpomatic::ContentTime next, + std::shared_ptr asset, + bool reference, + int64_t entry_point, + std::shared_ptr decoder, + dcp::Size size + ); + std::string calculate_lazy_digest (std::shared_ptr) const; + + std::shared_ptr _dcp_content; - 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; + dcpomatic::ContentTime _next; + std::vector> _reels; - std::list >::iterator _reel; + std::vector>::iterator _reel; /** Offset of _reel from the start of the content in frames */ - int64_t _offset; + int64_t _offset = 0; /** Reader for current mono picture asset, if applicable */ - boost::shared_ptr _mono_reader; + std::shared_ptr _mono_reader; /** Reader for current stereo picture asset, if applicable */ - boost::shared_ptr _stereo_reader; + std::shared_ptr _stereo_reader; /** Reader for current sound asset, if applicable */ - boost::shared_ptr _sound_reader; + std::shared_ptr _sound_reader; + std::shared_ptr _atmos_reader; + boost::optional _atmos_metadata; + + bool _decode_referenced = false; + boost::optional _forced_reduction; - bool _decode_referenced; + std::string _lazy_digest; };