X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fwriter.h;h=17ce42572c52da3df2d9e1a2eea96dd182da2847;hb=2d5b8cdde08044d323aa7193dfac6c9f8bca7131;hp=023107d9756555be0e144b9b363801e670cda33e;hpb=8349f0c97d98c0b7550ff4c76ad25f8f06270d6a;p=dcpomatic.git diff --git a/src/lib/writer.h b/src/lib/writer.h index 023107d97..17ce42572 100644 --- a/src/lib/writer.h +++ b/src/lib/writer.h @@ -32,6 +32,10 @@ class Job; namespace libdcp { class MonoPictureAsset; class MonoPictureAssetWriter; + class StereoPictureAsset; + class StereoPictureAssetWriter; + class PictureAsset; + class PictureAssetWriter; class SoundAsset; class SoundAssetWriter; } @@ -66,7 +70,7 @@ bool operator== (QueueItem const & a, QueueItem const & b); class Writer : public ExceptionStore, public boost::noncopyable { public: - Writer (boost::shared_ptr, boost::shared_ptr); + Writer (boost::shared_ptr, boost::weak_ptr); bool can_fake_write (int) const; @@ -85,7 +89,7 @@ private: /** 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; @@ -102,7 +106,7 @@ 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; @@ -122,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; };