Avoid a memcpy in the export code.
[dcpomatic.git] / src / lib / ffmpeg_encoder.h
index 5e6dcecf75d1ee556314d9ff8cddea1f49d12752..43c0d948bb4f75c28d9b53f44142b6b27f13fd8f 100644 (file)
@@ -61,6 +61,9 @@ private:
 
        void audio_frame (int size);
 
+       static void buffer_free(void* opaque, uint8_t* data);
+       void buffer_free2(uint8_t* data);
+
        AVCodec* _video_codec;
        AVCodecContext* _video_codec_context;
        AVCodec* _audio_codec;
@@ -90,6 +93,11 @@ private:
 
        boost::shared_ptr<Butler> _butler;
 
+       /** Store of shared_ptr<Image> to keep them alive whilst raw pointers into
+           their data have been passed to FFmpeg.
+       */
+       std::map<uint8_t*, boost::shared_ptr<const Image> > _pending_images;
+
        static int _video_stream_index;
        static int _audio_stream_index;
 };