Merge master.
[dcpomatic.git] / src / lib / sndfile_decoder.h
index 56fc3a9f08bc7811d4a6d7720992874d5a13b393..52590ef24a3b99bc841edff4687b2a97ced69a9c 100644 (file)
@@ -26,13 +26,22 @@ class SndfileContent;
 class SndfileDecoder : public AudioDecoder
 {
 public:
-       SndfileDecoder (boost::shared_ptr<const Film>, boost::shared_ptr<const 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;
 
+private:
+       bool pass ();
+       
        boost::shared_ptr<const SndfileContent> _sndfile_content;
+       SNDFILE* _sndfile;
+       SF_INFO _info;
+       int64_t _done;
+       int64_t _remaining;
+       float* _deinterleave_buffer;
 };