2007-05-30 21:56:52 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
2005-04-21 01:30:07 +00:00
|
|
|
*
|
2007-05-30 21:56:52 +00:00
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
2005-04-21 01:30:07 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2008-01-05 12:45:14 +00:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2005-04-21 01:30:07 +00:00
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
2005-10-18 01:30:26 +00:00
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2005-04-21 01:30:07 +00:00
|
|
|
*
|
2006-02-11 12:44:16 +00:00
|
|
|
* $URL$
|
|
|
|
* $Id$
|
2005-04-21 01:30:07 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "common/config-manager.h"
|
|
|
|
#include "common/savefile.h"
|
|
|
|
#include "common/system.h"
|
|
|
|
#include "common/file.h"
|
2008-11-10 14:11:30 +00:00
|
|
|
#include "graphics/thumbnail.h"
|
2005-04-21 01:30:07 +00:00
|
|
|
|
|
|
|
#include "saga/saga.h"
|
|
|
|
#include "saga/actor.h"
|
2005-08-11 22:00:32 +00:00
|
|
|
#include "saga/events.h"
|
|
|
|
#include "saga/interface.h"
|
2005-04-21 01:30:07 +00:00
|
|
|
#include "saga/isomap.h"
|
2005-08-11 22:00:32 +00:00
|
|
|
#include "saga/music.h"
|
|
|
|
#include "saga/render.h"
|
2005-04-21 01:30:07 +00:00
|
|
|
#include "saga/scene.h"
|
2005-08-11 22:00:32 +00:00
|
|
|
#include "saga/script.h"
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2009-01-11 14:44:29 +00:00
|
|
|
#define CURRENT_SAGA_VER 7
|
2005-05-15 14:46:13 +00:00
|
|
|
|
2005-04-21 01:30:07 +00:00
|
|
|
namespace Saga {
|
|
|
|
|
2005-05-31 20:08:46 +00:00
|
|
|
static SaveFileData emptySlot = {
|
2005-08-11 14:03:10 +00:00
|
|
|
"", 0
|
2005-05-31 20:08:46 +00:00
|
|
|
};
|
2005-05-28 11:06:55 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
char* SagaEngine::calcSaveFileName(uint slotNumber) {
|
|
|
|
static char name[MAX_FILE_NAME];
|
|
|
|
sprintf(name, "%s.s%02d", _targetName.c_str(), slotNumber);
|
|
|
|
return name;
|
|
|
|
}
|
|
|
|
|
2005-05-31 20:08:46 +00:00
|
|
|
SaveFileData *SagaEngine::getSaveFile(uint idx) {
|
2007-09-22 22:37:20 +00:00
|
|
|
if (idx >= MAX_SAVES) {
|
2005-05-23 18:53:36 +00:00
|
|
|
error("getSaveFileName wrong idx");
|
|
|
|
}
|
2005-05-31 20:08:46 +00:00
|
|
|
if (isSaveListFull()) {
|
|
|
|
return &_saveFiles[_saveFilesCount - idx - 1];
|
2005-05-28 11:06:55 +00:00
|
|
|
} else {
|
2005-08-11 14:03:10 +00:00
|
|
|
if (!emptySlot.name[0])
|
2005-08-16 19:04:51 +00:00
|
|
|
strcpy(emptySlot.name, getTextString(kTextNewSave));
|
2005-08-11 14:03:10 +00:00
|
|
|
|
2005-05-31 20:08:46 +00:00
|
|
|
return (idx == 0) ? &emptySlot : &_saveFiles[_saveFilesCount - idx];
|
2005-07-29 17:58:00 +00:00
|
|
|
}
|
2005-05-23 18:53:36 +00:00
|
|
|
}
|
|
|
|
|
2005-05-31 20:08:46 +00:00
|
|
|
bool SagaEngine::locateSaveFile(char *saveName, uint &titleNumber) {
|
|
|
|
uint i;
|
|
|
|
for (i = 0; i < _saveFilesCount; i++) {
|
|
|
|
if (strcmp(saveName, _saveFiles[i].name) == 0) {
|
|
|
|
if (isSaveListFull()) {
|
|
|
|
titleNumber = _saveFilesCount - i - 1;
|
|
|
|
} else {
|
|
|
|
titleNumber = _saveFilesCount - i;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint SagaEngine::getNewSaveSlotNumber() {
|
2005-06-02 16:18:44 +00:00
|
|
|
uint i, j;
|
|
|
|
bool found;
|
|
|
|
for (i = 0; i < MAX_SAVES; i++) {
|
2007-09-23 15:53:49 +00:00
|
|
|
found = false;
|
|
|
|
for (j = 0; j < _saveFilesCount; j++) {
|
|
|
|
if (_saveFiles[j].slotNumber == i) {
|
|
|
|
found = true;
|
|
|
|
break;
|
2005-06-02 16:18:44 +00:00
|
|
|
}
|
2005-05-31 20:08:46 +00:00
|
|
|
}
|
2007-09-23 15:53:49 +00:00
|
|
|
if (!found) {
|
|
|
|
return i;
|
|
|
|
}
|
2005-05-31 20:08:46 +00:00
|
|
|
}
|
2005-06-02 16:18:44 +00:00
|
|
|
|
|
|
|
error("getNewSaveSlotNumber save list is full");
|
2005-05-31 20:08:46 +00:00
|
|
|
}
|
2005-05-23 18:53:36 +00:00
|
|
|
|
2009-04-09 15:59:22 +00:00
|
|
|
static int compareSaveFileData(const void *a, const void *b) {
|
|
|
|
const SaveFileData *s1 = (const SaveFileData *)a;
|
|
|
|
const SaveFileData *s2 = (const SaveFileData *)b;
|
|
|
|
|
|
|
|
if (s1->slotNumber < s2->slotNumber) {
|
|
|
|
return -1;
|
|
|
|
} else if (s1->slotNumber > s2->slotNumber) {
|
|
|
|
return 1;
|
|
|
|
} else {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
void SagaEngine::fillSaveList() {
|
2007-09-19 08:40:12 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
int i;
|
|
|
|
Common::InSaveFile *in;
|
2007-07-12 17:58:15 +00:00
|
|
|
Common::StringList filenames;
|
2007-09-30 14:32:21 +00:00
|
|
|
char slot[3];
|
2007-09-23 15:53:49 +00:00
|
|
|
int slotNumber;
|
2005-05-23 18:53:36 +00:00
|
|
|
char *name;
|
2005-07-29 17:58:00 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
name = calcSaveFileName(MAX_SAVES);
|
2007-07-12 17:58:15 +00:00
|
|
|
name[strlen(name) - 2] = '*';
|
|
|
|
name[strlen(name) - 1] = 0;
|
2007-09-19 08:40:12 +00:00
|
|
|
|
2007-07-12 17:58:15 +00:00
|
|
|
filenames = _saveFileMan->listSavefiles(name);
|
2007-09-19 08:40:12 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
for (i = 0; i < MAX_SAVES; i++) {
|
2005-05-31 20:08:46 +00:00
|
|
|
_saveFiles[i].name[0] = 0;
|
|
|
|
_saveFiles[i].slotNumber = (uint)-1;
|
2005-07-29 17:58:00 +00:00
|
|
|
}
|
|
|
|
|
2005-05-31 20:08:46 +00:00
|
|
|
_saveFilesCount = 0;
|
2005-07-29 17:58:00 +00:00
|
|
|
|
2007-09-23 15:53:49 +00:00
|
|
|
for (Common::StringList::iterator file = filenames.begin(); file != filenames.end(); file++){
|
|
|
|
//Obtain the last 2 digits of the filename, since they correspond to the save slot
|
|
|
|
slot[0] = file->c_str()[file->size()-2];
|
|
|
|
slot[1] = file->c_str()[file->size()-1];
|
2007-09-30 14:31:47 +00:00
|
|
|
slot[2] = 0;
|
2007-09-23 15:53:49 +00:00
|
|
|
|
|
|
|
slotNumber = atoi(slot);
|
|
|
|
if (slotNumber >= 0 && slotNumber < MAX_SAVES) {
|
|
|
|
name = calcSaveFileName(slotNumber);
|
2005-06-02 22:14:57 +00:00
|
|
|
if ((in = _saveFileMan->openForLoading(name)) != NULL) {
|
2006-02-25 11:12:44 +00:00
|
|
|
_saveHeader.type = in->readUint32BE();
|
|
|
|
_saveHeader.size = in->readUint32LE();
|
|
|
|
_saveHeader.version = in->readUint32LE();
|
|
|
|
in->read(_saveHeader.name, sizeof(_saveHeader.name));
|
2005-06-02 16:18:44 +00:00
|
|
|
|
2006-02-25 11:12:44 +00:00
|
|
|
if (_saveHeader.type != MKID_BE('SAGA')) {
|
2006-06-07 09:31:52 +00:00
|
|
|
warning("SagaEngine::load wrong save %s format", name);
|
|
|
|
i++;
|
|
|
|
continue;
|
2005-06-02 16:18:44 +00:00
|
|
|
}
|
2005-06-05 16:53:53 +00:00
|
|
|
strcpy(_saveFiles[_saveFilesCount].name, _saveHeader.name);
|
2007-09-23 15:53:49 +00:00
|
|
|
_saveFiles[_saveFilesCount].slotNumber = slotNumber;
|
2005-06-02 16:18:44 +00:00
|
|
|
delete in;
|
|
|
|
_saveFilesCount++;
|
2005-05-23 18:53:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-04-09 15:59:22 +00:00
|
|
|
|
|
|
|
qsort(_saveFiles, _saveFilesCount, sizeof(_saveFiles[0]), compareSaveFileData);
|
2005-05-23 18:53:36 +00:00
|
|
|
}
|
|
|
|
|
2005-05-15 14:46:13 +00:00
|
|
|
void SagaEngine::save(const char *fileName, const char *saveName) {
|
2005-05-23 18:53:36 +00:00
|
|
|
Common::OutSaveFile *out;
|
2005-10-16 17:19:52 +00:00
|
|
|
char title[TITLESIZE];
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
if (!(out = _saveFileMan->openForSaving(fileName))) {
|
|
|
|
return;
|
|
|
|
}
|
2005-05-15 14:46:13 +00:00
|
|
|
|
2006-02-25 11:12:44 +00:00
|
|
|
_saveHeader.type = MKID_BE('SAGA');
|
2005-06-05 16:53:53 +00:00
|
|
|
_saveHeader.size = 0;
|
2006-02-25 11:12:44 +00:00
|
|
|
_saveHeader.version = CURRENT_SAGA_VER;
|
2007-08-26 15:57:30 +00:00
|
|
|
// Note that IHNM has a smaller save title size than ITE
|
|
|
|
// We allocate the ITE save title size here, to preserve
|
|
|
|
// savegame backwards compatibility
|
2005-09-03 07:56:42 +00:00
|
|
|
strncpy(_saveHeader.name, saveName, SAVE_TITLE_SIZE);
|
2005-05-15 14:46:13 +00:00
|
|
|
|
2006-02-25 11:12:44 +00:00
|
|
|
out->writeUint32BE(_saveHeader.type);
|
|
|
|
out->writeUint32LE(_saveHeader.size);
|
|
|
|
out->writeUint32LE(_saveHeader.version);
|
|
|
|
out->write(_saveHeader.name, sizeof(_saveHeader.name));
|
|
|
|
|
2005-10-16 17:19:52 +00:00
|
|
|
// Original game title
|
|
|
|
memset(title, 0, TITLESIZE);
|
2006-03-14 13:28:28 +00:00
|
|
|
strncpy(title, _gameTitle.c_str(), TITLESIZE);
|
2005-10-16 17:19:52 +00:00
|
|
|
out->write(title, TITLESIZE);
|
|
|
|
|
2008-11-10 14:11:30 +00:00
|
|
|
// Thumbnail
|
|
|
|
Graphics::saveThumbnail(*out);
|
|
|
|
|
|
|
|
// Date / time
|
2009-10-08 19:41:38 +00:00
|
|
|
TimeDate curTime;
|
2008-11-10 14:11:30 +00:00
|
|
|
_system->getTimeAndDate(curTime);
|
|
|
|
|
2008-11-29 18:01:16 +00:00
|
|
|
uint32 saveDate = ((curTime.tm_mday & 0xFF) << 24) | (((curTime.tm_mon + 1) & 0xFF) << 16) | ((curTime.tm_year + 1900) & 0xFFFF);
|
|
|
|
uint16 saveTime = ((curTime.tm_hour & 0xFF) << 8) | ((curTime.tm_min) & 0xFF);
|
2008-11-10 14:11:30 +00:00
|
|
|
|
|
|
|
out->writeUint32BE(saveDate);
|
|
|
|
out->writeUint16BE(saveTime);
|
|
|
|
// TODO: played time
|
|
|
|
|
2005-04-21 01:30:07 +00:00
|
|
|
// Surrounding scene
|
2005-05-23 18:53:36 +00:00
|
|
|
out->writeSint32LE(_scene->getOutsetSceneNumber());
|
2009-01-02 16:52:38 +00:00
|
|
|
#ifdef ENABLE_IHNM
|
2008-12-21 15:59:05 +00:00
|
|
|
if (getGameId() == GID_IHNM) {
|
2007-06-19 01:37:48 +00:00
|
|
|
out->writeSint32LE(_scene->currentChapterNumber());
|
2007-06-17 15:45:09 +00:00
|
|
|
// Protagonist
|
2007-06-19 01:37:48 +00:00
|
|
|
out->writeSint32LE(_scene->currentProtag());
|
2007-06-19 02:42:59 +00:00
|
|
|
out->writeSint32LE(_scene->getCurrentMusicTrack());
|
|
|
|
out->writeSint32LE(_scene->getCurrentMusicRepeat());
|
2007-06-17 15:45:09 +00:00
|
|
|
}
|
2009-01-02 16:52:38 +00:00
|
|
|
#endif
|
2005-04-21 01:30:07 +00:00
|
|
|
// Inset scene
|
2005-05-23 18:53:36 +00:00
|
|
|
out->writeSint32LE(_scene->currentSceneNumber());
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2009-01-02 16:52:38 +00:00
|
|
|
#ifdef ENABLE_IHNM
|
2008-12-21 15:59:05 +00:00
|
|
|
if (getGameId() == GID_IHNM) {
|
2005-09-26 07:22:32 +00:00
|
|
|
out->writeUint32LE(_globalFlags);
|
|
|
|
for (int i = 0; i < ARRAYSIZE(_ethicsPoints); i++)
|
2005-10-04 23:38:19 +00:00
|
|
|
out->writeSint16LE(_ethicsPoints[i]);
|
2005-09-26 07:22:32 +00:00
|
|
|
}
|
2009-01-02 16:52:38 +00:00
|
|
|
#endif
|
2005-09-26 07:22:32 +00:00
|
|
|
|
2005-05-12 15:11:32 +00:00
|
|
|
_interface->saveState(out);
|
|
|
|
|
2005-04-28 17:19:43 +00:00
|
|
|
_actor->saveState(out);
|
2005-07-29 17:58:00 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
out->writeSint16LE(_script->_commonBufferSize);
|
2005-05-08 14:04:06 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
out->write(_script->_commonBuffer, _script->_commonBufferSize);
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2009-01-11 14:44:29 +00:00
|
|
|
// ISO map x, y coordinates for ITE
|
|
|
|
if (getGameId() == GID_ITE) {
|
|
|
|
out->writeSint16LE(_isoMap->getMapPosition().x);
|
|
|
|
out->writeSint16LE(_isoMap->getMapPosition().y);
|
|
|
|
}
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2007-02-17 18:55:51 +00:00
|
|
|
out->finalize();
|
2005-11-05 14:24:13 +00:00
|
|
|
|
2009-05-19 11:42:14 +00:00
|
|
|
if (out->err())
|
2007-12-08 17:48:51 +00:00
|
|
|
warning("Can't write file '%s'. (Disk full?)", fileName);
|
2005-11-05 14:24:13 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
delete out;
|
2005-04-21 01:30:07 +00:00
|
|
|
}
|
|
|
|
|
2005-05-08 14:04:06 +00:00
|
|
|
void SagaEngine::load(const char *fileName) {
|
2005-05-23 18:53:36 +00:00
|
|
|
Common::InSaveFile *in;
|
2005-10-11 17:39:31 +00:00
|
|
|
int commonBufferSize;
|
2005-05-08 14:04:06 +00:00
|
|
|
int sceneNumber, insetSceneNumber;
|
2005-04-22 01:38:27 +00:00
|
|
|
int mapx, mapy;
|
2005-10-16 17:19:52 +00:00
|
|
|
char title[TITLESIZE];
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
if (!(in = _saveFileMan->openForLoading(fileName))) {
|
2005-04-21 01:30:07 +00:00
|
|
|
return;
|
2005-05-23 18:53:36 +00:00
|
|
|
}
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2006-02-25 11:12:44 +00:00
|
|
|
_saveHeader.type = in->readUint32BE();
|
|
|
|
_saveHeader.size = in->readUint32LE();
|
|
|
|
_saveHeader.version = in->readUint32LE();
|
|
|
|
in->read(_saveHeader.name, sizeof(_saveHeader.name));
|
|
|
|
|
|
|
|
// Some older saves were not written in an endian safe fashion.
|
|
|
|
// We try to detect this here by checking for extremly high version values.
|
|
|
|
// If found, we retry with the data swapped.
|
|
|
|
if (_saveHeader.version > 0xFFFFFF) {
|
2007-08-20 20:00:40 +00:00
|
|
|
warning("This savegame is not endian safe, retrying with the data swapped");
|
2006-02-25 11:12:44 +00:00
|
|
|
_saveHeader.version = SWAP_BYTES_32(_saveHeader.version);
|
2005-10-26 18:11:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
debug(2, "Save version: %x", _saveHeader.version);
|
|
|
|
|
2005-10-11 17:20:30 +00:00
|
|
|
if (_saveHeader.version < 4)
|
|
|
|
warning("This savegame is not endian-safe. There may be problems");
|
|
|
|
|
2006-02-25 11:12:44 +00:00
|
|
|
if (_saveHeader.type != MKID_BE('SAGA')) {
|
2007-12-08 17:48:51 +00:00
|
|
|
error("SagaEngine::load wrong save game format");
|
2005-05-15 14:46:13 +00:00
|
|
|
}
|
2005-07-29 17:58:00 +00:00
|
|
|
|
2005-10-16 17:19:52 +00:00
|
|
|
if (_saveHeader.version > 4) {
|
|
|
|
in->read(title, TITLESIZE);
|
2005-10-26 18:11:11 +00:00
|
|
|
debug(0, "Save is for: %s", title);
|
2005-10-16 17:19:52 +00:00
|
|
|
}
|
|
|
|
|
2008-11-10 14:11:30 +00:00
|
|
|
if (_saveHeader.version >= 6) {
|
2008-11-10 18:51:51 +00:00
|
|
|
// We don't need the thumbnail here, so just read it and discard it
|
|
|
|
Graphics::Surface *thumbnail = new Graphics::Surface();
|
|
|
|
assert(thumbnail);
|
|
|
|
Graphics::loadThumbnail(*in, *thumbnail);
|
|
|
|
delete thumbnail;
|
|
|
|
thumbnail = 0;
|
2008-11-10 14:11:30 +00:00
|
|
|
|
|
|
|
in->readUint32BE(); // save date
|
|
|
|
in->readUint16BE(); // save time
|
|
|
|
// TODO: played time
|
|
|
|
}
|
|
|
|
|
2009-01-17 21:45:53 +00:00
|
|
|
// Clear pending events here, and don't process queued music events
|
|
|
|
_events->clearList(false);
|
|
|
|
|
2005-04-21 01:30:07 +00:00
|
|
|
// Surrounding scene
|
2005-05-23 18:53:36 +00:00
|
|
|
sceneNumber = in->readSint32LE();
|
2009-01-02 16:52:38 +00:00
|
|
|
#ifdef ENABLE_IHNM
|
2008-12-21 15:59:05 +00:00
|
|
|
if (getGameId() == GID_IHNM) {
|
2007-06-19 11:41:06 +00:00
|
|
|
int currentChapter = _scene->currentChapterNumber();
|
2007-06-19 01:37:48 +00:00
|
|
|
_scene->setChapterNumber(in->readSint32LE());
|
|
|
|
_scene->setProtag(in->readSint32LE());
|
2007-06-19 11:41:06 +00:00
|
|
|
if (_scene->currentChapterNumber() != currentChapter)
|
2007-06-19 01:37:48 +00:00
|
|
|
_scene->changeScene(-2, 0, kTransitionFade, _scene->currentChapterNumber());
|
2007-06-19 02:42:59 +00:00
|
|
|
_scene->setCurrentMusicTrack(in->readSint32LE());
|
|
|
|
_scene->setCurrentMusicRepeat(in->readSint32LE());
|
|
|
|
_music->stop();
|
2007-08-26 00:45:07 +00:00
|
|
|
if (_scene->currentChapterNumber() == 8)
|
|
|
|
_interface->setMode(kPanelChapterSelection);
|
2008-12-21 15:59:05 +00:00
|
|
|
if (!(getFeatures() & GF_IHNM_DEMO)) {
|
2007-09-19 08:40:12 +00:00
|
|
|
_music->play(_music->_songTable[_scene->getCurrentMusicTrack()], _scene->getCurrentMusicRepeat() ? MUSIC_LOOP : MUSIC_NORMAL);
|
2007-08-26 03:32:18 +00:00
|
|
|
} else {
|
2007-07-31 00:06:57 +00:00
|
|
|
_music->play(3, MUSIC_LOOP);
|
2007-08-26 03:32:18 +00:00
|
|
|
}
|
2007-06-17 15:45:09 +00:00
|
|
|
}
|
2009-01-02 16:52:38 +00:00
|
|
|
#endif
|
2005-04-21 01:30:07 +00:00
|
|
|
|
|
|
|
// Inset scene
|
2005-05-23 18:53:36 +00:00
|
|
|
insetSceneNumber = in->readSint32LE();
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2009-01-02 16:52:38 +00:00
|
|
|
#ifdef ENABLE_IHNM
|
2008-12-21 15:59:05 +00:00
|
|
|
if (getGameId() == GID_IHNM) {
|
2005-09-26 07:22:32 +00:00
|
|
|
_globalFlags = in->readUint32LE();
|
|
|
|
for (int i = 0; i < ARRAYSIZE(_ethicsPoints); i++)
|
2005-10-04 23:38:19 +00:00
|
|
|
_ethicsPoints[i] = in->readSint16LE();
|
2005-09-26 07:22:32 +00:00
|
|
|
}
|
2009-01-02 16:52:38 +00:00
|
|
|
#endif
|
2005-09-26 07:22:32 +00:00
|
|
|
|
2005-05-12 15:11:32 +00:00
|
|
|
_interface->loadState(in);
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2005-04-28 17:19:43 +00:00
|
|
|
_actor->loadState(in);
|
2005-07-29 17:58:00 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
commonBufferSize = in->readSint16LE();
|
|
|
|
in->read(_script->_commonBuffer, commonBufferSize);
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2009-01-11 14:44:29 +00:00
|
|
|
if (getGameId() == GID_ITE) {
|
|
|
|
mapx = in->readSint16LE();
|
|
|
|
mapy = in->readSint16LE();
|
|
|
|
_isoMap->setMapPosition(mapx, mapy);
|
|
|
|
}
|
|
|
|
// Note: the mapx, mapy ISO map positions were incorrectly saved
|
|
|
|
// for IHNM too, which has no ISO map scenes, up to save version 6.
|
|
|
|
// Since they're at the end of the savegame, we just ignore them
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2005-05-23 18:53:36 +00:00
|
|
|
delete in;
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2005-08-11 22:00:32 +00:00
|
|
|
// Mute volume to prevent outScene music play
|
|
|
|
int volume = _music->getVolume();
|
|
|
|
_music->setVolume(0);
|
|
|
|
|
2009-01-02 16:52:38 +00:00
|
|
|
#ifdef ENABLE_IHNM
|
2007-06-17 15:45:09 +00:00
|
|
|
// Protagonist swapping
|
2008-12-21 15:59:05 +00:00
|
|
|
if (getGameId() == GID_IHNM) {
|
2007-06-19 01:37:48 +00:00
|
|
|
if (_scene->currentProtag() != 0 && _scene->currentChapterNumber() != 6) {
|
|
|
|
ActorData *actor1 = _actor->getFirstActor();
|
2007-08-13 15:57:04 +00:00
|
|
|
ActorData *actor2;
|
|
|
|
// The original gets actor2 from the current protagonist ID, but this is sometimes wrong
|
|
|
|
// If the current protagonist ID is not correct, use the stored protagonist
|
|
|
|
if (!_actor->validActorId(_scene->currentProtag())) {
|
|
|
|
actor2 = _actor->_protagonist;
|
|
|
|
} else {
|
|
|
|
actor2 = _actor->getActor(_scene->currentProtag());
|
|
|
|
}
|
2007-06-20 01:45:38 +00:00
|
|
|
|
2007-06-19 01:37:48 +00:00
|
|
|
SWAP(actor1->_location, actor2->_location);
|
|
|
|
|
|
|
|
actor2->_flags &= ~kProtagonist;
|
|
|
|
actor1->_flags |= kProtagonist;
|
|
|
|
_actor->_protagonist = _actor->_centerActor = actor1;
|
|
|
|
_scene->setProtag(actor1->_id);
|
|
|
|
}
|
2007-06-17 15:45:09 +00:00
|
|
|
}
|
2009-01-02 16:52:38 +00:00
|
|
|
#endif
|
2007-06-17 15:45:09 +00:00
|
|
|
|
2005-04-21 01:30:07 +00:00
|
|
|
_scene->clearSceneQueue();
|
2005-05-08 14:04:06 +00:00
|
|
|
_scene->changeScene(sceneNumber, ACTOR_NO_ENTRANCE, kTransitionNoFade);
|
2005-08-11 22:00:32 +00:00
|
|
|
|
2005-09-03 07:56:42 +00:00
|
|
|
_events->handleEvents(0); //dissolve backgrounds
|
2005-04-21 01:30:07 +00:00
|
|
|
|
2005-05-08 14:04:06 +00:00
|
|
|
if (insetSceneNumber != sceneNumber) {
|
2005-07-05 15:15:35 +00:00
|
|
|
_render->setFlag(RF_DISABLE_ACTORS);
|
2007-09-16 03:20:10 +00:00
|
|
|
_scene->draw();
|
2005-04-22 01:38:27 +00:00
|
|
|
_render->drawScene();
|
2005-07-05 15:15:35 +00:00
|
|
|
_render->clearFlag(RF_DISABLE_ACTORS);
|
2005-05-08 14:04:06 +00:00
|
|
|
_scene->changeScene(insetSceneNumber, ACTOR_NO_ENTRANCE, kTransitionNoFade);
|
2005-04-21 01:30:07 +00:00
|
|
|
}
|
2005-07-08 15:09:58 +00:00
|
|
|
|
2005-08-11 22:00:32 +00:00
|
|
|
_music->setVolume(volume);
|
|
|
|
|
2005-07-08 15:09:58 +00:00
|
|
|
_interface->draw();
|
2005-04-21 01:30:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
} // End of namespace Saga
|