aboutsummaryrefslogtreecommitdiff
path: root/engines/mads/nebular
diff options
context:
space:
mode:
Diffstat (limited to 'engines/mads/nebular')
-rw-r--r--engines/mads/nebular/game_nebular.cpp71
-rw-r--r--engines/mads/nebular/game_nebular.h6
-rw-r--r--engines/mads/nebular/globals_nebular.cpp51
-rw-r--r--engines/mads/nebular/globals_nebular.h63
-rw-r--r--engines/mads/nebular/nebular_scenes.cpp3
-rw-r--r--engines/mads/nebular/nebular_scenes.h14
-rw-r--r--engines/mads/nebular/nebular_scenes1.cpp53
-rw-r--r--engines/mads/nebular/nebular_scenes1.h56
-rw-r--r--engines/mads/nebular/nebular_scenes8.cpp29
-rw-r--r--engines/mads/nebular/nebular_scenes8.h10
10 files changed, 319 insertions, 37 deletions
diff --git a/engines/mads/nebular/game_nebular.cpp b/engines/mads/nebular/game_nebular.cpp
index c55abf5601..c18561bac0 100644
--- a/engines/mads/nebular/game_nebular.cpp
+++ b/engines/mads/nebular/game_nebular.cpp
@@ -28,6 +28,7 @@
#include "mads/msurface.h"
#include "mads/nebular/game_nebular.h"
#include "mads/nebular/dialogs_nebular.h"
+#include "mads/nebular/globals_nebular.h"
namespace MADS {
@@ -38,6 +39,9 @@ GameNebular::GameNebular(MADSEngine *vm): Game(vm) {
}
int GameNebular::checkCopyProtection() {
+ // DEBUG: Flag copy protection failure
+ _globals[5] = 0xFFFF;
+
if (!ConfMan.getBool("copy_protection"))
return true;
@@ -52,32 +56,27 @@ int GameNebular::checkCopyProtection() {
}
void GameNebular::initialiseGlobals() {
- // Allocate globals space
- _globalFlags.resize(210);
- for (int i = 0; i < 210; ++i)
- _globalFlags[i] = 0;
-
// Set specific values needed by the game
- _globalFlags[4] = 8;
- _globalFlags[33] = 1;
- _globalFlags[10] = 0xFFFF;
- _globalFlags[13] = 0xFFFF;
- _globalFlags[15] = 0xFFFF;
- _globalFlags[19] = 0xFFFF;
- _globalFlags[20] = 0xFFFF;
- _globalFlags[21] = 0xFFFF;
- _globalFlags[95] = 0xFFFF;
+ _globals[4] = 8;
+ _globals[33] = 1;
+ _globals[10] = 0xFFFF;
+ _globals[13] = 0xFFFF;
+ _globals[15] = 0xFFFF;
+ _globals[19] = 0xFFFF;
+ _globals[20] = 0xFFFF;
+ _globals[21] = 0xFFFF;
+ _globals[95] = 0xFFFF;
_objects.setData(3, 17, nullptr);
// Put the values 0 through 3 in a random order in global slots 83 to 86
for (int i = 0; i < 4;) {
int randomVal = _vm->getRandomNumber(3);
- _globalFlags[83 + i] = randomVal;
+ _globals[83 + i] = randomVal;
bool flag = false;
for (int idx2 = 0; idx2 < i; ++idx2) {
- if (_globalFlags[83 + idx2] == randomVal)
+ if (_globals[83 + idx2] == randomVal)
flag = true;
}
@@ -88,11 +87,11 @@ void GameNebular::initialiseGlobals() {
// Put the values 0 through 3 in a random order in global slots 87 to 90
for (int i = 0; i < 4;) {
int randomVal = _vm->getRandomNumber(3);
- _globalFlags[87 + i] = randomVal;
+ _globals[87 + i] = randomVal;
bool flag = false;
for (int idx2 = 0; idx2 < i; ++idx2) {
- if (_globalFlags[87 + idx2] == randomVal)
+ if (_globals[87 + idx2] == randomVal)
flag = true;
}
@@ -100,20 +99,20 @@ void GameNebular::initialiseGlobals() {
++i;
}
- _globalFlags[120] = 501;
- _globalFlags[121] = 0xFFFF;
- _globalFlags[55] = 0xFFFF;
- _globalFlags[119] = 1;
- _globalFlags[134] = 4;
+ _globals[120] = 501;
+ _globals[121] = 0xFFFF;
+ _globals[55] = 0xFFFF;
+ _globals[119] = 1;
+ _globals[134] = 4;
// Fill out the globals 200 to 209 with unique random values less than 10000
for (int i = 0; i < 10; ++i) {
int randomVal = _vm->getRandomNumber(9999);
- _globalFlags[200 + i] = randomVal;
+ _globals[200 + i] = randomVal;
bool flag = false;
for (int idx2 = 0; idx2 < i; ++idx2) {
- if (_globalFlags[200 + idx2] == randomVal)
+ if (_globals[200 + idx2] == randomVal)
flag = true;
}
@@ -124,20 +123,20 @@ void GameNebular::initialiseGlobals() {
// Difficulty level control
switch (_difficultyLevel) {
case DIFFICULTY_HARD:
- _globalFlags[35] = 0;
+ _globals[35] = 0;
_objects.setRoom(9, 1);
_objects.setRoom(50, 1);
- _globalFlags[137] = 5;
- _globalFlags[136] = 0;
+ _globals[137] = 5;
+ _globals[136] = 0;
break;
case DIFFICULTY_MEDIUM:
- _globalFlags[35] = 0;
+ _globals[35] = 0;
_objects.setRoom(8, 1);
- _globalFlags[137] = 0xFFFF;
- _globalFlags[136] = 6;
+ _globals[137] = 0xFFFF;
+ _globals[136] = 6;
break;
case DIFFICULTY_EASY:
- _globalFlags[35] = 2;
+ _globals[35] = 2;
_objects.setRoom(8, 1);
_objects.setRoom(27, 1);
break;
@@ -185,6 +184,14 @@ void GameNebular::setSectionHandler() {
}
}
+void GameNebular::checkShowDialog() {
+ if (_vm->_dialogs->_pendingDialog && _player._stepEnabled && !_globals[5]) {
+ _scene._spriteSlots.releasePlayerSprites();
+ _vm->_dialogs->showDialog();
+ _vm->_dialogs->_pendingDialog = DIALOG_NONE;
+ }
+}
+
} // End of namespace Nebular
} // End of namespace MADS
diff --git a/engines/mads/nebular/game_nebular.h b/engines/mads/nebular/game_nebular.h
index 6395ba0e4e..0250f66d8e 100644
--- a/engines/mads/nebular/game_nebular.h
+++ b/engines/mads/nebular/game_nebular.h
@@ -25,6 +25,7 @@
#include "common/scummsys.h"
#include "mads/game.h"
+#include "mads/nebular/globals_nebular.h"
namespace MADS {
@@ -40,6 +41,11 @@ protected:
virtual void initialiseGlobals();
virtual void setSectionHandler();
+
+ virtual void checkShowDialog();
+
+public:
+ Globals _globals;
};
diff --git a/engines/mads/nebular/globals_nebular.cpp b/engines/mads/nebular/globals_nebular.cpp
new file mode 100644
index 0000000000..20789cd154
--- /dev/null
+++ b/engines/mads/nebular/globals_nebular.cpp
@@ -0,0 +1,51 @@
+/* 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.
+ *
+ */
+
+#include "common/scummsys.h"
+#include "common/config-manager.h"
+#include "mads/nebular/globals_nebular.h"
+
+namespace MADS {
+
+namespace Nebular {
+
+Globals::Globals() {
+ // Initialise global flags
+ _flags.resize(210);
+ for (int i = 0; i < 210; ++i)
+ _flags[i] = 0;
+
+ // Initialise game flags
+ _chairHotspotIndex = 0;
+ _v1 = 0;
+ _v2 = 0;
+ _v3 = 0;
+ _v4 = 0;
+ _v5 = 0;
+ _v6 = 0;
+ _v7 = 0;
+ _v8 = 0;
+}
+
+} // End of namespace Nebular
+
+} // End of namespace MADS
diff --git a/engines/mads/nebular/globals_nebular.h b/engines/mads/nebular/globals_nebular.h
new file mode 100644
index 0000000000..0d8da78e42
--- /dev/null
+++ b/engines/mads/nebular/globals_nebular.h
@@ -0,0 +1,63 @@
+/* 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_GLOBALS_NEBULAR_H
+#define MADS_GLOBALS_NEBULAR_H
+
+#include "common/scummsys.h"
+#include "common/array.h"
+#include "mads/game.h"
+
+namespace MADS {
+
+namespace Nebular {
+
+class Globals {
+private:
+ Common::Array<uint16> _flags;
+public:
+ int _chairHotspotIndex;
+ int _v1;
+ int _v2;
+ int _v3;
+ int _v4;
+ int _v5;
+ int _v6;
+ int _v7;
+ int _v8;
+public:
+ /**
+ * Constructor
+ */
+ Globals();
+
+ /**
+ * Square brackets operator for accessing flags
+ */
+ uint16 &operator[](int idx) { return _flags[idx]; }
+};
+
+} // End of namespace Nebular
+
+} // End of namespace MADS
+
+#endif /* MADS_GLOBALS_NEBULAR_H */
diff --git a/engines/mads/nebular/nebular_scenes.cpp b/engines/mads/nebular/nebular_scenes.cpp
index e1dec2c34c..f82e102bfa 100644
--- a/engines/mads/nebular/nebular_scenes.cpp
+++ b/engines/mads/nebular/nebular_scenes.cpp
@@ -46,6 +46,9 @@ SceneLogic *SceneFactory::createScene(MADSEngine *vm) {
return new Scene804(vm);
}
+NebularScene::NebularScene(MADSEngine *vm) : SceneLogic(vm) {
+}
+
} // End of namespace Nebular
} // End of namespace MADS
diff --git a/engines/mads/nebular/nebular_scenes.h b/engines/mads/nebular/nebular_scenes.h
index 1997202fbd..9d617bb543 100644
--- a/engines/mads/nebular/nebular_scenes.h
+++ b/engines/mads/nebular/nebular_scenes.h
@@ -26,6 +26,7 @@
#include "common/scummsys.h"
#include "mads/game.h"
#include "mads/scene.h"
+#include "mads/nebular/globals_nebular.h"
namespace MADS {
@@ -88,6 +89,19 @@ public:
static SceneLogic *createScene(MADSEngine *vm);
};
+/**
+ * Specialized base class for Rex Nebular game scenes
+ */
+class NebularScene : public SceneLogic {
+protected:
+ Globals &_globals;
+public:
+ /**
+ * Constructor
+ */
+ NebularScene(MADSEngine *vm);
+};
+
} // End of namespace Nebular
} // End of namespace MADS
diff --git a/engines/mads/nebular/nebular_scenes1.cpp b/engines/mads/nebular/nebular_scenes1.cpp
new file mode 100644
index 0000000000..1de4eca509
--- /dev/null
+++ b/engines/mads/nebular/nebular_scenes1.cpp
@@ -0,0 +1,53 @@
+/* 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.
+ *
+ */
+
+#include "common/scummsys.h"
+#include "mads/mads.h"
+#include "mads/scene.h"
+#include "mads/nebular/nebular_scenes.h"
+#include "mads/nebular/nebular_scenes1.h"
+
+namespace MADS {
+
+namespace Nebular {
+
+void Scene101::setup() {
+}
+
+void Scene101::enter() {
+}
+
+void Scene101::step() {
+}
+
+void Scene101::preActions() {
+}
+
+void Scene101::actions() {
+}
+
+void Scene101::postActions() {
+}
+
+} // End of namespace Nebular
+
+} // End of namespace MADS
diff --git a/engines/mads/nebular/nebular_scenes1.h b/engines/mads/nebular/nebular_scenes1.h
new file mode 100644
index 0000000000..da6a2f0903
--- /dev/null
+++ b/engines/mads/nebular/nebular_scenes1.h
@@ -0,0 +1,56 @@
+/* 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_NEBULAR_SCENES1_H
+#define MADS_NEBULAR_SCENES1_H
+
+#include "common/scummsys.h"
+#include "mads/game.h"
+#include "mads/scene.h"
+#include "mads/nebular/nebular_scenes.h"
+
+namespace MADS {
+
+namespace Nebular {
+
+class Scene101: public NebularScene {
+public:
+ Scene101(MADSEngine *vm) : NebularScene(vm) {}
+
+ virtual void setup();
+
+ virtual void enter();
+
+ virtual void step();
+
+ virtual void preActions();
+
+ virtual void actions();
+
+ virtual void postActions();
+};
+
+} // End of namespace Nebular
+
+} // End of namespace MADS
+
+#endif /* MADS_NEBULAR_SCENES1_H */
diff --git a/engines/mads/nebular/nebular_scenes8.cpp b/engines/mads/nebular/nebular_scenes8.cpp
index ee06dd00d3..d08e64506e 100644
--- a/engines/mads/nebular/nebular_scenes8.cpp
+++ b/engines/mads/nebular/nebular_scenes8.cpp
@@ -32,13 +32,12 @@ namespace Nebular {
void Scene8xx::setup1() {
_vm->_sound->command(5);
- if ((_vm->_game->_globalFlags[178] && !_vm->_game->_globalFlags[179]) ||
+ if ((_globals[178] && !_globals[179]) ||
_scene->_nextSceneId == 804 || _scene->_nextSceneId == 805 ||
_scene->_nextSceneId == 808 || _scene->_nextSceneId == 810) {
_vm->_game->_player._spritesPrefix = "";
} else {
- _vm->_game->_player._spritesPrefix = _vm->_game->_globalFlags[0]
- == SEX_FEMALE ? "ROX" : "RXM";
+ _vm->_game->_player._spritesPrefix = _globals[0] == SEX_FEMALE ? "ROX" : "RXM";
}
_vm->_palette->setEntry(16, 0x0A, 0x3F, 0x3F);
@@ -49,6 +48,30 @@ void Scene8xx::setup2() {
_vm->_game->_aaName = Resources::formatAAName(5);
}
+void Scene8xx::enter1() {
+ if (_vm->_musicFlag) {
+ switch (_scene->_nextSceneId) {
+ case 801:
+ case 802:
+ case 803:
+ case 804:
+ case 806:
+ case 807:
+ case 808:
+ _vm->_sound->command(20);
+ break;
+ case 805:
+ _vm->_sound->command(23);
+ break;
+ case 810:
+ _vm->_sound->command(10);
+ break;
+ default:
+ break;
+ }
+ }
+}
+
/*------------------------------------------------------------------------*/
void Scene804::setup() {
diff --git a/engines/mads/nebular/nebular_scenes8.h b/engines/mads/nebular/nebular_scenes8.h
index 3f5d2744fa..a3bc97a990 100644
--- a/engines/mads/nebular/nebular_scenes8.h
+++ b/engines/mads/nebular/nebular_scenes8.h
@@ -26,12 +26,13 @@
#include "common/scummsys.h"
#include "mads/game.h"
#include "mads/scene.h"
+#include "mads/nebular/nebular_scenes.h"
namespace MADS {
namespace Nebular {
-class Scene8xx : public SceneLogic {
+class Scene8xx : public NebularScene {
protected:
/**
* Initial setup code shared by several scenes
@@ -42,8 +43,13 @@ protected:
* Initial setup code shared by several scenes
*/
void setup2();
+
+ /**
+ * Common scene enter code used by multiple scenes
+ */
+ void enter1();
public:
- Scene8xx(MADSEngine *vm) : SceneLogic(vm) {}
+ Scene8xx(MADSEngine *vm) : NebularScene(vm) {}
};
class Scene804: public Scene8xx {