X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fbutler.h;h=ea43374434f033a5becfebc13f2fce09a6436d5c;hp=f483524482bddd86e324aebe5ed9e407f1439acf;hb=e97d48b043fe39ec22687555225d6b4b526a2172;hpb=90c447e9200b9eef0f542b21fab1d0d9eebab733 diff --git a/src/lib/butler.h b/src/lib/butler.h index f48352448..ea4337443 100644 --- a/src/lib/butler.h +++ b/src/lib/butler.h @@ -20,54 +20,96 @@ #include "video_ring_buffers.h" #include "audio_ring_buffers.h" +#include "text_ring_buffers.h" #include "audio_mapping.h" +#include "exception_store.h" #include #include #include #include #include +#include -class Film; class Player; class PlayerVideo; -class Butler : public boost::noncopyable +class Butler : public ExceptionStore, public boost::noncopyable { public: - Butler (boost::weak_ptr film, boost::shared_ptr player, AudioMapping map, int audio_channels); + Butler ( + boost::shared_ptr player, + AudioMapping map, + int audio_channels, + boost::function pixel_format, + bool aligned, + bool fast + ); + ~Butler (); - void seek (DCPTime position, bool accurate); - std::pair, DCPTime> get_video (); - void get_audio (float* out, Frame frames); + void seek (dcpomatic::DCPTime position, bool accurate); + + enum Error { + NONE, + AGAIN + }; + + std::pair, dcpomatic::DCPTime> get_video (bool blocking, Error* e = 0); + boost::optional get_audio (float* out, Frame frames); + boost::optional get_closed_caption (); + + void disable_audio (); + + std::pair memory_used () const; private: void thread (); - void video (boost::shared_ptr video, DCPTime time); - void audio (boost::shared_ptr audio, DCPTime time); - void player_changed (); + void video (boost::shared_ptr video, dcpomatic::DCPTime time); + void audio (boost::shared_ptr audio, dcpomatic::DCPTime time, int frame_rate); + void text (PlayerText pt, TextType type, boost::optional track, dcpomatic::DCPTimePeriod period); + bool should_run () const; + void prepare (boost::weak_ptr video); + void player_change (ChangeType type); + void seek_unlocked (dcpomatic::DCPTime position, bool accurate); - boost::weak_ptr _film; boost::shared_ptr _player; boost::thread* _thread; VideoRingBuffers _video; AudioRingBuffers _audio; + TextRingBuffers _closed_caption; + + boost::thread_group _prepare_pool; + boost::asio::io_service _prepare_service; + boost::shared_ptr _prepare_work; + /** mutex to protect _pending_seek_position, _pending_seek_acurate, _finished, _died, _stop_thread */ boost::mutex _mutex; boost::condition _summon; boost::condition _arrived; - boost::optional _pending_seek_position; + boost::optional _pending_seek_position; bool _pending_seek_accurate; - + int _suspended; bool _finished; + bool _died; + bool _stop_thread; AudioMapping _audio_mapping; int _audio_channels; - bool _stop_thread; + bool _disable_audio; + + boost::function _pixel_format; + bool _aligned; + bool _fast; + + /** If we are waiting to be refilled following a seek, this is the time we were + seeking to. + */ + boost::optional _awaiting; boost::signals2::scoped_connection _player_video_connection; boost::signals2::scoped_connection _player_audio_connection; - boost::signals2::scoped_connection _player_changed_connection; + boost::signals2::scoped_connection _player_text_connection; + boost::signals2::scoped_connection _player_change_connection; };