X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fwriter.h;h=d922cfce01a4685ed1b5941dc1bf0998f999c3ba;hb=acb1ace5884337757102bc05074b6b37f04c49cd;hp=62714edf39f675e6354510434618e695a214576c;hpb=996b0c06e23bcb6b300d7b8799df94993692e07d;p=dcpomatic.git diff --git a/src/lib/writer.h b/src/lib/writer.h index 62714edf3..d922cfce0 100644 --- a/src/lib/writer.h +++ b/src/lib/writer.h @@ -22,6 +22,7 @@ #include #include #include "exceptions.h" +#include "types.h" class Film; class EncodedData; @@ -31,6 +32,10 @@ class Job; namespace libdcp { class MonoPictureAsset; class MonoPictureAssetWriter; + class StereoPictureAsset; + class StereoPictureAssetWriter; + class PictureAsset; + class PictureAssetWriter; class SoundAsset; class SoundAssetWriter; } @@ -56,31 +61,34 @@ public: int size; /** frame index */ int frame; + Eyes eyes; }; bool operator< (QueueItem const & a, QueueItem const & b); bool operator== (QueueItem const & a, QueueItem const & b); -class Writer : public ExceptionStore +class Writer : public ExceptionStore, public boost::noncopyable { public: - Writer (boost::shared_ptr, boost::shared_ptr); + Writer (boost::shared_ptr, boost::shared_ptr); bool can_fake_write (int) const; - void write (boost::shared_ptr, int); - void fake_write (int); + void write (boost::shared_ptr, int, Eyes); + void fake_write (int, Eyes); void write (boost::shared_ptr); - void repeat (int f); + void repeat (int f, Eyes); void finish (); private: void thread (); void check_existing_picture_mxf (); + bool check_existing_picture_mxf_frame (FILE *, int, Eyes); + bool have_sequenced_image_at_queue_head () const; /** our Film */ - boost::shared_ptr _film; + boost::shared_ptr _film; boost::shared_ptr _job; /** the first frame index that does not already exist in our MXF */ int _first_nonexistant_frame; @@ -98,9 +106,10 @@ private: /** condition to manage thread wakeups */ boost::condition _condition; /** the data of the last written frame, or 0 if there isn't one */ - boost::shared_ptr _last_written; + boost::shared_ptr _last_written[EYES_COUNT]; /** the index of the last written frame */ int _last_written_frame; + Eyes _last_written_eyes; /** maximum number of frames to hold in memory, for when we are managing ordering */ @@ -117,8 +126,8 @@ private: */ int _pushed_to_disk; - boost::shared_ptr _picture_asset; - boost::shared_ptr _picture_asset_writer; + boost::shared_ptr _picture_asset; + boost::shared_ptr _picture_asset_writer; boost::shared_ptr _sound_asset; boost::shared_ptr _sound_asset_writer; };