diff options
author | Sven Hesse | 2008-05-11 18:55:40 +0000 |
---|---|---|
committer | Sven Hesse | 2008-05-11 18:55:40 +0000 |
commit | c5498a69bfaee74e2b5b046b36512c8a5d4785f9 (patch) | |
tree | 5af2b119460ce499b4e36cbb6195e688849c2f54 /engines/gob/saveload_v4.cpp | |
parent | 4b21c2958ddf3cf1e69f427c715406d76712bed1 (diff) | |
download | scummvm-rg350-c5498a69bfaee74e2b5b046b36512c8a5d4785f9.tar.gz scummvm-rg350-c5498a69bfaee74e2b5b046b36512c8a5d4785f9.tar.bz2 scummvm-rg350-c5498a69bfaee74e2b5b046b36512c8a5d4785f9.zip |
Implemented temp buffer saving/loading ("SAVE.TMP") in Woodruff.
Objects you take from or leave in screens are remembered correctly now.
svn-id: r32030
Diffstat (limited to 'engines/gob/saveload_v4.cpp')
-rw-r--r-- | engines/gob/saveload_v4.cpp | 66 |
1 files changed, 65 insertions, 1 deletions
diff --git a/engines/gob/saveload_v4.cpp b/engines/gob/saveload_v4.cpp index 2235b4834e..75e44cc1bc 100644 --- a/engines/gob/saveload_v4.cpp +++ b/engines/gob/saveload_v4.cpp @@ -27,12 +27,13 @@ #include "gob/gob.h" #include "gob/saveload.h" +#include "gob/global.h" #include "gob/game.h" namespace Gob { SaveLoad_v4::SaveFile SaveLoad_v4::_saveFiles[] = { - { "", 0, kSaveModeNone, kSaveNone } + { "save.tmp", 0, kSaveModeSave, kSaveTempBuffer } }; SaveLoad_v4::SaveLoad_v4(GobEngine *vm, const char *targetName) : @@ -45,31 +46,94 @@ SaveLoad_v4::~SaveLoad_v4() { } SaveLoad::SaveMode SaveLoad_v4::getSaveMode(const char *fileName) { + fileName = stripPath(fileName); + + for (int i = 0; i < ARRAYSIZE(_saveFiles); i++) + if (!scumm_stricmp(fileName, _saveFiles[i].sourceName)) + return _saveFiles[i].mode; + return kSaveModeNone; } int SaveLoad_v4::getSaveType(const char *fileName) { + for (int i = 0; i < ARRAYSIZE(_saveFiles); i++) + if (!scumm_stricmp(fileName, _saveFiles[i].sourceName)) + return i; + return -1; } int32 SaveLoad_v4::getSizeVersioned(int type) { assertInited(); + switch (_saveFiles[type].type) { + case kSaveTempBuffer: + return getSizeTempBuffer(_saveFiles[type]); + default: + break; + } + return -1; } bool SaveLoad_v4::loadVersioned(int type, int16 dataVar, int32 size, int32 offset) { assertInited(); + switch (_saveFiles[type].type) { + case kSaveTempBuffer: + if (loadTempBuffer(_saveFiles[type], dataVar, size, offset)) + return true; + + warning("While loading from the tempBuffer"); + break; + + default: + break; + } + return false; } bool SaveLoad_v4::saveVersioned(int type, int16 dataVar, int32 size, int32 offset) { assertInited(); + switch (_saveFiles[type].type) { + case kSaveTempBuffer: + if (saveTempBuffer(_saveFiles[type], dataVar, size, offset)) + return true; + + warning("While saving to the tempBuffer"); + break; + + default: + break; + } + return false; } +int32 SaveLoad_v4::getSizeTempBuffer(SaveFile &saveFile) { + return _tmpBuffer.getSize(); +} + +bool SaveLoad_v4::loadTempBuffer(SaveFile &saveFile, + int16 dataVar, int32 size, int32 offset) { + + debugC(3, kDebugSaveLoad, "Loading from the temporary buffer (%d, %d, %d)", + dataVar, size, offset); + + return _tmpBuffer.read(_vm->_global->_inter_variables + dataVar, size, offset); +} + +bool SaveLoad_v4::saveTempBuffer(SaveFile &saveFile, + int16 dataVar, int32 size, int32 offset) { + + debugC(3, kDebugSaveLoad, "Saving to the temporary buffer (%d, %d, %d)", + dataVar, size, offset); + + return _tmpBuffer.write(_vm->_global->_inter_variables + dataVar, size, offset); +} + void SaveLoad_v4::assertInited() { if (_varSize > 0) return; |