diff options
-rw-r--r-- | engines/dm/dm.cpp | 80 | ||||
-rw-r--r-- | engines/dm/dm.h | 4 | ||||
-rw-r--r-- | engines/dm/gfx.h | 5 | ||||
-rw-r--r-- | engines/dm/loadsave.cpp | 1 |
4 files changed, 53 insertions, 37 deletions
diff --git a/engines/dm/dm.cpp b/engines/dm/dm.cpp index 77d7ed012a..94f9f30420 100644 --- a/engines/dm/dm.cpp +++ b/engines/dm/dm.cpp @@ -72,8 +72,43 @@ DMEngine::~DMEngine() { DebugMan.clearAllDebugChannels(); } +void DMEngine::initializeGame() { + _displayMan->loadGraphics(); + // DUMMY CODE: next line + _displayMan->loadPalette(gPalCredits); + + _eventMan->initMouse(); + + while (_loadsaveMan->loadgame() != kLoadgameSuccess) { + // MISSING CODE: F0441_STARTEND_ProcessEntrance + } + + _displayMan->loadFloorSet(kFloorSetStone); + _displayMan->loadWallSet(kWallSetStone); + + startGame(); + warning("MISSING CODE: F0267_MOVE_GetMoveResult_CPSCE (if newGame)"); + _eventMan->showMouse(true); + warning("MISSING CODE: F0357_COMMAND_DiscardAllInput"); +} + + +void DMEngine::startGame() { + _eventMan->_primaryMouseInput = gPrimaryMouseInput_Interface; + _eventMan->_secondaryMouseInput = gSecondaryMouseInput_Movement; + // TODO:(next 2 lines) move to F0003_MAIN_ProcessNewPartyMap_CPSE + _dungeonMan->setCurrentMapAndPartyMap(0); + _displayMan->loadCurrentMapGraphics(); + + + _menuMan->drawMovementArrows(); + _gameTimeTicking = true; + + // MISSING CODE: Lot of stuff +} Common::Error DMEngine::run() { + // scummvm/engine specific initGraphics(320, 200, false); _console = new Console(this); _displayMan = new DisplayMan(this); @@ -82,55 +117,32 @@ Common::Error DMEngine::run() { _menuMan = new MenuMan(this); _championMan = new ChampionMan(this); _loadsaveMan = new LoadsaveMan(this); - _displayMan->setUpScreens(320, 200); - _displayMan->loadGraphics(); - - _dungeonMan->loadDungeonFile(); - _dungeonMan->setCurrentMapAndPartyMap(0); - - - _displayMan->loadCurrentMapGraphics(); - _displayMan->loadPalette(gPalCredits); - - _eventMan->initMouse(); - _eventMan->showMouse(true); - - _loadsaveMan->loadgame(); - - startGame(); + initializeGame(); // @ F0463_START_InitializeGame_CPSADEF + while (true) { + gameloop(); + // MISSING CODE: F0444_STARTEND_Endgame(G0303_B_PartyDead); + } + return Common::kNoError; +} +void DMEngine::gameloop() { while (true) { _stopWaitingForPlayerInput = false; //do { - _eventMan->processInput(); - _eventMan->processCommandQueue(); + _eventMan->processInput(); + _eventMan->processCommandQueue(); //} while (!_stopWaitingForPlayerInput || !_gameTimeTicking); _displayMan->clearScreen(kColorBlack); _displayMan->drawDungeon(_dungeonMan->_currMap.partyDir, _dungeonMan->_currMap.partyPosX, _dungeonMan->_currMap.partyPosY); - // DUMMY CODE: + // DUMMY CODE: next line _menuMan->drawMovementArrows(); _displayMan->updateScreen(); _system->delayMillis(10); } - - - return Common::kNoError; -} - - -void DMEngine::startGame() { - _eventMan->_primaryMouseInput = gPrimaryMouseInput_Interface; - _eventMan->_secondaryMouseInput = gSecondaryMouseInput_Movement; - - - _menuMan->drawMovementArrows(); - _gameTimeTicking = true; - - // MISSING CODE: Lot of stuff } } // End of namespace DM diff --git a/engines/dm/dm.h b/engines/dm/dm.h index 67d968a7f9..852b210ff0 100644 --- a/engines/dm/dm.h +++ b/engines/dm/dm.h @@ -84,7 +84,9 @@ public: DMEngine(OSystem *syst); ~DMEngine(); - virtual Common::Error run(); + virtual Common::Error run(); // @ main + void initializeGame(); // @ F0463_START_InitializeGame_CPSADEF + void gameloop(); // @ F0002_MAIN_GameLoop_CPSDF private: Console *_console; diff --git a/engines/dm/gfx.h b/engines/dm/gfx.h index cf06f1c7eb..241d45bfda 100644 --- a/engines/dm/gfx.h +++ b/engines/dm/gfx.h @@ -245,8 +245,6 @@ class DisplayMan { void drawSquareD0R(direction dir, int16 posX, int16 posY); // @ F0126_DUNGEONVIEW_DrawSquareD0R void drawSquareD0C(direction dir, int16 posX, int16 posY); // @ F0127_DUNGEONVIEW_DrawSquareD0C - void loadWallSet(WallSet set); // @ F0095_DUNGEONVIEW_LoadWallSet - void loadFloorSet(FloorSet set); // @ F0094_DUNGEONVIEW_LoadFloorSet void applyCreatureReplColors(int replacedColor, int replacementColor); // @ F0093_DUNGEONVIEW_ApplyCreatureReplacementColors @@ -258,6 +256,9 @@ public: DisplayMan(DMEngine *dmEngine); ~DisplayMan(); + void loadWallSet(WallSet set); // @ F0095_DUNGEONVIEW_LoadWallSet + void loadFloorSet(FloorSet set); // @ F0094_DUNGEONVIEW_LoadFloorSet + void setUpScreens(uint16 width, uint16 height); void loadGraphics(); // @ F0479_MEMORY_ReadGraphicsDatHeader, F0460_START_InitializeGraphicData void loadCurrentMapGraphics(); diff --git a/engines/dm/loadsave.cpp b/engines/dm/loadsave.cpp index e58b746060..5518e7927d 100644 --- a/engines/dm/loadsave.cpp +++ b/engines/dm/loadsave.cpp @@ -22,6 +22,7 @@ LoadgameResponse LoadsaveMan::loadgame() { assert(false); // MISSING CODE: load game } + _vm->_dungeonMan->loadDungeonFile(); if (newGame) { |