X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fdcp_decoder.h;h=4068696eafe397620b824d3665a0f0e9e541752d;hp=15220810d0f63b5e9c871121084d110d7579f1ba;hb=a5be11a965c2c38442e4e069874e7e21b5b43a5c;hpb=c0503d4121ffead6a3adb745b167191cd006b4a3 diff --git a/src/lib/dcp_decoder.h b/src/lib/dcp_decoder.h index 15220810d..4068696ea 100644 --- a/src/lib/dcp_decoder.h +++ b/src/lib/dcp_decoder.h @@ -1,19 +1,20 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ @@ -21,33 +22,65 @@ * @brief A decoder of existing DCPs. */ -#include "video_decoder.h" -#include "audio_decoder.h" -#include "subtitle_decoder.h" +#include "decoder.h" +#include "dcp.h" +#include +#include +#include +#include namespace dcp { class Reel; } class DCPContent; +class Log; struct dcp_subtitle_within_dcp_test; -class DCPDecoder : public VideoDecoder, public AudioDecoder, public SubtitleDecoder +class DCPDecoder : public DCP, public Decoder { public: - DCPDecoder (boost::shared_ptr, bool fast); + DCPDecoder (boost::shared_ptr film, boost::shared_ptr, bool fast); -private: - friend struct dcp_subtitle_within_dcp_test; + 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); - std::list image_subtitles_during (ContentTimePeriod, bool starting) const; - std::list text_subtitles_during (ContentTimePeriod, bool starting) const; +private: + friend struct dcp_subtitle_within_dcp_test; + + void next_reel (); + void get_readers (); + void pass_texts (ContentTime next, dcp::Size size); + void pass_texts ( + ContentTime next, + boost::shared_ptr asset, + bool reference, + int64_t entry_point, + boost::shared_ptr decoder, + dcp::Size size + ); + /** Time of next thing to return from pass relative to the start of _reel */ 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; };