+ void seek (dcpomatic::ContentTime t, bool accurate);
+
+ std::vector<dcpomatic::FontData> fonts () const;
+
+ std::string lazy_digest () const {
+ return _lazy_digest;
+ }
+
+ dcpomatic::ContentTime position () const;
+
+private:
+ friend struct dcp_subtitle_within_dcp_test;
+
+ void next_reel ();
+ void get_readers ();
+ void pass_texts (dcpomatic::ContentTime next, dcp::Size size);
+ void pass_texts (
+ dcpomatic::ContentTime next,
+ std::shared_ptr<dcp::SubtitleAsset> asset,
+ bool reference,
+ int64_t entry_point,
+ std::shared_ptr<TextDecoder> decoder,
+ dcp::Size size
+ );
+ std::string calculate_lazy_digest (std::shared_ptr<const DCPContent>) const;
+
+ /** Time of next thing to return from pass relative to the start of _reel */
+ dcpomatic::ContentTime _next;
+ std::list<std::shared_ptr<dcp::Reel> > _reels;
+
+ std::list<std::shared_ptr<dcp::Reel> >::iterator _reel;
+ /** Offset of _reel from the start of the content in frames */
+ int64_t _offset;
+ /** Reader for current mono picture asset, if applicable */
+ std::shared_ptr<dcp::MonoPictureAssetReader> _mono_reader;
+ /** Reader for current stereo picture asset, if applicable */
+ std::shared_ptr<dcp::StereoPictureAssetReader> _stereo_reader;
+ /** Reader for current sound asset, if applicable */
+ std::shared_ptr<dcp::SoundAssetReader> _sound_reader;
+ std::shared_ptr<dcp::AtmosAssetReader> _atmos_reader;
+ boost::optional<AtmosMetadata> _atmos_metadata;
+
+ bool _decode_referenced;
+ boost::optional<int> _forced_reduction;