X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fwriter.h;h=e56e12e75a2255ac95bab0b1563733f3a5521e94;hb=50cb31af16240b248700dab1484d7f07656c66df;hp=77f98f160294a0c973677911885918f37f239a61;hpb=5e4ab7ebd9a6b62b64fbaf91d7aa1a2a9d4bdec4;p=dcpomatic.git diff --git a/src/lib/writer.h b/src/lib/writer.h index 77f98f160..e56e12e75 100644 --- a/src/lib/writer.h +++ b/src/lib/writer.h @@ -21,10 +21,12 @@ #include #include #include +#include "exceptions.h" class Film; class EncodedData; class AudioBuffers; +class Job; namespace libdcp { class MonoPictureAsset; @@ -33,12 +35,41 @@ namespace libdcp { class SoundAssetWriter; } -class Writer +struct QueueItem { public: - Writer (boost::shared_ptr); + enum Type { + /** a normal frame with some JPEG200 data */ + FULL, + /** a frame whose data already exists in the MXF, + and we fake-write it; i.e. we update the writer's + state but we use the data that is already on disk. + */ + FAKE, + /** this is a repeat of the last frame to be written */ + REPEAT + } type; + + /** encoded data for FULL */ + boost::shared_ptr encoded; + /** size of data for FAKE */ + int size; + /** frame index */ + int frame; +}; + +bool operator< (QueueItem const & a, QueueItem const & b); +bool operator== (QueueItem const & a, QueueItem const & b); + +class Writer : public ExceptionStore +{ +public: + 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); void repeat (int f); void finish (); @@ -46,19 +77,46 @@ public: private: void thread (); + void check_existing_picture_mxf (); + /** our 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; + /** our thread, or 0 */ boost::thread* _thread; + /** true if our thread should finish */ bool _finish; - std::list, int> > _queue; + /** queue of things to write to disk */ + std::list _queue; + /** number of FULL frames whose JPEG200 data is currently held in RAM */ + int _queued_full_in_memory; + /** mutex for thread state */ mutable boost::mutex _mutex; + /** 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; - std::list _pending; + /** the index of the last written frame */ int _last_written_frame; - static const unsigned int _maximum_frames_in_memory; + /** maximum number of frames to hold in memory, for when we are managing + ordering + */ + static const int _maximum_frames_in_memory; + /** number of FULL written frames */ + int _full_written; + /** number of FAKE written frames */ + int _fake_written; + /** number of REPEAT written frames */ + int _repeat_written; + /** number of frames pushed to disk and then recovered + due to the limit of frames to be held in memory. + */ + int _pushed_to_disk; + boost::shared_ptr _picture_asset; boost::shared_ptr _picture_asset_writer; boost::shared_ptr _sound_asset;