diff options
| author | Nicola Mettifogo | 2007-02-19 12:54:58 +0000 |
|---|---|---|
| committer | Nicola Mettifogo | 2007-02-19 12:54:58 +0000 |
| commit | 745d814caaaace321b29a619263f5f398747c7b4 (patch) | |
| tree | de99703ea1ba41c530327ffb0e84165ad7573e0a /engines/parallaction/saveload.cpp | |
| parent | 1121fe494856f0d45ac52ac8f4ce59022fbbdfd7 (diff) | |
| download | scummvm-rg350-745d814caaaace321b29a619263f5f398747c7b4.tar.gz scummvm-rg350-745d814caaaace321b29a619263f5f398747c7b4.tar.bz2 scummvm-rg350-745d814caaaace321b29a619263f5f398747c7b4.zip | |
renamed file to follow common convention
svn-id: r25719
Diffstat (limited to 'engines/parallaction/saveload.cpp')
| -rw-r--r-- | engines/parallaction/saveload.cpp | 773 |
1 files changed, 773 insertions, 0 deletions
diff --git a/engines/parallaction/saveload.cpp b/engines/parallaction/saveload.cpp new file mode 100644 index 0000000000..36b49e9580 --- /dev/null +++ b/engines/parallaction/saveload.cpp @@ -0,0 +1,773 @@ +/* ScummVM - Scumm Interpreter + * Copyright (C) 2006 The ScummVM project + * + * 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 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * 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 + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + * $URL$ + * $Id$ + * + */ + + +#include "parallaction/parallaction.h" +#include "parallaction/disk.h" +#include "parallaction/inventory.h" +#include "parallaction/graphics.h" +#include "parallaction/zone.h" + +#include "common/savefile.h" + +#include "gui/widget.h" +#include "gui/ListWidget.h" +#include "gui/message.h" + +/* Nippon Safes savefiles are called 'game.0' to 'game.9'. The game conventiently allows users to + * give meanigful name to savegames, and it uses an extra file 'savegame' to keep track of these + * names. + * + * This re-implementation disposes of the extra file to make moving of savefiles easier. Debugging + * will benefit from this, too. The savegame name is written as the first line of the savefile + * itself, thus breaking compatibility with the original version. Who cares anyway? + */ + + +namespace Parallaction { + + +extern char _gameNames[][20]; + +void Parallaction::doLoadGame(uint16 slot) { + + _introSarcData3 = 200; + _introSarcData2 = 1; + + char filename[PATH_LEN]; + sprintf(filename, "game.%i", slot); + + Common::InSaveFile *f = _saveFileMan->openForLoading(filename); + if (!f) return; + + char s[30]; + + f->readLine(s, 29); + + f->readLine(_vm->_characterName, 15); + f->readLine(_location, 15); + + strcat(_location, "."); + + f->readLine(s, 15); + _firstPosition._x = atoi(s); + + f->readLine(s, 15); + _firstPosition._y = atoi(s); + + f->readLine(s, 15); + _score = atoi(s); + + f->readLine(s, 15); + _commandFlags = atoi(s); + + f->readLine(s, 15); + + _engineFlags |= kEngineQuit; + freeZones(_zones._next); + freeNodeList(_zones._next); + _zones._next = NULL; + _engineFlags &= ~kEngineQuit; + + _numLocations = atoi(s); + + uint16 _si; + for (_si = 0; _si < _numLocations; _si++) { + f->readLine(s, 20); + s[strlen(s)] = '\0'; + + strcpy(_locationNames[_si], s); + + f->readLine(s, 15); + _localFlags[_si] = atoi(s); + } + _locationNames[_si][0] = '\0'; + + for (_si = 0; _si < 30; _si++) { + f->readLine(s, 15); + _inventory[_si]._id = atoi(s); + + f->readLine(s, 15); + _inventory[_si]._index = atoi(s); + } + + delete f; + + _engineFlags &= ~kEngineMiniDonna; + if (!scumm_stricmp(_vm->_characterName, "donnatras")) { + _engineFlags |= kEngineMiniDonna; + strcpy(_vm->_characterName, "donna"); + } + if (!scumm_stricmp(_vm->_characterName, "minidonnatras")) { + _engineFlags |= kEngineMiniDonna; + strcpy(_vm->_characterName, "minidonna"); + } + + if (_vm->_characterName[0] == 'm') { + strcpy(filename, _vm->_characterName+4); + } else { + strcpy(filename, _vm->_characterName); + } + strcat(filename, ".tab"); + freeTable(_objectsNames); + initTable(filename, _objectsNames); + + refreshInventory(_vm->_characterName); + + parseLocation("common"); + closeArchive(); + + strcat(_location, _vm->_characterName); + _engineFlags |= kEngineChangeLocation; + +#if 0 + printf("game loaded: character %s, location %s\n", _vm->_characterName, _location); +#endif + + return; +} + + +void Parallaction::doSaveGame(uint16 slot, const char* name) { + + char path[PATH_LEN]; + sprintf(path, "game.%i", slot); + + Common::OutSaveFile *f = _saveFileMan->openForSaving(path); + if (f == 0) { + char buf[32]; + sprintf(buf, "Can't save game in slot %i\n\n(%s)", slot, path); + GUI::MessageDialog dialog(buf); + dialog.runModal(); + return; + } + + char s[30]; + + if (!name || name[0] == '\0') { + sprintf(s, "default_%i", slot); + } else { + strncpy(s, name, 29); + } + + f->writeString(s); + f->writeString("\n"); + + if (_engineFlags & kEngineMiniDonna) { + sprintf(s, "%stras\n", _vm->_characterName); + } else { + sprintf(s, "%s\n", _vm->_characterName); + } + f->writeString(s); + + sprintf(s, "%s\n", _saveData1); + f->writeString(s); + sprintf(s, "%d\n", _yourself._zone.pos._position._x); + f->writeString(s); + sprintf(s, "%d\n", _yourself._zone.pos._position._y); + f->writeString(s); + sprintf(s, "%d\n", _score); + f->writeString(s); + sprintf(s, "%u\n", _commandFlags); + f->writeString(s); + + sprintf(s, "%d\n", _numLocations); + f->writeString(s); + for (uint16 _si = 0; _si < _numLocations; _si++) { + sprintf(s, "%s\n%u\n", _locationNames[_si], _localFlags[_si]); + f->writeString(s); + } + + for (uint16 _si = 0; _si < 30; _si++) { + sprintf(s, "%u\n%d\n", _inventory[_si]._id, _inventory[_si]._index); + f->writeString(s); + } + + delete f; + + refreshInventory(_vm->_characterName); + + return; + + +} + +// FIXME: only to be implemented for text mode selection +void textModeFunc1( char *) { + +} + + + + +#if 0 +int16 selectSaveFile(uint16 arg_0) { + + REGISTERS pregs; + pregs._ax = (void*)(uint32)dos_videomode; + int86(0x10, &pregs); + +// window(0 ,0, 23, 79); + puts(" FILE NAME "); + + if (arg_0 != 0) { + printf("(Use \x18 \x19 \x10 to edit then press enter)\n\n"); + } else { + puts("\n"); + } + + uint16 _si; + for (_si = 0; _si < 11; _si++) { + printf(" %s \n", _gameNames[_si]); + } + + int16 _di = editSaveFileName(3, 13, 0, 12, 1, arg_0); + + pregs._ax = (void*)0x93; + int86(0x10, &pregs); + + set_vga_mode_x(0); + byte palette[PALETTE_SIZE]; + _vm->_graphics->getBlackPalette(palette); + _vm->_graphics->setPalette(palette); + + + _vm->_graphics->copyScreen(Graphics::kBit2, Graphics::kBitBack); + _vm->_graphics->copyScreen(Graphics::kBitBack, Graphics::kBitFront); + + if (arg_0 != 0) { + _vm->_graphics->setPalette(_palette); + } + + _vm->_graphics->swapBuffers(); + + return _si; +} + +int16 editSaveFileName(uint16 arg_0, uint16 arg_2, uint16 arg_4, uint16 arg_6, uint16 arg_8, uint16 arg_A) { + uint16 _di = arg_0; + uint16 _si = _di; + uint16 v4 = _di; + uint16 v1 = 0; + + do { + + set_cursor(_si, arg_4); + + while (v1 == 0) { + int16 v6 = get_kb(); + byte _al = v6 & 0xFF; + if (_al == 0) { + + _al = (v6 & 0xFF00) >> 8; + if (_al == 'H') { + if (_si<=_di) + _si = arg_2; + else + _si = _si - arg_8; + + v1 = 1; + } else + if (_al == 'M') { + + } else + if (_al == 'P') { + if (_si>=arg_2) + _si = _di; + else + _si = _si + arg_8; + + v1 = 1; + } + + if (_si != 0xD && arg_A != 0) { + + set_cursor(_si, arg_4+1); + v1 = 1; + textModeFunc1( _gameNames[(_si - _di)/arg_8] ); + + return (_si - _di)/arg_8 + 1; + + } + + } else + if (_al == 0xD) return (_si - _di)/arg_8 + 1; + } + + v1 = 0; + set_cursor(v4, arg_4); + v4 = _si; + + } while (true); + + return 0; + +} +#endif + +#if 0 +void loadGame() { + + uint16 v6 = 0; + uint16 v4 = 0; + uint16 v2 = 0; + uint16 _bx; + + FILE* stream = fopen("savegame", "r"); + if (stream) { + for (uint16 _si = 0; _si < 10; _si++) { + fgets(_gameNames[_si], 18, stream); + _bx = strlen(_gameNames[_si]) - 1; + _gameNames[_si][_bx] = '\0'; + } + fclose(stream); + } + + int16 _di = selectSaveFile( 0 ); + if (_di > 10) return; + + _introSarcData3 = 200; + _introSarcData2 = 1; + _moveSarcExaZones[0] = 0; + _moveSarcZones[0] = 0; + + char filename[PATH_LEN]; + sprintf(filename, "game.%d", _di); + stream = fopen(filename, "r"); + if (!stream) return; + + fgets(_vm->_characterName, 15, stream); + _vm->_characterName[strlen(_vm->_characterName)] = '\0'; + + fgets(_location, 15, stream); + _location[strlen(_location)] = '.'; + + char s[20]; + fgets(s, 15, stream); + _firstPosition._x = atoi(s); + + fgets(s, 15, stream); + _firstPosition._y = atoi(s); + + fgets(s, 15, stream); + _score = atoi(s); + + fgets(s, 15, stream); + _commandFlags = atoi(s); + + fgets(s, 15, stream); + + _engineFlags |= kEngineQuit; + freeZones(_zones._next); + freeNodeList(_zones._next); + _zones._next = NULL; + _engineFlags &= ~kEngineQuit; + + _numLocations = atoi(s); + + uint16 _si; + for (_si = 0; _si < _numLocations; _si++) { + fgets(s, 20, stream); + s[strlen(s)] = '\0'; + + strcpy(_locationNames[_si], s); + + fgets(s, 15, stream); + _localFlags[_si] = atoi(s); + } + _locationNames[_si] = '\0'; + + for (_si = 0; _si < 30; _si++) { + fgets(s, 15, stream); + _inventory[_si]._id = atoi(s); + + fgets(s, 15, stream); + _inventory[_si]._index = atoi(s); + } + + fclose(stream); + + _engineFlags &= ~kEngineMiniDonna; + if (!scumm_stricmp(_vm->_characterName, "donnatras")) { + _engineFlags |= kEngineMiniDonna; + strcpy(_vm->_characterName, "donna"); + } + if (!scumm_stricmp(_vm->_characterName, "minidonnatras")) { + _engineFlags |= kEngineMiniDonna; + strcpy(_vm->_characterName, "minidonna"); + } + + if (_vm->_characterName[0] == 'm') { + strcpy(filename, _vm->_characterName+4); + } else { + strcpy(filename, _vm->_characterName); + } + strcat(filename, ".tab"); + freeTable(_objectsNames); + initTable(filename, _objectsNames); + + refreshInventory(); + + parseLocation("common"); + closeArchive(); + + strcat(_location, _vm->_characterName); + _engineFlags |= kEngineChangeLocation; + + return; +} + + +int16 get_kb() { + + REGISTERS pregs; + pregs._ax = 0; + int86(0x16, &pregs); + + return (int16)(int32)pregs._ax; + +} + + +#endif + +#if 0 +void saveGame() { + +// strcpy(v30, asc_1C91A); + uint16 v8 = 0, v6 = 0; + int16 v4 = -1; + int16 v2 = 0; + + if (!scumm_stricmp(_location, "caveau")) return; + + FILE* stream = fopen("savegame", "r"); + if (stream) { + for (uint16 _si = 0; _si < 10; _si++) { + fgets(_gameNames[_si], 18, stream); + uint16 _bx = strlen(_gameNames[_si]) - 1; + _gameNames[_si][_bx] = '\0'; + } + fclose(stream); + } + + int16 _di = selectSaveFile( 1 ); + if (_di > 10) return; + + stream = fopen("savegame", "w"); + if (stream) { + for (uint16 _si = 0; _si < 10; _si++) { + fputs(_gameNames[_si], stream); + fputs("\n", stream); + } + fclose(stream); + } + + char path[PATH_LEN]; + sprintf(path, "game.%d", _di); + stream = fopen(path, "w"); + if (!stream) return; + + if (_engineFlags & kEngineMiniDonna) { + fprintf(stream, "%stras\n", _vm->_characterName); + } else { + fprintf(stream, "%s\n", _vm->_characterName); + } + + fprintf(stream, "%s\n", _saveData1); + fprintf(stream, "%d\n", _yourself._zone.pos._position._x); + fprintf(stream, "%d\n", _yourself._zone.pos._position._y); + fprintf(stream, "%d\n", _score); + fprintf(stream, "%ld\n", _commandFlags); + + fprintf(stream, "%d\n", _numLocations); + for (uint16 _si = 0; _si < _numLocations; _si++) { + fprintf(stream, "%s\n%ld\n", _locationNames[_si], _localFlags[_si]); + } + + for (uint16 _si = 0; _si < 30; _si++) { + fprintf(stream, "%ld\n%d\n", _inventory[_si]._id, _inventory[_si]._index); + } + + fclose(stream); + + refreshInventory(); + + return; +} +#endif + + + +enum { + kSaveCmd = 'SAVE', + kLoadCmd = 'LOAD', + kPlayCmd = 'PLAY', + kOptionsCmd = 'OPTN', + kHelpCmd = 'HELP', + kAboutCmd = 'ABOU', + kQuitCmd = 'QUIT', + kChooseCmd = 'CHOS' +}; + + + +SaveLoadChooser::SaveLoadChooser(const String &title, const String &buttonLabel, Parallaction *engine) + : Dialog("scummsaveload"), _list(0), _chooseButton(0), _gfxWidget(0), _vm(engine) { + +// _drawingHints |= GUI::THEME_HINT_SPECIAL_COLOR; + + new GUI::StaticTextWidget(this, "scummsaveload_title", title); + + // Add choice list + _list = new GUI::ListWidget(this, "scummsaveload_list"); + _list->setEditable(true); + _list->setNumberingMode(GUI::kListNumberingOne); + + _container = new GUI::ContainerWidget(this, 0, 0, 10, 10); + _container->setHints(GUI::THEME_HINT_USE_SHADOW); + + _gfxWidget = new GUI::GraphicsWidget(this, 0, 0, 10, 10); + + _date = new GUI::StaticTextWidget(this, 0, 0, 10, 10, "No date saved", GUI::kTextAlignCenter); + _time = new GUI::StaticTextWidget(this, 0, 0, 10, 10, "No time saved", GUI::kTextAlignCenter); + _playtime = new GUI::StaticTextWidget(this, 0, 0, 10, 10, "No playtime saved", GUI::kTextAlignCenter); + + // Buttons + new GUI::ButtonWidget(this, "scummsaveload_cancel", "Cancel", GUI::kCloseCmd, 0); + _chooseButton = new GUI::ButtonWidget(this, "scummsaveload_choose", buttonLabel, kChooseCmd, 0); + _chooseButton->setEnabled(false); +} + +SaveLoadChooser::~SaveLoadChooser() { +} + +const Common::String &SaveLoadChooser::getResultString() const { + return _list->getSelectedString(); +} + +void SaveLoadChooser::setList(const StringList& list) { + _list->setList(list); +} + +int SaveLoadChooser::runModal() { + if (_gfxWidget) + _gfxWidget->setGfx(0); + int ret = GUI::Dialog::runModal(); + return ret; +} + +void SaveLoadChooser::handleCommand(GUI::CommandSender *sender, uint32 cmd, uint32 data) { + int selItem = _list->getSelected(); + switch (cmd) { + case GUI::kListItemActivatedCmd: + case GUI::kListItemDoubleClickedCmd: + if (selItem >= 0) { + if (!getResultString().empty()) { + _list->endEditMode(); + setResult(selItem); + close(); + } + } + break; + case kChooseCmd: + _list->endEditMode(); + setResult(selItem); + close(); + break; + case GUI::kListSelectionChangedCmd: { + if (_gfxWidget) { + updateInfos(); + } + + _list->startEditMode(); + // Disable button if nothing is selected, or (in load mode) if an empty + // list item is selected. We allow choosing an empty item in save mode + // because we then just assign a default name. + _chooseButton->setEnabled(selItem >= 0 && (!getResultString().empty())); + _chooseButton->draw(); + } break; + case GUI::kCloseCmd: + setResult(-1); + default: + Dialog::handleCommand(sender, cmd, data); + } +} + +void SaveLoadChooser::reflowLayout() { + _container->setFlags(GUI::WIDGET_INVISIBLE); + _gfxWidget->setFlags(GUI::WIDGET_INVISIBLE); + _date->setFlags(GUI::WIDGET_INVISIBLE); + _time->setFlags(GUI::WIDGET_INVISIBLE); + _playtime->setFlags(GUI::WIDGET_INVISIBLE); + + Dialog::reflowLayout(); +} + +void SaveLoadChooser::updateInfos() { +/* int selItem = _list->getSelected(); + Graphics::Surface *thumb; + thumb = _vm->loadThumbnailFromSlot(selItem + 1); + + if (thumb) { + _gfxWidget->setGfx(thumb); + _gfxWidget->useAlpha(256); + thumb->free(); + } else { + _gfxWidget->setGfx(-1, -1, _fillR, _fillG, _fillB); + } + + delete thumb; + _gfxWidget->draw(); + + InfoStuff infos; + memset(&infos, 0, sizeof(InfoStuff)); + char buffer[32]; + if (_vm->loadInfosFromSlot(selItem + 1, &infos)) { + snprintf(buffer, 32, "Date: %.2d.%.2d.%.4d", + (infos.date >> 24) & 0xFF, (infos.date >> 16) & 0xFF, + infos.date & 0xFFFF); + _date->setLabel(buffer); + _date->draw(); + + snprintf(buffer, 32, "Time: %.2d:%.2d", + (infos.time >> 8) & 0xFF, infos.time & 0xFF); + _time->setLabel(buffer); + _time->draw(); + + int minutes = infos.playtime / 60; + int hours = minutes / 60; + minutes %= 60; + + snprintf(buffer, 32, "Playtime: %.2d:%.2d", + hours & 0xFF, minutes & 0xFF); + _playtime->setLabel(buffer); + _playtime->draw(); + } else { + snprintf(buffer, 32, "No date saved"); + _date->setLabel(buffer); + _date->draw(); + + snprintf(buffer, 32, "No time saved"); + _time->setLabel(buffer); + _time->draw(); + + snprintf(buffer, 32, "No playtime saved"); + _playtime->setLabel(buffer); + _playtime->draw(); + } +*/ +} + +int Parallaction::buildSaveFileList(Common::StringList& l) { + + char name[16]; + char buf[30]; + + int count = 0; + + for (int i = 0; i < 10; i++) { + sprintf(name, "game.%i", i); + + buf[0] = '\0'; + Common::InSaveFile *f = _saveFileMan->openForLoading(name); + + if (f) { + f->readLine(buf, 29); + delete f; + + count++; + } + + l.push_back(buf); + } + + return count; +} + + +int Parallaction::selectSaveFile(uint16 arg_0, const char* caption, const char* button) { + + SaveLoadChooser* slc = new SaveLoadChooser(caption, button, _vm); + + Common::StringList l; + + /*int count = */ buildSaveFileList(l); + slc->setList(l); + + int idx = slc->runModal(); + if (idx >= 0) { + _saveFileName = slc->getResultString(); + } + + delete slc; + + return idx; +} + + + +void Parallaction::loadGame() { + + int _di = selectSaveFile( 0, "Load file", "Load" ); + if (_di == -1) { + return; + } + + doLoadGame(_di); + + GUI::TimedMessageDialog dialog("Loading game...", 1500); + dialog.runModal(); + + changeCursor(kCursorArrow); + + return; +} + + +void Parallaction::saveGame() { + +// strcpy(v30, asc_1C91A); + + if (!scumm_stricmp(_location, "caveau")) + return; + + int slot = selectSaveFile( 1, "Save file", "Save" ); + if (slot == -1) { + return; + } + + doSaveGame(slot, _saveFileName.c_str()); + + GUI::TimedMessageDialog dialog("Saving game...", 1500); + dialog.runModal(); + + return; + + +} + + + + + +} // namespace Parallaction |
