aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
Diffstat (limited to 'engines')
-rw-r--r--engines/draci/game.cpp50
-rw-r--r--engines/draci/game.h2
2 files changed, 25 insertions, 27 deletions
diff --git a/engines/draci/game.cpp b/engines/draci/game.cpp
index e7f1b2d454..8a4500c04c 100644
--- a/engines/draci/game.cpp
+++ b/engines/draci/game.cpp
@@ -72,24 +72,23 @@ Game::Game(DraciEngine *vm) : _vm(vm) {
file = initArchive.getFile(3);
Common::MemoryReadStream gameData(file->_data, file->_length);
- _info = new GameInfo();
- _info->_currentRoom = gameData.readByte() - 1;
- _info->_mapRoom = gameData.readByte() - 1;
- _info->_numObjects = gameData.readUint16LE();
- _info->_numIcons = gameData.readUint16LE();
- _info->_numVariables = gameData.readByte();
- _info->_numPersons = gameData.readByte();
- _info->_numDialogs = gameData.readByte();
- _info->_maxIconWidth = gameData.readUint16LE();
- _info->_maxIconHeight = gameData.readUint16LE();
- _info->_musicLength = gameData.readUint16LE();
- _info->_crc[0] = gameData.readUint16LE();
- _info->_crc[1] = gameData.readUint16LE();
- _info->_crc[2] = gameData.readUint16LE();
- _info->_crc[3] = gameData.readUint16LE();
-
- _info->_numDialogBlocks = curOffset;
+ _info._currentRoom = gameData.readByte() - 1;
+ _info._mapRoom = gameData.readByte() - 1;
+ _info._numObjects = gameData.readUint16LE();
+ _info._numIcons = gameData.readUint16LE();
+ _info._numVariables = gameData.readByte();
+ _info._numPersons = gameData.readByte();
+ _info._numDialogs = gameData.readByte();
+ _info._maxIconWidth = gameData.readUint16LE();
+ _info._maxIconHeight = gameData.readUint16LE();
+ _info._musicLength = gameData.readUint16LE();
+ _info._crc[0] = gameData.readUint16LE();
+ _info._crc[1] = gameData.readUint16LE();
+ _info._crc[2] = gameData.readUint16LE();
+ _info._crc[3] = gameData.readUint16LE();
+
+ _info._numDialogBlocks = curOffset;
// Read in variables
@@ -128,11 +127,11 @@ Game::Game(DraciEngine *vm) : _vm(vm) {
_objects[i]._location = (~(1 << 7) & tmp) - 1;
}
- assert(numDialogs == _info->_numDialogs);
- assert(numPersons == _info->_numPersons);
- assert(numVariables == _info->_numVariables);
- assert(numObjects == _info->_numObjects);
- assert(numIcons == _info->_numIcons);
+ assert(numDialogs == _info._numDialogs);
+ assert(numPersons == _info._numPersons);
+ assert(numVariables == _info._numVariables);
+ assert(numObjects == _info._numObjects);
+ assert(numIcons == _info._numIcons);
}
void Game::init() {
@@ -172,7 +171,7 @@ void Game::loadRoom(int roomNum) {
_currentRoom._escRoom = roomReader.readByte() - 1;
_currentRoom._numGates = roomReader.readByte();
- for (uint i = 0; i < _info->_numObjects; ++i) {
+ for (uint i = 0; i < _info._numObjects; ++i) {
debugC(1, kDraciLogicDebugLevel,
"Checking if object %d (%d) is at the current location (%d)", i,
_objects[i]._location, roomNum);
@@ -186,7 +185,7 @@ void Game::loadRoom(int roomNum) {
// Run the init scripts for room objects
// We can't do this in the above loop because some objects' scripts reference
// other objects that may not yet be loaded
- for (uint i = 0; i < _info->_numObjects; ++i) {
+ for (uint i = 0; i < _info._numObjects; ++i) {
if (_objects[i]._location == roomNum) {
_vm->_script->run(getObject(i)->_program, getObject(i)->_init);
}
@@ -328,7 +327,7 @@ void Game::changeRoom(uint roomNum) {
int oldRoomNum = _currentRoom._roomNum;
- for (uint i = 0; i < _info->_numObjects; ++i) {
+ for (uint i = 0; i < _info._numObjects; ++i) {
GameObject *obj = &_objects[i];
if (i != 0 && obj->_location == oldRoomNum) {
@@ -366,7 +365,6 @@ Game::~Game() {
delete[] _dialogOffsets;
delete[] _iconStatus;
delete[] _objects;
- delete _info;
}
GameObject::~GameObject() {
diff --git a/engines/draci/game.h b/engines/draci/game.h
index c9f913dbc8..c68990dace 100644
--- a/engines/draci/game.h
+++ b/engines/draci/game.h
@@ -147,7 +147,7 @@ public:
private:
DraciEngine *_vm;
int *_variables;
- GameInfo *_info;
+ GameInfo _info;
Person *_persons;
uint16 *_dialogOffsets;
byte *_iconStatus;