// $Id$
-#include <AL/al.h>
-#include <AL/alut.h>
+#if defined( __APPLE__ )
+# define AL_ILLEGAL_ENUM AL_INVALID_ENUM
+# define AL_ILLEGAL_COMMAND AL_INVALID_OPERATION
+# include <OpenAL/al.h>
+# include <OpenAL/alut.h>
+#else
+# include <AL/al.h>
+# include <AL/alut.h>
+#endif
#include <simgear/debug/logstream.hxx>
#include <simgear/misc/sg_path.hxx>
// constructor
-SGSoundSample::SGSoundSample( const char *path, const char *file ) :
+SGSoundSample::SGSoundSample( const char *path, const char *file,
+ bool cleanup ) :
+ data(NULL),
pitch(1.0),
volume(1.0),
loop(AL_FALSE)
if ( strlen(file) ) {
samplepath.append( file );
}
-
- SG_LOG( SG_GENERAL, SG_ALERT, "From file sounds sample = "
+
+ sample_name = samplepath.str();
+
+ SG_LOG( SG_GENERAL, SG_DEBUG, "From file sounds sample = "
<< samplepath.str() );
ALuint error;
if ( error != AL_NO_ERROR ) {
print_openal_error( error );
throw sg_exception("Failed to gen OpenAL buffer.");
- } else {
- SG_LOG( SG_GENERAL, SG_ALERT, "Buffer created ok!" );
}
// Load the sample file
+#if defined (__APPLE__)
+ alutLoadWAVFile( (ALbyte *)samplepath.c_str(),
+ &format, &data, &size, &freq );
+#else
alutLoadWAVFile( (ALbyte *)samplepath.c_str(),
&format, &data, &size, &freq, &loop );
+#endif
if (alGetError() != AL_NO_ERROR) {
throw sg_exception("Failed to load wav file.");
}
throw sg_exception("Failed to buffer data.");
}
- alutUnloadWAV( format, data, size, freq );
+ if ( cleanup ) {
+ alutUnloadWAV( format, data, size, freq );
+ data = NULL;
+ }
// Bind buffer with a source.
alGenSources(1, &source);
// constructor
SGSoundSample::SGSoundSample( unsigned char *_data, int len, int _freq ) :
+ data(NULL),
pitch(1.0),
volume(1.0),
loop(AL_FALSE)
{
- SG_LOG( SG_GENERAL, SG_ALERT, "In memory sounds sample" );
+ SG_LOG( SG_GENERAL, SG_DEBUG, "In memory sounds sample" );
+
+ sample_name = "unknown, generated from data";
source_pos[0] = 0.0; source_pos[1] = 0.0; source_pos[2] = 0.0;
source_vel[0] = 0.0; source_vel[1] = 0.0; source_vel[2] = 0.0;
// Load wav data into a buffer.
alGenBuffers(1, &buffer);
if (alGetError() != AL_NO_ERROR) {
- SG_LOG( SG_GENERAL, SG_ALERT, "Error in alGenBuffers()" );
+ throw sg_exception("Failed to gen buffer." );
return;
}
// destructor
SGSoundSample::~SGSoundSample() {
- SG_LOG( SG_GENERAL, SG_ALERT, "Deleting a sample" );
+ SG_LOG( SG_GENERAL, SG_INFO, "Deleting a sample" );
+ if ( data != NULL ) {
+ free(data);
+ }
alDeleteSources(1, &source);
alDeleteBuffers(1, &buffer);
}