From 018f9fc27841aa1922797a22d9bcc7aabe81e9f1 Mon Sep 17 00:00:00 2001 From: Chris Robinson Date: Tue, 30 Nov 2010 00:32:13 -0800 Subject: [PATCH] Handle all channel configurations for double --- OpenAL32/alBuffer.c | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/OpenAL32/alBuffer.c b/OpenAL32/alBuffer.c index bba92b21..bad6f85d 100644 --- a/OpenAL32/alBuffer.c +++ b/OpenAL32/alBuffer.c @@ -297,14 +297,22 @@ AL_API ALvoid AL_APIENTRY alBufferData(ALuint buffer,ALenum format,const ALvoid alSetError(Context, err); break; - case SrcFmtDouble: - if(SrcChannels == SrcFmtMono) - err = LoadData(ALBuf, freq, AL_FORMAT_MONO_FLOAT32, size, SrcChannels, SrcType, data); - else - err = LoadData(ALBuf, freq, AL_FORMAT_STEREO_FLOAT32, size, SrcChannels, SrcType, data); + case SrcFmtDouble: { + ALenum NewFormat = AL_FORMAT_MONO_FLOAT32; + switch(SrcChannels) + { + case SrcFmtMono: NewFormat = AL_FORMAT_MONO_FLOAT32; break; + case SrcFmtStereo: NewFormat = AL_FORMAT_STEREO_FLOAT32; break; + case SrcFmtRear: NewFormat = AL_FORMAT_REAR32; break; + case SrcFmtQuad: NewFormat = AL_FORMAT_QUAD32; break; + case SrcFmtX51: NewFormat = AL_FORMAT_51CHN32; break; + case SrcFmtX61: NewFormat = AL_FORMAT_61CHN32; break; + case SrcFmtX71: NewFormat = AL_FORMAT_71CHN32; break; + } + err = LoadData(ALBuf, freq, NewFormat, size, SrcChannels, SrcType, data); if(err != AL_NO_ERROR) alSetError(Context, err); - break; + } break; case SrcFmtMulaw: case SrcFmtIMA4: {