X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fbutler.h;h=fb133d10809413298364faba4e02a8d62c42c5b1;hb=61a3f348c433ca4f8d2e7bb9758ad5d61bd35407;hp=5b09f6e5f836bfa861e4681588608bad9e8f0d6e;hpb=b733ff51f0212d02dbf33ccb62e67f07941f5ace;p=dcpomatic.git diff --git a/src/lib/butler.h b/src/lib/butler.h index 5b09f6e5f..fb133d108 100644 --- a/src/lib/butler.h +++ b/src/lib/butler.h @@ -41,9 +41,15 @@ public: ~Butler (); void seek (DCPTime position, bool accurate); - std::pair, DCPTime> get_video (); + + enum Error { + NONE, + AGAIN + }; + + std::pair, DCPTime> get_video (Error* e = 0); boost::optional get_audio (float* out, Frame frames); - boost::optional > get_closed_caption (); + boost::optional get_closed_caption (); void disable_audio (); @@ -53,10 +59,10 @@ private: void thread (); void video (boost::shared_ptr video, DCPTime time); void audio (boost::shared_ptr audio, DCPTime time); - void text (PlayerText pt, TextType type, DCPTimePeriod period); + void text (PlayerText pt, TextType type, boost::optional track, DCPTimePeriod period); bool should_run () const; void prepare (boost::weak_ptr video) const; - void player_changed (bool frequent); + void player_change (ChangeType type, bool frequent); void seek_unlocked (DCPTime position, bool accurate); boost::shared_ptr _player; @@ -83,6 +89,7 @@ private: boost::condition _arrived; boost::optional _pending_seek_position; bool _pending_seek_accurate; + int _suspended; bool _finished; bool _died; bool _stop_thread; @@ -100,5 +107,5 @@ private: boost::signals2::scoped_connection _player_video_connection; boost::signals2::scoped_connection _player_audio_connection; boost::signals2::scoped_connection _player_text_connection; - boost::signals2::scoped_connection _player_changed_connection; + boost::signals2::scoped_connection _player_change_connection; };