diff options
Diffstat (limited to 'engines')
-rw-r--r-- | engines/saga/rscfile.cpp | 261 |
1 files changed, 123 insertions, 138 deletions
diff --git a/engines/saga/rscfile.cpp b/engines/saga/rscfile.cpp index d645d178c5..edb0ec4b59 100644 --- a/engines/saga/rscfile.cpp +++ b/engines/saga/rscfile.cpp @@ -358,13 +358,21 @@ bool Resource::createContexts() { int voicesFileIndex = 0; bool digitalMusic = false; bool soundFileInArray = false; - bool voicesFileInArray = false; bool multipleVoices = false; bool censoredVersion = false; uint16 voiceFileType = GAME_VOICEFILE; + bool fileFound = false; + int maxFile = 0; _vm->_voiceFilesExist = true; + struct SoundFileInfo { + char fileName[40]; + bool isCompressed; + }; + + SoundFileInfo *curSoundfiles; + // If the Wyrmkeep credits file is found, set the Wyrmkeep version flag to true if (Common::File::exists("graphics/credit3n.dlt")) { _vm->_gf_wyrmkeep = true; @@ -375,172 +383,149 @@ bool Resource::createContexts() { _contextsCount++; if (_vm->getFilesDescriptions()[i].fileType == GAME_SOUNDFILE) soundFileInArray = true; - if (_vm->getFilesDescriptions()[i].fileType == GAME_VOICEFILE) - voicesFileInArray = true; } + //// Detect and add SFX files //////////////////////////////////////////////// + SoundFileInfo sfxFilesITE[] = { + { "sounds.rsc", false }, + { "sounds.cmp", true }, + { "soundsd.rsc", false }, + { "soundsd.cmp", true } + }; + + SoundFileInfo sfxFilesIHNM[] = { + { "sfx.res", false }, + { "sfx.cmp", true } + }; + if (!soundFileInArray) { - if (_vm->getGameType() == GType_ITE) { - // If the sound file is not specified in the detector table, add it here - if (Common::File::exists("sounds.rsc")) { - _contextsCount++; - soundFileIndex = _contextsCount - 1; - sprintf(soundFileName, "sounds.rsc"); - } else if (Common::File::exists("sounds.cmp")) { - _contextsCount++; - soundFileIndex = _contextsCount - 1; - sprintf(soundFileName, "sounds.cmp"); - _vm->_gf_compressed_sounds = true; - } else if (Common::File::exists("soundsd.rsc")) { - _contextsCount++; - soundFileIndex = _contextsCount - 1; - sprintf(soundFileName, "soundsd.rsc"); - } else if (Common::File::exists("soundsd.cmp")) { + // If the sound file is not specified in the detector table, add it here + fileFound = false; + curSoundfiles = _vm->getGameType() == GType_ITE ? sfxFilesITE : sfxFilesIHNM; + maxFile = _vm->getGameType() == GType_ITE ? 4 : 2; + + for (i = 0; i < maxFile; i++) { + if (Common::File::exists(curSoundfiles[i].fileName)) { _contextsCount++; soundFileIndex = _contextsCount - 1; - sprintf(soundFileName, "soundsd.cmp"); - _vm->_gf_compressed_sounds = true; - } else { - // No sound file found, don't add any file to the array - soundFileInArray = true; + sprintf(soundFileName, curSoundfiles[i].fileName); + _vm->_gf_compressed_sounds = curSoundfiles[i].isCompressed; + fileFound = true; + break; + } + } + + if (!fileFound) { + // No sound file found, don't add any file to the array + soundFileInArray = true; + if (_vm->getGameType() == GType_ITE) { // ITE floppy versions have both voices and sounds in voices.rsc voiceFileType = GAME_SOUNDFILE | GAME_VOICEFILE; } - } else { - // If the sound file is not specified in the detector table, add it here - if (Common::File::exists("sfx.res")) { - _contextsCount++; - soundFileIndex = _contextsCount - 1; - sprintf(soundFileName, "sfx.res"); - } else if (Common::File::exists("sfx.cmp")) { - _contextsCount++; - soundFileIndex = _contextsCount - 1; - sprintf(soundFileName, "sfx.cmp"); - _vm->_gf_compressed_sounds = true; - } else { - // No sound file found, don't add any file to the array - soundFileInArray = true; - } } } - if (!voicesFileInArray) { - if (_vm->getGameType() == GType_ITE) { - // If the voices file is not specified in the detector table, add it here - if (Common::File::exists("voices.rsc")) { - _contextsCount++; - voicesFileIndex = _contextsCount - 1; - sprintf(_voicesFileName[0], "voices.rsc"); - } else if (Common::File::exists("voices.cmp")) { - _contextsCount++; - voicesFileIndex = _contextsCount - 1; - sprintf(_voicesFileName[0], "voices.cmp"); - _vm->_gf_compressed_sounds = true; - } else if (Common::File::exists("voicesd.rsc")) { - _contextsCount++; - voicesFileIndex = _contextsCount - 1; - sprintf(_voicesFileName[0], "voicesd.rsc"); - } else if (Common::File::exists("voicesd.cmp")) { - _contextsCount++; - voicesFileIndex = _contextsCount - 1; - sprintf(_voicesFileName[0], "voicesd.cmp"); - _vm->_gf_compressed_sounds = true; - } else if (Common::File::exists("inherit the earth voices") || - Common::File::exists("inherit the earth voices.cmp")) { - _contextsCount++; - voicesFileIndex = _contextsCount - 1; - if (Common::File::exists("inherit the earth voices")) { - sprintf(_voicesFileName[0], "inherit the earth voices"); - } else { - sprintf(_voicesFileName[0], "inherit the earth voices.cmp"); - _vm->_gf_compressed_sounds = true; - } - + //// Detect and add voice files ///////////////////////////////////////////// + SoundFileInfo voiceFilesITE[] = { + { "voices.rsc", false }, + { "voices.cmp", true }, + { "voicesd.rsc", false }, + { "voicesd.cmp", true }, + { "inherit the earth voices", false }, + { "inherit the earth voices.cmp", true }, + { "ite voices.bin", false } + }; + + SoundFileInfo voiceFilesIHNM[] = { + { "voicess.res", false }, + { "voicess.cmp", true }, + { "voicesd.res", false }, + { "voicesd.cmp", true }, + }; + + // Detect and add voice files + fileFound = false; + curSoundfiles = _vm->getGameType() == GType_ITE ? voiceFilesITE : voiceFilesIHNM; + maxFile = _vm->getGameType() == GType_ITE ? 4 : 2; + + for (i = 0; i < maxFile; i++) { + if (Common::File::exists(curSoundfiles[i].fileName)) { + _contextsCount++; + voicesFileIndex = _contextsCount - 1; + sprintf(_voicesFileName[0], curSoundfiles[i].fileName); + _vm->_gf_compressed_sounds = curSoundfiles[i].isCompressed; + fileFound = true; + + // Special cases + if (!stricmp(curSoundfiles[i].fileName, "inherit the earth voices") || + !stricmp(curSoundfiles[i].fileName, "inherit the earth voices.cmp")) { // The resources in the Wyrmkeep combined Windows/Mac/Linux CD version are little endian, but // the voice file is big endian. If we got such a version with mixed files, mark this voice file // as big endian if (!_vm->isBigEndian()) voiceFileType = GAME_VOICEFILE | GAME_SWAPENDIAN; // This file is big endian - } else if (Common::File::exists("ite voices.bin")) { // MacBinary voice files - _contextsCount++; - voicesFileIndex = _contextsCount - 1; - sprintf(_voicesFileName[0], "ite voices.bin"); + } + + if (!stricmp(curSoundfiles[i].fileName, "ite voices.bin")) { voiceFileType = GAME_VOICEFILE | GAME_MACBINARY; - } else { - // No voice file found, don't add any file to the array - voicesFileInArray = true; - warning("No voice file found, voices will be disabled"); - _vm->_voicesEnabled = false; - _vm->_subtitlesEnabled = true; - _vm->_voiceFilesExist = false; } - } else { - // If the voices file is not specified in the detector table, add it here - if (Common::File::exists("voicess.res") || Common::File::exists("voicess.cmp")) { - _contextsCount++; - voicesFileIndex = _contextsCount - 1; + + if (!stricmp(curSoundfiles[i].fileName, "voicess.res") || + !stricmp(curSoundfiles[i].fileName, "voicess.cmp")) { // IHNM has multiple voice files multipleVoices = true; - // Note: it is assumed that the voices are always last in the list + // Note: it is assumed that the voice files are always last in the list if (Common::File::exists("voices4.res") || Common::File::exists("voices4.cmp")) { _contextsCount += 6; // voices1-voices6 } else { - // The German and French versions of IHNM don't have Nimdok's chapter, therefore the voices file - // for that chapter is missing + // The German and French versions of IHNM don't have Nimdok's chapter, + // therefore the voices file for that chapter is missing _contextsCount += 5; // voices1-voices3, voices4-voices5 censoredVersion = true; } - if (Common::File::exists("voicess.res")) { - sprintf(_voicesFileName[0], "voicess.res"); - } else { - sprintf(_voicesFileName[0], "voicess.cmp"); - _vm->_gf_compressed_sounds = true; - } - } else if (Common::File::exists("voicesd.res")) { - _contextsCount++; - voicesFileIndex = _contextsCount - 1; - sprintf(_voicesFileName[0], "voicesd.res"); - } else if (Common::File::exists("voicesd.cmp")) { - _contextsCount++; - voicesFileIndex = _contextsCount - 1; - sprintf(_voicesFileName[0], "voicesd.cmp"); - _vm->_gf_compressed_sounds = true; - } else { - // No voice file found, don't add any file to the array - voicesFileInArray = true; - - if (_vm->getGameType() == GType_IHNM && _vm->isMacResources()) { - // The Macintosh version of IHNM has no voices.res, and it has all - // its voice files in subdirectories, so don't do anything here - } else { - warning("No voice file found, voices will be disabled"); - _vm->_voicesEnabled = false; - _vm->_subtitlesEnabled = true; - _vm->_voiceFilesExist = false; - } } + + break; } } - if (_vm->getGameType() == GType_ITE) { - // Check for digital music in ITE - if (Common::File::exists("music.rsc")) { - _contextsCount++; - digitalMusic = true; - sprintf(musicFileName, "music.rsc"); - } else if (Common::File::exists("music.cmp")) { - _contextsCount++; - digitalMusic = true; - sprintf(musicFileName, "music.cmp"); - } else if (Common::File::exists("musicd.rsc")) { - _contextsCount++; - digitalMusic = true; - sprintf(musicFileName, "musicd.rsc"); - } else if (Common::File::exists("musicd.cmp")) { - _contextsCount++; - digitalMusic = true; - sprintf(musicFileName, "musicd.cmp"); + if (!fileFound) { + if (_vm->getGameType() == GType_IHNM && _vm->isMacResources()) { + // The Macintosh version of IHNM has no voices.res, and it has all + // its voice files in subdirectories, so don't do anything here } else { + warning("No voice file found, voices will be disabled"); + _vm->_voicesEnabled = false; + _vm->_subtitlesEnabled = true; + _vm->_voiceFilesExist = false; + } + } + + //// Detect and add ITE music files ///////////////////////////////////////// + // We don't set the compressed flag here + SoundFileInfo musicFilesITE[] = { + { "music.rsc", true }, + { "music.cmp", true }, + { "musicd.rsc", true }, + { "musicd.cmp", true }, + }; + + // Check for digital music in ITE + if (_vm->getGameType() == GType_ITE) { + fileFound = false; + + for (i = 0; i < 4; i++) { + if (Common::File::exists(musicFilesITE[i].fileName)) { + _contextsCount++; + digitalMusic = true; + fileFound = true; + sprintf(musicFileName, musicFilesITE[i].fileName); + break; + } + } + + if (!fileFound) { + // No sound file found, don't add any file to the array digitalMusic = false; } } @@ -559,12 +544,12 @@ bool Resource::createContexts() { } else if (!soundFileInArray && i == soundFileIndex) { context->fileName = soundFileName; context->fileType = GAME_SOUNDFILE; - } else if (!voicesFileInArray && i == voicesFileIndex) { + } else if (_vm->_voiceFilesExist && i == voicesFileIndex) { context->fileName = _voicesFileName[0]; // can be GAME_VOICEFILE or GAME_SOUNDFILE | GAME_VOICEFILE or GAME_VOICEFILE | GAME_SWAPENDIAN context->fileType = voiceFileType; } else { - if (!(!voicesFileInArray && multipleVoices && (i > voicesFileIndex))) { + if (!(_vm->_voiceFilesExist && multipleVoices && (i > voicesFileIndex))) { context->fileName = _vm->getFilesDescriptions()[i].fileName; context->fileType = _vm->getFilesDescriptions()[i].fileType; } else { |