scummvm/engines/mads/game.h

242 lines
5.3 KiB
C++

/* ScummVM - Graphic Adventure Engine
*
* 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.
*
* 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.
*
*/
#ifndef MADS_GAME_H
#define MADS_GAME_H
#include "common/scummsys.h"
#include "common/savefile.h"
#include "common/str-array.h"
#include "common/serializer.h"
#include "mads/audio.h"
#include "mads/scene.h"
#include "mads/game_data.h"
#include "mads/globals.h"
#include "mads/inventory.h"
#include "mads/player.h"
#include "mads/screen.h"
namespace MADS {
class MADSEngine;
enum {
PLAYER_INVENTORY = 2
};
enum KernelMode {
KERNEL_GAME_LOAD = 0, KERNEL_SECTION_PRELOAD = 1, KERNEL_SECTION_INIT = 2,
KERNEL_ROOM_PRELOAD = 3, KERNEL_ROOM_INIT = 4, KERNEL_ACTIVE_CODE = 5
};
enum ProtectionResult {
PROTECTION_SUCCEED = 0, PROTECTION_FAIL = 1, PROTECTION_ESCAPE = 2
};
#define MADS_SAVEGAME_VERSION 1
struct MADSSavegameHeader {
uint8 _version;
Common::String _saveName;
Graphics::Surface *_thumbnail;
int _year, _month, _day;
int _hour, _minute;
int _totalFrames;
};
class Game {
private:
/**
* Main game loop
*/
void gameLoop();
/**
* Inner game loop for executing gameplay within a game section
*/
void sectionLoop();
/**
* Load quotes data
*/
void loadQuotes();
protected:
MADSEngine *_vm;
MSurface *_surface;
int _statusFlag;
Common::StringArray _quotes;
bool _quoteEmergency;
bool _vocabEmergency;
bool _anyEmergency;
int _lastSave;
Common::String _saveName;
Common::InSaveFile *_saveFile;
/**
* Constructor
*/
Game(MADSEngine *vm);
/**
* Initializes the current section number of the game
*/
void initSection(int sectionNumber);
//@{
/** @name Virtual Method list */
/**
* Perform any copy protection check
*/
virtual ProtectionResult checkCopyProtection() = 0;
/**
* Initializes global variables for a new game
*/
virtual void initializeGlobals() = 0;
/**
* Set up the section handler specific to each section
*/
virtual void setSectionHandler() = 0;
/**
* Checks for whether to show a dialog
*/
virtual void checkShowDialog() = 0;
//@}
public:
static Game *init(MADSEngine *vm);
public:
Player _player;
ScreenObjects _screenObjects;
int _sectionNumber;
int _priorSectionNumber;
int _currentSectionNumber;
InventoryObjects _objects;
SectionHandler *_sectionHandler;
VisitedScenes _visitedScenes;
Scene _scene;
KernelMode _kernelMode;
int _trigger;
ScreenTransition _fx;
TriggerMode _triggerMode;
TriggerMode _triggerSetupMode;
uint32 _priorFrameTimer;
Common::String _aaName;
int _winStatus;
int _widepipeCtr;
int _loadGameSlot;
public:
virtual ~Game();
/**
* Main outer loop for the game
*/
void run();
/**
* Return the number of quotes
*/
uint32 getQuotesSize() { return _quotes.size(); }
/**
* Get a specific quote string
*/
const Common::String &getQuote(uint32 index) { return _quotes[index - 1]; }
/**
* Split a quote into two lines for display on-screen
*/
void splitQuote(const Common::String &source, Common::String &line1, Common::String &line2);
Common::StringArray getMessage(uint32 id);
/**
* Returns the globals for the game
*/
virtual Globals &globals() = 0;
/**
* Standard object handling across the game
*/
virtual void doObjectAction() = 0;
/**
* Fallback handler for any action that isn't explicitly handled
*/
virtual void unhandledAction() = 0;
/**
* Global game step
*/
virtual void step() = 0;
/**
* Synchronize the game data
* @param s Serializer
* @param phase1 If true, it's synchronizing the basic scene information
*/
virtual void synchronize(Common::Serializer &s, bool phase1);
// DEPRECATED: ScummVM re-implementation keeps all the quotes loaded, so the methods below are stubs
void clearQuotes() {}
void loadQuoteRange(int startNum, int endNum) {}
void loadQuoteSet(...) {}
void loadQuote(int quoteNum) {}
/**
* Handle a keyboard event
*/
void handleKeypress(const Common::Event &event);
/**
* Starts a savegame loading.
* @remarks Due to the way the engine is implemented, loading is done in two
* parts, the second part after the specific scene has been loaded
*/
void loadGame(int slotNumber);
/**
* Save the current game
*/
void saveGame(int slotNumber, const Common::String &saveName);
/**
* Write out a savegame header
*/
void writeSavegameHeader(Common::OutSaveFile *out, MADSSavegameHeader &header);
/**
* Read in a savegame header
*/
static bool readSavegameHeader(Common::InSaveFile *in, MADSSavegameHeader &header);
};
} // End of namespace MADS
#endif /* MADS_GAME_H */