diff options
author | Arystanbek Dyussenov <arystan.d@gmail.com> | 2010-09-04 22:49:07 +0400 |
---|---|---|
committer | Arystanbek Dyussenov <arystan.d@gmail.com> | 2010-09-04 22:49:07 +0400 |
commit | 90b464d3728d9ed8ec26fdf59058d236b99dbcd9 (patch) | |
tree | e88cab4fb1358e962b19f658064ca8c9f8d29f5b /intern/audaspace/intern/AUD_FileFactory.cpp | |
parent | 08d02dd04d836976b25793bb1d4c6a86b3f924c7 (diff) | |
parent | b0b787ef38f9947b3176642556f5282eb3518f69 (diff) |
COLLADA branch: merge from trunk -r 28015:31610.soc-2009-chingachgook
Diffstat (limited to 'intern/audaspace/intern/AUD_FileFactory.cpp')
-rw-r--r-- | intern/audaspace/intern/AUD_FileFactory.cpp | 60 |
1 files changed, 23 insertions, 37 deletions
diff --git a/intern/audaspace/intern/AUD_FileFactory.cpp b/intern/audaspace/intern/AUD_FileFactory.cpp index b63390803b1..986fc6c109a 100644 --- a/intern/audaspace/intern/AUD_FileFactory.cpp +++ b/intern/audaspace/intern/AUD_FileFactory.cpp @@ -23,73 +23,59 @@ * ***** END LGPL LICENSE BLOCK ***** */ +#ifdef WITH_FFMPEG +// needed for INT64_C +#ifndef __STDC_CONSTANT_MACROS +#define __STDC_CONSTANT_MACROS +#endif +#include "AUD_FFMPEGReader.h" +#endif + #include "AUD_FileFactory.h" #include "AUD_Buffer.h" #include <cstring> -#ifdef WITH_FFMPEG -#include "AUD_FFMPEGReader.h" -#endif #ifdef WITH_SNDFILE #include "AUD_SndFileReader.h" #endif -AUD_FileFactory::AUD_FileFactory(const char* filename) +AUD_FileFactory::AUD_FileFactory(std::string filename) : + m_filename(filename) { - if(filename != NULL) - { - m_filename = new char[strlen(filename)+1]; AUD_NEW("string") - strcpy(m_filename, filename); - } - else - m_filename = NULL; } -AUD_FileFactory::AUD_FileFactory(unsigned char* buffer, int size) +AUD_FileFactory::AUD_FileFactory(const data_t* buffer, int size) : + m_buffer(new AUD_Buffer(size)) { - m_filename = NULL; - m_buffer = AUD_Reference<AUD_Buffer>(new AUD_Buffer(size)); memcpy(m_buffer.get()->getBuffer(), buffer, size); } -AUD_FileFactory::~AUD_FileFactory() -{ - if(m_filename) - { - delete[] m_filename; AUD_DELETE("string") - } -} +static const char* read_error = "AUD_FileFactory: File couldn't be read."; -AUD_IReader* AUD_FileFactory::createReader() +AUD_IReader* AUD_FileFactory::createReader() const { - AUD_IReader* reader = 0; - #ifdef WITH_SNDFILE try { - if(m_filename) - reader = new AUD_SndFileReader(m_filename); + if(m_buffer.get()) + return new AUD_SndFileReader(m_buffer); else - reader = new AUD_SndFileReader(m_buffer); - AUD_NEW("reader") - return reader; + return new AUD_SndFileReader(m_filename); } - catch(AUD_Exception e) {} + catch(AUD_Exception&) {} #endif #ifdef WITH_FFMPEG try { - if(m_filename) - reader = new AUD_FFMPEGReader(m_filename); + if(m_buffer.get()) + return new AUD_FFMPEGReader(m_buffer); else - reader = new AUD_FFMPEGReader(m_buffer); - AUD_NEW("reader") - return reader; + return new AUD_FFMPEGReader(m_filename); } - catch(AUD_Exception e) {} + catch(AUD_Exception&) {} #endif - return reader; + AUD_THROW(AUD_ERROR_FILE, read_error); } |