VOYEUR: Workaround original game using invalid hotspot Ids

This commit is contained in:
Paul Gilbert 2017-08-07 19:20:05 -04:00
parent da4d4d8272
commit 659fdfaf9e
4 changed files with 7 additions and 4 deletions

View File

@ -43,7 +43,7 @@ SVoy::SVoy(VoyeurEngine *vm):_vm(vm) {
_abortInterface = false;
_isAM = false;
Common::fill(&_phoneCallsReceived[0], &_phoneCallsReceived[5], false);
Common::fill(&_roomHotspotsEnabled[0], &_roomHotspotsEnabled[20], false);
Common::fill(&_roomHotspotsEnabled[0], &_roomHotspotsEnabled[32], false);
_victimMurdered = false;
_audioVisualStartTime = 0;
@ -118,7 +118,8 @@ void SVoy::synchronize(Common::Serializer &s) {
_audioHotspotTimes.synchronize(s);
_evidenceHotspotTimes.synchronize(s);
for (int idx = 0; idx < 20; ++idx) {
int count = s.getVersion() == 1 ? 20 : 32;
for (int idx = 0; idx < count; ++idx) {
s.syncAsByte(_roomHotspotsEnabled[idx]);
}

View File

@ -113,7 +113,7 @@ public:
bool _abortInterface;
bool _isAM;
bool _phoneCallsReceived[5];
bool _roomHotspotsEnabled[20];
bool _roomHotspotsEnabled[32];
bool _victimMurdered;
int _aptLoadMode;

View File

@ -793,6 +793,7 @@ void VoyeurEngine::loadGame(int slot) {
header._thumbnail->free();
delete header._thumbnail;
serializer.setVersion(header._version);
synchronize(serializer);
delete saveFile;
@ -821,6 +822,7 @@ Common::Error VoyeurEngine::saveGameState(int slot, const Common::String &desc)
Common::Serializer serializer(NULL, saveFile);
// Synchronise the data
serializer.setVersion(VOYEUR_SAVEGAME_VERSION);
synchronize(serializer);
saveFile->finalize();

View File

@ -296,7 +296,7 @@ public:
void showEndingNews();
};
#define VOYEUR_SAVEGAME_VERSION 1
#define VOYEUR_SAVEGAME_VERSION 2
/**
* Header for Voyeur savegame files