X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Flib%2Fsndfile_decoder.h;h=5ebe1da7b251852ee523df1e24fc9597406570f2;hb=4e5c1b91ff04bebc692e52115a741948037dda54;hp=56fc3a9f08bc7811d4a6d7720992874d5a13b393;hpb=db468a15e50c8491d4b8462ad0676be905f49065;p=dcpomatic.git diff --git a/src/lib/sndfile_decoder.h b/src/lib/sndfile_decoder.h index 56fc3a9f0..5ebe1da7b 100644 --- a/src/lib/sndfile_decoder.h +++ b/src/lib/sndfile_decoder.h @@ -17,22 +17,32 @@ */ -#include #include "decoder.h" #include "audio_decoder.h" +#include "audio_examiner.h" +#include class SndfileContent; -class SndfileDecoder : public AudioDecoder +class SndfileDecoder : public AudioDecoder, public AudioExaminer { public: - SndfileDecoder (boost::shared_ptr, boost::shared_ptr); + SndfileDecoder (boost::shared_ptr 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 _sndfile_content; + SNDFILE* _sndfile; + SF_INFO _info; + int64_t _done; + int64_t _remaining; + float* _deinterleave_buffer; };