mirror of
https://github.com/libretro/scummvm.git
synced 2024-12-15 22:28:10 +00:00
- Cleanup
- This time fixed the real cause of the mismatching malloc / delete[] call. svn-id: r36191
This commit is contained in:
parent
8f91046af4
commit
9df7f7385c
@ -125,15 +125,28 @@ void Sound::voicePlayFromList(Common::List<const char*> fileList) {
|
|||||||
Audio::AppendableAudioStream *out = Audio::makeAppendableAudioStream(22050, Audio::Mixer::FLAG_AUTOFREE | Audio::Mixer::FLAG_UNSIGNED);
|
Audio::AppendableAudioStream *out = Audio::makeAppendableAudioStream(22050, Audio::Mixer::FLAG_AUTOFREE | Audio::Mixer::FLAG_UNSIGNED);
|
||||||
|
|
||||||
for (Common::List<const char*>::iterator i = fileList.begin(); i != fileList.end(); i++) {
|
for (Common::List<const char*>::iterator i = fileList.begin(); i != fileList.end(); i++) {
|
||||||
uint32 fileSize = 0;
|
Common::SeekableReadStream *file = _vm->resource()->createReadStream(*i);
|
||||||
uint8 *file = _vm->resource()->fileData(*i, &fileSize);
|
|
||||||
Common::MemoryReadStream vocStream(file, fileSize, false);
|
// TODO: Maybe output an warning like "file not found"?
|
||||||
|
if (!file)
|
||||||
|
continue;
|
||||||
|
|
||||||
int size, rate;
|
int size, rate;
|
||||||
uint8 *data = Audio::loadVOCFromStream(vocStream, size, rate);
|
uint8 *data = Audio::loadVOCFromStream(*file, size, rate);
|
||||||
out->queueBuffer(data, size);
|
delete file;
|
||||||
delete[] file;
|
|
||||||
|
// FIXME/HACK: While loadVOCStream uses malloc / realloc,
|
||||||
|
// AppendableAudioStream uses delete[] to free the passed buffer.
|
||||||
|
// As a consequence we just 'move' the data to a buffer allocated
|
||||||
|
// via new[].
|
||||||
|
uint8 *vocBuffer = new uint8[size];
|
||||||
|
assert(vocBuffer);
|
||||||
|
memcpy(vocBuffer, data, size);
|
||||||
|
free(data);
|
||||||
|
|
||||||
|
out->queueBuffer(vocBuffer, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
out->finish();
|
out->finish();
|
||||||
|
|
||||||
_soundChannels[h].file = *fileList.begin();
|
_soundChannels[h].file = *fileList.begin();
|
||||||
|
Loading…
Reference in New Issue
Block a user