diff options
-rw-r--r-- | engines/saga/sndres.cpp | 42 |
1 files changed, 15 insertions, 27 deletions
diff --git a/engines/saga/sndres.cpp b/engines/saga/sndres.cpp index 243202cb6b..4a32e4f929 100644 --- a/engines/saga/sndres.cpp +++ b/engines/saga/sndres.cpp @@ -183,7 +183,7 @@ bool SndRes::load(ResourceContext *context, uint32 resourceId, SoundBuffer &buff int size; byte flags; size_t voxSize; - const GameSoundInfo *soundInfo; + const GameSoundInfo *soundInfo = 0; Common::File* file; if (resourceId == (uint32)-1) { @@ -240,7 +240,7 @@ bool SndRes::load(ResourceContext *context, uint32 resourceId, SoundBuffer &buff resourceType = kSoundAIFF; } else if (!memcmp(header, "ajkg", 4) != 0) { resourceType = kSoundShorten; - } else { + } else if (soundInfo) { resourceType = soundInfo->resourceType; } @@ -269,43 +269,32 @@ bool SndRes::load(ResourceContext *context, uint32 resourceId, SoundBuffer &buff buffer.isBigEndian = _vm->isMacResources(); buffer.soundType = resourceType; buffer.originalSize = 0; + buffer.stereo = false; switch (resourceType) { case kSoundPCM: - buffer.frequency = 22050; - buffer.isSigned = soundInfo->isSigned; - buffer.sampleBits = soundInfo->sampleBits; - buffer.size = soundResourceLength; - buffer.stereo = false; - if (onlyHeader) { - buffer.buffer = NULL; - } else { - buffer.buffer = (byte *) malloc(soundResourceLength); - readS.read(buffer.buffer, soundResourceLength); - } - result = true; - break; case kSoundMacPCM: + { + int soundOffset = (resourceType == kSoundMacPCM) ? 36 : 0; buffer.frequency = 22050; buffer.isSigned = soundInfo->isSigned; buffer.sampleBits = soundInfo->sampleBits; - buffer.size = soundResourceLength - 36; - buffer.stereo = false; + buffer.size = soundResourceLength - soundOffset; if (onlyHeader) { buffer.buffer = NULL; } else { - buffer.buffer = (byte *)malloc(buffer.size); - - readS.seek(readS.pos() + 36); + buffer.buffer = (byte *) malloc(buffer.size); + if (soundOffset > 0) + readS.seek(soundOffset, SEEK_CUR); readS.read(buffer.buffer, buffer.size); } result = true; + } break; case kSoundVOX: buffer.frequency = 22050; buffer.isSigned = soundInfo->isSigned; buffer.sampleBits = soundInfo->sampleBits; - buffer.stereo = false; buffer.size = soundResourceLength * 4; if (onlyHeader) { buffer.buffer = NULL; @@ -325,7 +314,6 @@ bool SndRes::load(ResourceContext *context, uint32 resourceId, SoundBuffer &buff if (data) { buffer.frequency = rate; buffer.sampleBits = 8; - buffer.stereo = false; buffer.isSigned = false; buffer.size = size; if (onlyHeader) { @@ -340,9 +328,9 @@ bool SndRes::load(ResourceContext *context, uint32 resourceId, SoundBuffer &buff case kSoundWAV: if (Audio::loadWAVFromStream(readS, size, rate, flags)) { buffer.frequency = rate; - buffer.sampleBits = 16; - buffer.stereo = ((flags & Audio::Mixer::FLAG_STEREO) != 0); - buffer.isSigned = true; + buffer.sampleBits = (flags & Audio::Mixer::FLAG_16BITS) ? 16 : 8; + buffer.stereo = flags & Audio::Mixer::FLAG_STEREO; + buffer.isSigned = !(flags & Audio::Mixer::FLAG_UNSIGNED); buffer.size = size; if (onlyHeader) { buffer.buffer = NULL; @@ -356,8 +344,8 @@ bool SndRes::load(ResourceContext *context, uint32 resourceId, SoundBuffer &buff case kSoundAIFF: if (Audio::loadAIFFFromStream(readS, size, rate, flags)) { buffer.frequency = rate; - buffer.sampleBits = 16; - buffer.stereo = ((flags & Audio::Mixer::FLAG_STEREO) != 0); + buffer.sampleBits = (flags & Audio::Mixer::FLAG_16BITS) ? 16 : 8; + buffer.stereo = flags & Audio::Mixer::FLAG_STEREO; buffer.isSigned = true; buffer.size = size; if (onlyHeader) { |