X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fj2k_encoder.h;h=ea0a2bef89bfbe873a83cbad11be48a1a0788985;hb=925d97b8e51421bf509c5ffbe4abe8f77a6ca95e;hp=afa010ace01cb71c38398e6a03cb1931fc1a7330;hpb=dd9be86db6cde0afa5da0d1d1ac43b42e05dca26;p=dcpomatic.git diff --git a/src/lib/j2k_encoder.h b/src/lib/j2k_encoder.h index afa010ace..ea0a2bef8 100644 --- a/src/lib/j2k_encoder.h +++ b/src/lib/j2k_encoder.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2016 Carl Hetherington + Copyright (C) 2012-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,13 +18,16 @@ */ + #ifndef DCPOMATIC_J2K_ENCODER_H #define DCPOMATIC_J2K_ENCODER_H + /** @file src/j2k_encoder.h * @brief J2KEncoder class. */ + #include "util.h" #include "cross.h" #include "event_history.h" @@ -37,6 +40,7 @@ #include #include + class Film; class EncodeServerDescription; class DCPVideo; @@ -44,19 +48,22 @@ class Writer; class Job; class PlayerVideo; + /** @class J2KEncoder * @brief Class to manage encoding to J2K. * * This class keeps a queue of frames to be encoded and distributes * the work around threads and encoding servers. */ - -class J2KEncoder : public boost::noncopyable, public ExceptionStore, public std::enable_shared_from_this +class J2KEncoder : public ExceptionStore, public std::enable_shared_from_this { public: J2KEncoder (std::shared_ptr film, std::shared_ptr writer); ~J2KEncoder (); + J2KEncoder (J2KEncoder const&) = delete; + J2KEncoder& operator= (J2KEncoder const&) = delete; + /** Called to indicate that a processing run is about to begin */ void begin (); @@ -89,7 +96,7 @@ private: std::shared_ptr _threads; mutable boost::mutex _queue_mutex; - std::list > _queue; + std::list _queue; /** condition to manage thread wakeups when we have nothing to do */ boost::condition _empty_condition; /** condition to manage thread wakeups when we have too much to do */ @@ -98,10 +105,11 @@ private: std::shared_ptr _writer; Waker _waker; - std::shared_ptr _last_player_video[EYES_COUNT]; + std::shared_ptr _last_player_video[static_cast(Eyes::COUNT)]; boost::optional _last_player_video_time; boost::signals2::scoped_connection _server_found_connection; }; + #endif