Merge master.
[dcpomatic.git] / src / lib / sndfile_decoder.h
index 9a3ef49b017a3983f698a57c89218089d7e3bfa2..52590ef24a3b99bc841edff4687b2a97ced69a9c 100644 (file)
@@ -26,13 +26,22 @@ class SndfileContent;
 class SndfileDecoder : public AudioDecoder
 {
 public:
-       SndfileDecoder (boost::shared_ptr<const Film>, boost::shared_ptr<SndfileContent>);
+       SndfileDecoder (boost::shared_ptr<const SndfileContent> c);
+       ~SndfileDecoder ();
 
-       bool pass ();
+       void seek (ContentTime, bool);
 
-private:
-       SNDFILE* open_file (sf_count_t &);
-       void close_file (SNDFILE*);
+       int audio_channels () const;
+       ContentTime audio_length () const;
+       int audio_frame_rate () const;
 
-       boost::shared_ptr<SndfileContent> _sndfile_content;
+private:
+       bool pass ();
+       
+       boost::shared_ptr<const SndfileContent> _sndfile_content;
+       SNDFILE* _sndfile;
+       SF_INFO _info;
+       int64_t _done;
+       int64_t _remaining;
+       float* _deinterleave_buffer;
 };