diff options
author | Max Horn | 2010-01-23 00:02:01 +0000 |
---|---|---|
committer | Max Horn | 2010-01-23 00:02:01 +0000 |
commit | c3c7071948010c6418f8246b82232832ef5c48c4 (patch) | |
tree | c2d214e73dc22c0e66c1dd961f0a71cbc15c0806 /engines | |
parent | 0b7ae99ad4245695f490d8b41c90bf90a1213542 (diff) | |
download | scummvm-rg350-c3c7071948010c6418f8246b82232832ef5c48c4.tar.gz scummvm-rg350-c3c7071948010c6418f8246b82232832ef5c48c4.tar.bz2 scummvm-rg350-c3c7071948010c6418f8246b82232832ef5c48c4.zip |
AGOS: Unify code related to compressed sound
svn-id: r47455
Diffstat (limited to 'engines')
-rw-r--r-- | engines/agos/sound.cpp | 117 |
1 files changed, 33 insertions, 84 deletions
diff --git a/engines/agos/sound.cpp b/engines/agos/sound.cpp index 19fe689f17..670f8bf9a7 100644 --- a/engines/agos/sound.cpp +++ b/engines/agos/sound.cpp @@ -403,6 +403,32 @@ void FlacSound::playSound(uint sound, uint loopSound, Audio::Mixer::SoundType ty /////////////////////////////////////////////////////////////////////////////// #pragma mark - +static BaseSound *makeCompressedSound(Audio::Mixer *mixer, File *file, const Common::String &basename) { +#ifdef USE_FLAC + file->open(basename + ".fla"); + if (file->isOpen()) { + return new FlacSound(mixer, file); + } +#endif +#ifdef USE_VORBIS + file->open(basename + ".ogg"); + if (file->isOpen()) { + return new VorbisSound(mixer, file); + } +#endif +#ifdef USE_MAD + file->open(basename + ".mp3"); + if (file->isOpen()) { + return new MP3Sound(mixer, file); + } +#endif + return 0; +} + + +/////////////////////////////////////////////////////////////////////////////// +#pragma mark - + Sound::Sound(AGOSEngine *vm, const GameSpecificSettings *gss, Audio::Mixer *mixer) : _vm(vm), _mixer(mixer) { _voice = 0; @@ -451,36 +477,10 @@ void Sound::loadVoiceFile(const GameSpecificSettings *gss) { char filename[16]; File *file = new File(); -#ifdef USE_FLAC if (!_hasVoiceFile) { - sprintf(filename, "%s.fla", gss->speech_filename); - file->open(filename); - if (file->isOpen()) { - _hasVoiceFile = true; - _voice = new FlacSound(_mixer, file); - } + _voice = makeCompressedSound(_mixer, file, gss->speech_filename); + _hasVoiceFile = (_voice != 0); } -#endif -#ifdef USE_VORBIS - if (!_hasVoiceFile) { - sprintf(filename, "%s.ogg", gss->speech_filename); - file->open(filename); - if (file->isOpen()) { - _hasVoiceFile = true; - _voice = new VorbisSound(_mixer, file); - } - } -#endif -#ifdef USE_MAD - if (!_hasVoiceFile) { - sprintf(filename, "%s.mp3", gss->speech_filename); - file->open(filename); - if (file->isOpen()) { - _hasVoiceFile = true; - _voice = new MP3Sound(_mixer, file); - } - } -#endif if (!_hasVoiceFile && _vm->getGameType() == GType_SIMON2) { // for simon2 mac/amiga, only read index file file->open("voices.idx"); @@ -532,36 +532,10 @@ void Sound::loadSfxFile(const GameSpecificSettings *gss) { char filename[16]; File *file = new File(); -#ifdef USE_FLAC if (!_hasEffectsFile) { - sprintf(filename, "%s.fla", gss->effects_filename); - file->open(filename); - if (file->isOpen()) { - _hasEffectsFile = true; - _effects = new FlacSound(_mixer, file); - } - } -#endif -#ifdef USE_VORBIS - if (!_hasEffectsFile) { - sprintf(filename, "%s.ogg", gss->effects_filename); - file->open(filename); - if (file->isOpen()) { - _hasEffectsFile = true; - _effects = new VorbisSound(_mixer, file); - } - } -#endif -#ifdef USE_MAD - if (!_hasEffectsFile) { - sprintf(filename, "%s.mp3", gss->effects_filename); - file->open(filename); - if (file->isOpen()) { - _hasEffectsFile = true; - _effects = new MP3Sound(_mixer, file); - } + _effects = makeCompressedSound(_mixer, file, gss->effects_filename); + _hasEffectsFile = (_effects != 0); } -#endif const bool dataIsUnsigned = (_vm->getGameType() == GType_PP || _vm->getGameType() == GType_FF || _vm->getGameId() == GID_SIMON1CD32); @@ -859,36 +833,11 @@ void Sound::switchVoiceFile(const GameSpecificSettings *gss, uint disc) { char filename[16]; File *file = new File(); -#ifdef USE_FLAC - if (!_hasVoiceFile) { - sprintf(filename, "%s%d.fla", gss->speech_filename, disc); - file->open(filename); - if (file->isOpen()) { - _hasVoiceFile = true; - _voice = new FlacSound(_mixer, file); - } - } -#endif -#ifdef USE_VORBIS - if (!_hasVoiceFile) { - sprintf(filename, "%s%d.ogg", gss->speech_filename, disc); - file->open(filename); - if (file->isOpen()) { - _hasVoiceFile = true; - _voice = new VorbisSound(_mixer, file); - } - } -#endif -#ifdef USE_MAD if (!_hasVoiceFile) { - sprintf(filename, "%s%d.mp3", gss->speech_filename, disc); - file->open(filename); - if (file->isOpen()) { - _hasVoiceFile = true; - _voice = new MP3Sound(_mixer, file); - } + sprintf(filename, "%s%d", gss->speech_filename, disc); + _voice = makeCompressedSound(_mixer, file, filename); + _hasVoiceFile = (_voice != 0); } -#endif if (!_hasVoiceFile) { sprintf(filename, "%s%d.wav", gss->speech_filename, disc); file->open(filename); |