aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
authorEinar Johan Trøan Sømåen2012-06-15 18:45:28 +0200
committerEinar Johan Trøan Sømåen2012-06-15 18:45:28 +0200
commitbd31b5f20144169c830211db29eac8d4789f1428 (patch)
tree4340e07ea238ecb1b8b39399a0555e6d38c4778b /engines
parente546237a2311d2e4d323d0754dd313730b58200e (diff)
downloadscummvm-rg350-bd31b5f20144169c830211db29eac8d4789f1428.tar.gz
scummvm-rg350-bd31b5f20144169c830211db29eac8d4789f1428.tar.bz2
scummvm-rg350-bd31b5f20144169c830211db29eac8d4789f1428.zip
WINTERMUTE: Move some of the initialization code over from PlatformSDL
Diffstat (limited to 'engines')
-rw-r--r--engines/wintermute/PlatformSDL.cpp169
-rw-r--r--engines/wintermute/PlatformSDL.h1
-rw-r--r--engines/wintermute/wintermute.cpp182
-rw-r--r--engines/wintermute/wintermute.h6
4 files changed, 181 insertions, 177 deletions
diff --git a/engines/wintermute/PlatformSDL.cpp b/engines/wintermute/PlatformSDL.cpp
index 10d18c7fc1..e27cbb291f 100644
--- a/engines/wintermute/PlatformSDL.cpp
+++ b/engines/wintermute/PlatformSDL.cpp
@@ -42,178 +42,9 @@ namespace WinterMute {
CBGame *CBPlatform::Game = NULL;
-
#define CLASS_NAME "GF_FRAME"
-//////////////////////////////////////////////////////////////////////////
int CBPlatform::Initialize(CBGame *inGame, int argc, char *argv[]) {
- //setlocale(LC_CTYPE, "");
-
Game = inGame;
- if (!Game) return 1;
-
-
- bool windowedMode = true;
-
-
- // parse command line
- char *SaveGame = NULL;
- char param[MAX_PATH];
- for (int i = 0; i < argc; i++) {
- strcpy(param, argv[i]);
-
- if (scumm_stricmp(param, "-project") == 0) {
- if (argc > i) strcpy(param, argv[i + 1]);
- else param[0] = '\0';
-
- if (strcmp(param, "") != 0) {
- char *IniDir = CBUtils::GetPath(param);
- char *IniName = CBUtils::GetFilename(param);
-
- // switch to ini's dir
- warning("TODO: Place ini-files somewhere");
-// chdir(IniDir);
-
- // set ini name
- sprintf(param, "./%s", IniName);
- Game->_registry->SetIniName(param);
-
- delete [] IniDir;
- delete [] IniName;
- }
- } else if (scumm_stricmp(param, "-windowed") == 0) windowedMode = true;
- }
-
-
- if (Game->_registry->ReadBool("Debug", "DebugMode")) Game->DEBUG_DebugEnable("./wme.log");
-
- Game->_dEBUG_ShowFPS = Game->_registry->ReadBool("Debug", "ShowFPS");
-
- if (Game->_registry->ReadBool("Debug", "DisableSmartCache")) {
- Game->LOG(0, "Smart cache is DISABLED");
- Game->_smartCache = false;
- }
-
-/* bool AllowDirectDraw = Game->_registry->ReadBool("Debug", "AllowDirectDraw", false);*/
-
- // load general game settings
- Game->Initialize1();
-
-
- if (FAILED(Game->LoadSettings("startup.settings"))) {
- Game->LOG(0, "Error loading game settings.");
- delete Game;
- Game = NULL;
-
- warning("Some of the essential files are missing. Please reinstall.");
- return 2;
- }
-
- Game->Initialize2();
-
- Game->GetDebugMgr()->OnGameInit();
- Game->_scEngine->LoadBreakpoints();
-
-
-
- HRESULT ret;
-
- // initialize the renderer
- ret = Game->_renderer->InitRenderer(Game->_settingsResWidth, Game->_settingsResHeight, windowedMode);
- if (FAILED(ret)) {
- Game->LOG(ret, "Error initializing renderer. Exiting.");
-
- delete Game;
- Game = NULL;
- return 3;
- }
-
- Game->Initialize3();
-
-#ifdef __IPHONEOS__
- SDL_AddEventWatch(CBPlatform::SDLEventWatcher, NULL);
-#endif
-
- // initialize sound manager (non-fatal if we fail)
- ret = Game->_soundMgr->initialize();
- if (FAILED(ret)) {
- Game->LOG(ret, "Sound is NOT available.");
- }
-
-
- // load game
- uint32 DataInitStart = GetTime();
-
- if (FAILED(Game->LoadFile(Game->_settingsGameFile ? Game->_settingsGameFile : "default.game"))) {
- Game->LOG(ret, "Error loading game file. Exiting.");
- delete Game;
- Game = NULL;
- return false;
- }
- Game->SetWindowTitle();
- Game->_renderer->_ready = true;
- Game->_miniUpdateEnabled = true;
-
- Game->LOG(0, "Engine initialized in %d ms", GetTime() - DataInitStart);
- Game->LOG(0, "");
-
-
- if (SaveGame) {
- Game->LoadGame(SaveGame);
- delete [] SaveGame;
- }
-
- // all set, ready to go
- return 0;
-}
-
-
-//////////////////////////////////////////////////////////////////////////
-int CBPlatform::MessageLoop() {
- bool done = false;
-
- while (!done) {
- Common::Event event;
- while (g_system->getEventManager()->pollEvent(event)) {
- HandleEvent(&event);
- }
-
- if (Game && Game->_renderer->_active && Game->_renderer->_ready) {
-
- Game->DisplayContent();
- Game->DisplayQuickMsg();
-
- Game->DisplayDebugInfo();
-
- // ***** flip
- if (!Game->_suspendedRendering) Game->_renderer->Flip();
- if (Game->_loading) Game->LoadGame(Game->_scheduledLoadSlot);
- }
- if (Game->_quitting) break;
-
- }
-
- if (Game) {
- // remember previous window position
- /*
- if(Game->_renderer && Game->_renderer->_windowed)
- {
- if(!::IsIconic(Game->_renderer->_window))
- {
- int PosX = Game->_renderer->_windowRect.left;
- int PosY = Game->_renderer->_windowRect.top;
- PosX -= Game->_renderer->_monitorRect.left;
- PosY -= Game->_renderer->_monitorRect.top;
-
- Game->_registry->WriteInt("Video", "WindowPosX", PosX);
- Game->_registry->WriteInt("Video", "WindowPosY", PosY);
- }
- }
- */
-
- delete Game;
- Game = NULL;
- }
- return 0;
}
//////////////////////////////////////////////////////////////////////////
diff --git a/engines/wintermute/PlatformSDL.h b/engines/wintermute/PlatformSDL.h
index 347d306378..6adba29ae8 100644
--- a/engines/wintermute/PlatformSDL.h
+++ b/engines/wintermute/PlatformSDL.h
@@ -42,7 +42,6 @@ class CBGame;
class CBPlatform {
public:
static int Initialize(CBGame *inGame, int argc, char *argv[]);
- static int MessageLoop();
static void HandleEvent(Common::Event *event);
static AnsiString GetSystemFontPath();
diff --git a/engines/wintermute/wintermute.cpp b/engines/wintermute/wintermute.cpp
index d91619710b..ed8054885d 100644
--- a/engines/wintermute/wintermute.cpp
+++ b/engines/wintermute/wintermute.cpp
@@ -34,6 +34,10 @@
#include "engines/wintermute/Ad/AdGame.h"
#include "engines/wintermute/wintermute.h"
#include "engines/wintermute/PlatformSDL.h"
+#include "engines/wintermute/Base/BRegistry.h"
+
+#include "engines/wintermute/Base/BSoundMgr.h"
+#include "engines/wintermute/Base/scriptables/ScEngine.h"
namespace WinterMute {
@@ -57,6 +61,7 @@ WinterMuteEngine::WinterMuteEngine(OSystem *syst)
_rnd = new Common::RandomSource("WinterMute");
debug("WinterMuteEngine::WinterMuteEngine");
+ _game = NULL;
}
WinterMuteEngine::~WinterMuteEngine() {
@@ -106,16 +111,183 @@ Common::Error WinterMuteEngine::run() {
// This test will show up if --debugflags=example or --debugflags=example2 or both of them and -d3 are specified on the commandline
debugC(3, kWinterMuteDebugExample | kWinterMuteDebugExample2, "Example debug call two");
- CAdGame *game = new CAdGame;
-
int ret = 1;
-
- ret = CBPlatform::Initialize(game, NULL, 0);
+
+ ret = init();
if (ret == 0) {
- ret = CBPlatform::MessageLoop();
+ ret = messageLoop();
}
return Common::kNoError;
}
+int WinterMuteEngine::init() {
+ char argv[1] = { ' ' };
+ int argc = 0;
+ _game = new CAdGame;
+ if (!_game) return 1;
+
+ bool windowedMode = true;
+
+ // parse command line
+ char *SaveGame = NULL;
+ char param[MAX_PATH];
+/* for (int i = 0; i < argc; i++) {
+ strcpy(param, argv[i]);
+
+ if (scumm_stricmp(param, "-project") == 0) {
+ if (argc > i) strcpy(param, argv[i + 1]);
+ else param[0] = '\0';
+
+ if (strcmp(param, "") != 0) {
+ char *IniDir = CBUtils::GetPath(param);
+ char *IniName = CBUtils::GetFilename(param);
+
+ // switch to ini's dir
+ warning("TODO: Place ini-files somewhere");
+ // chdir(IniDir);
+
+ // set ini name
+ sprintf(param, "./%s", IniName);
+ _game->_registry->SetIniName(param);
+
+ delete [] IniDir;
+ delete [] IniName;
+ }
+ } else if (scumm_stricmp(param, "-windowed") == 0) windowedMode = true;
+ }*/
+
+
+ if (_game->_registry->ReadBool("Debug", "DebugMode")) _game->DEBUG_DebugEnable("./wme.log");
+
+ _game->_dEBUG_ShowFPS = _game->_registry->ReadBool("Debug", "ShowFPS");
+
+ if (_game->_registry->ReadBool("Debug", "DisableSmartCache")) {
+ _game->LOG(0, "Smart cache is DISABLED");
+ _game->_smartCache = false;
+ }
+
+ /* bool AllowDirectDraw = _game->_registry->ReadBool("Debug", "AllowDirectDraw", false);*/
+
+ // load general game settings
+ _game->Initialize1();
+
+
+ if (FAILED(_game->LoadSettings("startup.settings"))) {
+ _game->LOG(0, "Error loading game settings.");
+ delete _game;
+ _game = NULL;
+
+ warning("Some of the essential files are missing. Please reinstall.");
+ return 2;
+ }
+
+ _game->Initialize2();
+
+ _game->GetDebugMgr()->OnGameInit();
+ _game->_scEngine->LoadBreakpoints();
+
+
+
+ HRESULT ret;
+
+ // initialize the renderer
+ ret = _game->_renderer->InitRenderer(_game->_settingsResWidth, _game->_settingsResHeight, windowedMode);
+ if (FAILED(ret)) {
+ _game->LOG(ret, "Error initializing renderer. Exiting.");
+
+ delete _game;
+ _game = NULL;
+ return 3;
+ }
+
+ _game->Initialize3();
+
+#ifdef __IPHONEOS__
+ SDL_AddEventWatch(CBPlatform::SDLEventWatcher, NULL);
+#endif
+
+ // initialize sound manager (non-fatal if we fail)
+ ret = _game->_soundMgr->initialize();
+ if (FAILED(ret)) {
+ _game->LOG(ret, "Sound is NOT available.");
+ }
+
+
+ // load game
+ uint32 DataInitStart = CBPlatform::GetTime();
+
+ if (FAILED(_game->LoadFile(_game->_settingsGameFile ? _game->_settingsGameFile : "default.game"))) {
+ _game->LOG(ret, "Error loading game file. Exiting.");
+ delete _game;
+ _game = NULL;
+ return false;
+ }
+ _game->SetWindowTitle();
+ _game->_renderer->_ready = true;
+ _game->_miniUpdateEnabled = true;
+
+ _game->LOG(0, "Engine initialized in %d ms", CBPlatform::GetTime() - DataInitStart);
+ _game->LOG(0, "");
+
+
+ if (SaveGame) {
+ _game->LoadGame(SaveGame);
+ delete [] SaveGame;
+ }
+
+ CBPlatform::Initialize(_game, 0, NULL);
+
+ // all set, ready to go
+ return 0;
+}
+
+int WinterMuteEngine::messageLoop() {
+ bool done = false;
+
+ while (!done) {
+ Common::Event event;
+ while (_system->getEventManager()->pollEvent(event)) {
+ CBPlatform::HandleEvent(&event);
+ }
+
+ if (_game && _game->_renderer->_active && _game->_renderer->_ready) {
+
+ _game->DisplayContent();
+ _game->DisplayQuickMsg();
+
+ _game->DisplayDebugInfo();
+
+ // ***** flip
+ if (!_game->_suspendedRendering) _game->_renderer->Flip();
+ if (_game->_loading) _game->LoadGame(_game->_scheduledLoadSlot);
+ }
+ if (_game->_quitting) break;
+
+ }
+
+ if (_game) {
+ // remember previous window position
+ /*
+ if(_game->_renderer && _game->_renderer->_windowed)
+ {
+ if(!::IsIconic(_game->_renderer->_window))
+ {
+ int PosX = _game->_renderer->_windowRect.left;
+ int PosY = _game->_renderer->_windowRect.top;
+ PosX -= _game->_renderer->_monitorRect.left;
+ PosY -= _game->_renderer->_monitorRect.top;
+
+ _game->_registry->WriteInt("Video", "WindowPosX", PosX);
+ _game->_registry->WriteInt("Video", "WindowPosY", PosY);
+ }
+ }
+ */
+
+ delete _game;
+ _game = NULL;
+ }
+ return 0;
+}
+
} // End of namespace WinterMute
diff --git a/engines/wintermute/wintermute.h b/engines/wintermute/wintermute.h
index e1f5047239..1a03de5553 100644
--- a/engines/wintermute/wintermute.h
+++ b/engines/wintermute/wintermute.h
@@ -30,7 +30,7 @@
namespace WinterMute {
class Console;
-
+class CBGame;
// our engine debug channels
enum {
kWinterMuteDebugExample = 1 << 0,
@@ -47,8 +47,10 @@ public:
virtual Common::Error run();
private:
+ int init();
+ int messageLoop();
Console *_console;
-
+ CBGame *_game;
// We need random numbers
Common::RandomSource *_rnd;
};