X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fwriter.h;h=e63591a8a338d50351b8ed4f0f45ad48e794c148;hb=e80732c66bb8907836eafeb816d695f96e063843;hp=023107d9756555be0e144b9b363801e670cda33e;hpb=2c4023c4f8e9ed5c09a30e28cc0bf8633b7635a3;p=dcpomatic.git diff --git a/src/lib/writer.h b/src/lib/writer.h index 023107d97..e63591a8a 100644 --- a/src/lib/writer.h +++ b/src/lib/writer.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2014 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,23 +17,35 @@ */ -#include +/** @file src/lib/writer.h + * @brief Writer class. + */ + +#include "exceptions.h" +#include "types.h" +#include "player_subtitles.h" #include +#include #include #include -#include "exceptions.h" -#include "types.h" +#include class Film; class EncodedData; class AudioBuffers; class Job; - -namespace libdcp { - class MonoPictureAsset; - class MonoPictureAssetWriter; - class SoundAsset; - class SoundAssetWriter; +class Font; + +namespace dcp { + class MonoPictureMXF; + class MonoPictureMXFWriter; + class StereoPictureMXF; + class StereoPictureMXFWriter; + class PictureMXF; + class PictureMXFWriter; + class SoundMXF; + class SoundMXFWriter; + class InteropSubtitleContent; } struct QueueItem @@ -47,8 +59,6 @@ public: 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 */ @@ -63,29 +73,46 @@ public: bool operator< (QueueItem const & a, QueueItem const & b); bool operator== (QueueItem const & a, QueueItem const & b); +/** @class Writer + * @brief Class to manage writing JPEG2000 and audio data to MXFs on disk. + * + * This class creates sound and picture MXFs, then takes EncodedData + * or AudioBuffers objects (containing image or sound data respectively) + * and writes them to the MXFs. + * + * ::write() for EncodedData can be called out of order, and the Writer + * will sort it out. write() for AudioBuffers must be called in order. + */ + class Writer : public ExceptionStore, public boost::noncopyable { public: - Writer (boost::shared_ptr, boost::shared_ptr); + Writer (boost::shared_ptr, boost::weak_ptr); + ~Writer (); bool can_fake_write (int) const; void write (boost::shared_ptr, int, Eyes); void fake_write (int, Eyes); void write (boost::shared_ptr); + void write (PlayerSubtitles subs); + void write (std::list > fonts); void repeat (int f, Eyes); void finish (); + void set_encoder_threads (int threads); + private: void thread (); + void terminate_thread (bool); void check_existing_picture_mxf (); bool check_existing_picture_mxf_frame (FILE *, int, Eyes); - bool have_sequenced_image_at_queue_head () const; + bool have_sequenced_image_at_queue_head (); /** our Film */ boost::shared_ptr _film; - boost::shared_ptr _job; + boost::weak_ptr _job; /** the first frame index that does not already exist in our MXF */ int _first_nonexistant_frame; @@ -99,31 +126,34 @@ private: int _queued_full_in_memory; /** mutex for thread state */ mutable boost::mutex _mutex; - /** condition to manage thread wakeups */ - boost::condition _condition; + /** 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 */ + boost::condition _full_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 - */ - static const int _maximum_frames_in_memory; - + * ordering + */ + 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; - boost::shared_ptr _sound_asset_writer; + boost::shared_ptr _picture_mxf; + boost::shared_ptr _picture_mxf_writer; + boost::shared_ptr _sound_mxf; + boost::shared_ptr _sound_mxf_writer; + boost::shared_ptr _subtitle_content; + + std::list > _fonts; };