/********************************************************************** Audacity: A Digital Audio Editor ODDecodeBlockFile.h Created by Michael Chinen (mchinen) Audacity(R) is copyright (c) 1999-2008 Audacity Team. License: GPL v2. See License.txt. ******************************************************************//** \class ODDecodeBlockFile \brief ODDecodeBlockFile is a special type of SimpleBlockFile that does not necessarily have summary OR audio data available The summary and audio is eventually computed and written to a file in a background thread. Load On-Demand implementation of the SimpleBlockFIle for audio files that need to be decoded (mp3,flac,etc..). Also, see ODPCMAliasBlockFile for a similar file. *//*******************************************************************/ #ifndef __AUDACITY_ODDecodeBlockFile__ #define __AUDACITY_ODDecodeBlockFile__ #include "SimpleBlockFile.h" #include "../BlockFile.h" #include "../ondemand/ODTaskThread.h" #include "../DirManager.h" #include "../ondemand/ODDecodeTask.h" #include /// An AliasBlockFile that references uncompressed data in an existing file class ODDecodeBlockFile : public SimpleBlockFile { public: // Constructor / Destructor /// Create a disk file and write summary and sample data to it ODDecodeBlockFile(wxFileName baseFileName,wxFileName audioFileName, sampleCount aliasStart, sampleCount aliasLen, int aliasChannel, unsigned int decodeType); /// Create the memory structure to refer to the given block file ODDecodeBlockFile(wxFileName existingFile, wxFileName audioFileName, sampleCount aliasStart, sampleCount aliasLen, int aliasChannel, unsigned int decodeType, float min, float max, float rms, bool dataAvailable); virtual ~ODDecodeBlockFile(); //checks to see if summary data has been computed and written to disk yet. Thread safe. Blocks if we are writing summary data. virtual bool IsSummaryAvailable(); /// Returns TRUE if this block's complete data is ready to be accessed by Read() virtual bool IsDataAvailable(); /// Returns TRUE if the summary has not yet been written, but is actively being computed and written to disk virtual bool IsSummaryBeingComputed(){return false;} //Calls that rely on summary files need to be overidden virtual wxLongLong GetSpaceUsage(); /// Gets extreme values for the specified region virtual void GetMinMax(sampleCount start, sampleCount len, float *outMin, float *outMax, float *outRMS); /// Gets extreme values for the entire block virtual void GetMinMax(float *outMin, float *outMax, float *outRMS); /// Returns the 256 byte summary data block virtual bool Read256(float *buffer, sampleCount start, sampleCount len); /// Returns the 64K summary data block virtual bool Read64K(float *buffer, sampleCount start, sampleCount len); /// returns true before decoding is complete, because it is linked to the encoded file until then. /// returns false afterwards. ///Makes new ODPCMAliasBlockFile or PCMAliasBlockFile depending on summary availability virtual BlockFile *Copy(wxFileName fileName); ///Saves as xml ODPCMAliasBlockFile or PCMAliasBlockFile depending on summary availability virtual void SaveXML(XMLWriter &xmlFile); ///Reconstructs from XML a ODPCMAliasBlockFile and reschedules it for OD loading static BlockFile *BuildFromXML(DirManager &dm, const wxChar **attrs); ///Writes the summary file if summary data is available virtual void Recover(void); ///A public interface to WriteSummary int DoWriteBlockFile(){return WriteODDecodeBlockFile();} int WriteODDecodeBlockFile(); ///Sets the value that indicates where the first sample in this block corresponds to the global sequence/clip. Only for display use. void SetStart(sampleCount startSample){mStart = startSample;} ///Gets the value that indicates where the first sample in this block corresponds to the global sequence/clip. Only for display use. sampleCount GetStart(){return mStart;} //returns the number of samples from the beginning of the track that this blockfile starts at sampleCount GetGlobalStart(){return mClipOffset+mStart;} //returns the number of samples from the beginning of the track that this blockfile ends at sampleCount GetGlobalEnd(){return mClipOffset+mStart+GetLength();} //Below calls are overrided just so we can take wxlog calls out, which are not threadsafe. /// Reads the specified data from the aliased file using libsndfile virtual int ReadData(samplePtr data, sampleFormat format, sampleCount start, sampleCount len); /// Read the summary into a buffer virtual bool ReadSummary(void *data); ///Returns the type of audiofile this blockfile is loaded from. virtual unsigned int GetDecodeType(){return mType;} virtual void SetDecodeType(unsigned int type){mType=type;} ///sets the amount of samples the clip associated with this blockfile is offset in the wavetrack (non effecting) void SetClipOffset(sampleCount numSamples){mClipOffset= numSamples;} ///Gets the number of samples the clip associated with this blockfile is offset by. sampleCount GetClipOffset(){return mClipOffset;} //OD TODO:set ISAlias to true while we have no data? ///set the decoder, void SetODFileDecoder(ODFileDecoder* decoder); wxFileName GetAudioFileName(){return mAudioFileName;} ///sets the file name the summary info will be saved in. threadsafe. virtual void SetFileName(wxFileName &name); virtual wxFileName GetFileName(); /// Prevents a read on other threads of the encoded audio file. virtual void LockRead(); /// Allows reading of encoded file on other threads. virtual void UnlockRead(); ///// Get the name of the file where the audio data for this block is /// stored. wxFileName GetEncodedAudioFilename() { return mAudioFileName; } /// Modify this block to point at a different file. This is generally /// looked down on, but it is necessary in one case: see /// DirManager::EnsureSafeFilename(). void ChangeAudioFile(wxFileName newAudioFile); protected: // virtual void WriteSimpleBlockFile(); virtual void *CalcSummary(samplePtr buffer, sampleCount len, sampleFormat format); //The on demand type. unsigned int mType; ///This lock is for the filename (string) of the blockfile that contains summary/audio data ///after decoding ODLock mFileNameMutex; ///The original file the audio came from. wxFileName mAudioFileName; ODLock mDataAvailableMutex; bool mDataAvailable; bool mDataBeingComputed; ODFileDecoder* mDecoder; ODLock mDecoderMutex; ///For accessing the audio file that will be decoded. Used by dir manager; ODLock mReadDataMutex; ///for reporting after task is complete. Only for display use. sampleCount mStart; ///the ODTask needs to know where this blockfile lies in the track, so for convenience, we have this here. sampleCount mClipOffset; sampleFormat mFormat; sampleCount mAliasStart;//where in the encoded audio file this block corresponds to. int mAliasChannel;//The channel number in the encoded file.. }; #endif