X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fsndfile_decoder.h;h=41d5faf082ec29c75b2c2e1059f528c59a26e0ff;hb=65618b6b245a7ba25a7814e00d1d1510cfa61f64;hp=56fc3a9f08bc7811d4a6d7720992874d5a13b393;hpb=6809fdcbf8c65afe3c986b0e2b430d55ce7b124c;p=dcpomatic.git diff --git a/src/lib/sndfile_decoder.h b/src/lib/sndfile_decoder.h index 56fc3a9f0..41d5faf08 100644 --- a/src/lib/sndfile_decoder.h +++ b/src/lib/sndfile_decoder.h @@ -20,19 +20,29 @@ #include #include "decoder.h" #include "audio_decoder.h" +#include "audio_examiner.h" 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; };