aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
Diffstat (limited to 'engines')
-rw-r--r--engines/dm/dungeonman.cpp57
-rw-r--r--engines/dm/dungeonman.h36
-rw-r--r--engines/dm/gfx.cpp57
-rw-r--r--engines/dm/gfx.h64
4 files changed, 149 insertions, 65 deletions
diff --git a/engines/dm/dungeonman.cpp b/engines/dm/dungeonman.cpp
index 0702ab2fbb..bb803abf92 100644
--- a/engines/dm/dungeonman.cpp
+++ b/engines/dm/dungeonman.cpp
@@ -53,7 +53,62 @@ void DungeonMan::mapCoordsAfterRelMovement(direction dir, int16 stepsForward, in
posY += dirIntoStepCountNorth[dir] * stepsRight;
}
-DungeonMan::DungeonMan(DMEngine *dmEngine) : _vm(dmEngine), _rawDunFileData(NULL), _maps(NULL), _rawMapData(NULL) {}
+DungeonMan::DungeonMan(DMEngine *dmEngine) : _vm(dmEngine), _rawDunFileData(NULL), _maps(NULL), _rawMapData(NULL) {
+ _dunData.columCount = 0;
+ _dunData.eventMaximumCount = 0;
+
+ _dunData.mapsFirstColumnIndex = nullptr;
+ _dunData.columnsCumulativeSquareThingCount = nullptr;
+ _dunData.squareFirstThings = nullptr;
+ _dunData.textData = nullptr;
+ _dunData.mapData = nullptr;
+
+ for (int i = 0; i < 16; i++)
+ _dunData.thingsData[i] = nullptr;
+
+ _currMap.partyDir = kDirNorth;
+ _currMap.partyPosX = 0;
+ _currMap.partyPosY = 0;
+ _currMap.currPartyMapIndex = 0;
+ _currMap.index = 0;
+ _currMap.width = 0;
+ _currMap.height = 0;
+
+ _currMap.data = nullptr;
+ _currMap.map = nullptr;
+ _currMap.colCumulativeSquareFirstThingCount = nullptr;
+
+ _messages.newGame = true;
+ _messages.restartGameRequest = false;
+
+ _rawDunFileDataSize = 0;
+ _rawDunFileData = nullptr;
+
+ _fileHeader.dungeonId = 0;
+ _fileHeader.ornamentRandomSeed = 0;
+ _fileHeader.rawMapDataSize = 0;
+ _fileHeader.mapCount = 0;
+ _fileHeader.textDataWordCount = 0;
+ _fileHeader.partyStartDir = kDirNorth;
+ _fileHeader.partyStartPosX = 0;
+ _fileHeader.partyStartPosY = 0;
+ _fileHeader.squareFirstThingCount = 0;
+
+ for (int i = 0; i < 16; i++)
+ _fileHeader.thingCounts[i] = 0;
+
+ _maps = nullptr;
+ _rawMapData = nullptr;
+
+ _currMapInscriptionWallOrnIndex = 0;
+ _isFacingAlcove = false;
+ _isFacingViAltar = false;
+ _isFacingFountain = false;
+
+ for (int i = 0; i < 4; i++)
+ for (int j = 0; j < 6; j++)
+ _dungeonViewClickableBoxes[j][i] = 0;
+}
DungeonMan::~DungeonMan() {
delete[] _rawDunFileData;
diff --git a/engines/dm/dungeonman.h b/engines/dm/dungeonman.h
index cb53ba0440..7652596eb4 100644
--- a/engines/dm/dungeonman.h
+++ b/engines/dm/dungeonman.h
@@ -331,7 +331,6 @@ public:
byte toByte() { return data; } // I don't like 'em casts
};
-
struct DungeonFileHeader {
uint16 dungeonId; // @ G0526_ui_DungeonID
// equal to dungeonId
@@ -366,21 +365,19 @@ struct Map {
uint8 doorSet0, doorSet1;
}; // @ MAP
-
-
struct DungeonData {
// I have no idea the heck is this
- uint16 *mapsFirstColumnIndex = NULL; // @ G0281_pui_DungeonMapsFirstColumnIndex
+ uint16 *mapsFirstColumnIndex; // @ G0281_pui_DungeonMapsFirstColumnIndex
uint16 columCount; // @ G0282_ui_DungeonColumnCount
// I have no idea the heck is this
- uint16 *columnsCumulativeSquareThingCount = NULL; // @ G0280_pui_DungeonColumnsCumulativeSquareThingCount
- Thing *squareFirstThings = NULL; // @ G0283_pT_SquareFirstThings
- uint16 *textData = NULL; // @ G0260_pui_DungeonTextData
+ uint16 *columnsCumulativeSquareThingCount; // @ G0280_pui_DungeonColumnsCumulativeSquareThingCount
+ Thing *squareFirstThings; // @ G0283_pT_SquareFirstThings
+ uint16 *textData; // @ G0260_pui_DungeonTextData
- uint16 **thingsData[16] = {NULL}; // @ G0284_apuc_ThingData
+ uint16 **thingsData[16]; // @ G0284_apuc_ThingData
- byte ***mapData = NULL; // @ G0279_pppuc_DungeonMapData
+ byte ***mapData; // @ G0279_pppuc_DungeonMapData
// TODO: ??? is this doing here
uint16 eventMaximumCount; // @ G0369_ui_EventMaximumCount
@@ -393,21 +390,18 @@ struct CurrMapData {
uint8 currPartyMapIndex; // @ G0309_i_PartyMapIndex
uint8 index; // @ G0272_i_CurrentMapIndex
- byte **data = NULL; // @ G0271_ppuc_CurrentMapData
- Map *map = NULL; // @ G0269_ps_CurrentMap
+ byte **data; // @ G0271_ppuc_CurrentMapData
+ Map *map; // @ G0269_ps_CurrentMap
uint16 width; // @ G0273_i_CurrentMapWidth
uint16 height; // @ G0274_i_CurrentMapHeight
- uint16 *colCumulativeSquareFirstThingCount = NULL; // @G0270_pui_CurrentMapColumnsCumulativeSquareFirstThingCount
+ uint16 *colCumulativeSquareFirstThingCount; // @G0270_pui_CurrentMapColumnsCumulativeSquareFirstThingCount
}; // @ AGGREGATE
struct Messages {
- bool newGame = true; // @ G0298_B_NewGame
- bool restartGameRequest = false; // @ G0523_B_RestartGameRequested
+ bool newGame; // @ G0298_B_NewGame
+ bool restartGameRequest; // @ G0523_B_RestartGameRequested
}; // @ AGGREGATE
-
-
-
class DungeonMan {
DMEngine *_vm;
@@ -446,15 +440,15 @@ public:
void setSquareAspect(uint16 *aspectArray, direction dir, int16 mapX, int16 mapY); // @ F0172_DUNGEON_SetSquareAspect
void decodeText(char *destString, Thing thing, TextType type); // F0168_DUNGEON_DecodeText
- uint32 _rawDunFileDataSize = 0; // @ probably NONE
- byte *_rawDunFileData = NULL; // @ ???
+ uint32 _rawDunFileDataSize; // @ probably NONE
+ byte *_rawDunFileData; // @ ???
DungeonFileHeader _fileHeader; // @ G0278_ps_DungeonHeader
DungeonData _dunData; // @ NONE
CurrMapData _currMap; // @ NONE
- Map *_maps = NULL; // @ G0277_ps_DungeonMaps
+ Map *_maps; // @ G0277_ps_DungeonMaps
// does not have to be freed
- byte *_rawMapData = NULL; // @ G0276_puc_DungeonRawMapData
+ byte *_rawMapData; // @ G0276_puc_DungeonRawMapData
Messages _messages; // @ NONE;
int16 _currMapInscriptionWallOrnIndex; // @ G0265_i_CurrentMapInscriptionWallOrnamentIndex
diff --git a/engines/dm/gfx.cpp b/engines/dm/gfx.cpp
index 5a81151f64..581e4fa343 100644
--- a/engines/dm/gfx.cpp
+++ b/engines/dm/gfx.cpp
@@ -633,15 +633,62 @@ int gFountainOrnIndices[kFountainOrnCount] = {35}; // @ G0193_ai_Graphic558_Foun
byte gAlcoveOrnIndices[kAlcoveOrnCount] = { // @ G0192_auc_Graphic558_AlcoveOrnamentIndices
1, /* Square Alcove */
2, /* Vi Altar */
- 3}; /* Arched Alcove */
-
+ 3}; /* Arched Alcove */
}
using namespace DM;
-DisplayMan::DisplayMan(DMEngine *dmEngine) :
- _vm(dmEngine), _screenWidth(0), _screenHeight(0),
- _vgaBuffer(NULL), _bitmaps(NULL) {}
+DisplayMan::DisplayMan(DMEngine *dmEngine) : _vm(dmEngine) {
+ _vgaBuffer = nullptr;
+ _bitmaps = nullptr;
+ _grapItemCount = 0;
+ _packedItemPos = nullptr;
+ _packedBitmaps = nullptr;
+ _bitmaps = nullptr;
+ _tmpBitmap = nullptr;
+ _floorBitmap = nullptr;
+ _ceilingBitmap = nullptr;
+ _currMapAllowedCreatureTypes = nullptr;
+
+ _screenWidth = _screenHeight = 0;
+ _championPortraitOrdinal = 0;
+ _currMapViAltarIndex = 0;
+
+ for (int i = 0; i < 25; i++)
+ _wallSetBitMaps[i] = nullptr;
+
+ for (int i = 0; i < kStairsGraphicCount; i++)
+ _stairIndices[i] = 0;
+
+ for (int i = 0; i < 4; i++)
+ _palChangesProjectile[i] = nullptr;
+
+ for (int i = 0; i < kAlcoveOrnCount; i++)
+ _currMapAlcoveOrnIndices[i] = 0;
+
+ for (int i = 0; i < kFountainOrnCount; i++)
+ _currMapFountainOrnIndices[i] = 0;
+
+ for (int i = 0; i < 2; i++) {
+ for (int j = 0; j < 16; j++) {
+ _currMapWallOrnInfo[j][i] = 0;
+ _currMapFloorOrnInfo[j][i] = 0;
+ }
+ for (int j = 0; j < 17; j++) {
+ _currMapDoorOrnInfo[j][i] = 0;
+ }
+ }
+
+ for (int i = 0; i < 16; i++) {
+ _currMapWallOrnIndices[i] = 0;
+ _currMapFloorOrnIndices[i] = 0;
+ }
+
+ for (int i = 0; i < 18; i++)
+ _currMapDoorOrnIndices[i] = 0;
+
+ Thing _inscriptionThing = Thing::thingNone;
+}
DisplayMan::~DisplayMan() {
delete[] _packedItemPos;
diff --git a/engines/dm/gfx.h b/engines/dm/gfx.h
index d8f4e29247..8ed7c565be 100644
--- a/engines/dm/gfx.h
+++ b/engines/dm/gfx.h
@@ -121,36 +121,26 @@ extern Viewport gDungeonViewport;
#define kDoorOrnDestroyedMask 15 // @ C15_DOOR_ORNAMENT_DESTROYED_MASK
#define kDoorOrnThivesEyeMask 16 // @ C16_DOOR_ORNAMENT_THIEVES_EYE_MASK
-
-
-
class DisplayMan {
- DMEngine *_vm = NULL;
+ DMEngine *_vm;
uint16 _screenWidth;
- uint16 _screenHeight = 0;
- byte *_vgaBuffer = NULL;
-
+ uint16 _screenHeight;
+ byte *_vgaBuffer;
/// Related to graphics.dat file
- uint16 _grapItemCount = 0; // @ G0632_ui_GraphicCount
- uint32 *_packedItemPos = NULL;
- byte *_packedBitmaps = NULL;
- byte **_bitmaps = NULL;
-
+ uint16 _grapItemCount; // @ G0632_ui_GraphicCount
+ uint32 *_packedItemPos;
+ byte *_packedBitmaps;
+ byte **_bitmaps;
// pointers 13,14 and [15-19] are owned by this array
- byte *_wallSetBitMaps[25] = {NULL}; // @G[0696..0710]_puc_Bitmap_WallSet_...
-
- uint16 _stairIndices[kStairsGraphicCount] = {0};
-
+ byte *_wallSetBitMaps[25]; // @G[0696..0710]_puc_Bitmap_WallSet_...
+ uint16 _stairIndices[kStairsGraphicCount];
// pointers are not owned by these fields
- byte *_floorBitmap = NULL;
- byte *_ceilingBitmap = NULL;
-
-
- byte *_palChangesProjectile[4] = {NULL}; // @G0075_apuc_PaletteChanges_Projectile
-
+ byte *_floorBitmap;
+ byte *_ceilingBitmap;
+ byte *_palChangesProjectile[4]; // @G0075_apuc_PaletteChanges_Projectile
DisplayMan(const DisplayMan &other); // no implementation on purpose
void operator=(const DisplayMan &rhs); // no implementation on purpose
@@ -185,16 +175,14 @@ class DisplayMan {
bool isDrawnWallOrnAnAlcove(int16 wallOrnOrd, ViewWall viewWallIndex); // @ F0107_DUNGEONVIEW_IsDrawnWallOrnamentAnAlcove_CPSF
// some methods use this for a stratchpad, don't make assumptions about content between function calls
- byte *_tmpBitmap = NULL;
+ byte *_tmpBitmap;
public:
DisplayMan(DMEngine *dmEngine);
~DisplayMan();
- void setUpScreens(uint16 width, uint16 height);
+ void setUpScreens(uint16 width, uint16 height);
void loadGraphics(); // @ F0479_MEMORY_ReadGraphicsDatHeader, F0460_START_InitializeGraphicData
-
void loadCurrentMapGraphics();
-
void loadPalette(uint16 *palette);
/// Gives the width of an IMG0 type item
@@ -222,20 +210,20 @@ public:
void drawDungeon(direction dir, int16 posX, int16 posY); // @ F0128_DUNGEONVIEW_Draw_CPSF
void updateScreen();
- int16 _championPortraitOrdinal = 0; // @ G0289_i_DungeonView_ChampionPortraitOrdinal
- int16 _currMapAlcoveOrnIndices[kAlcoveOrnCount] = {0}; // @ G0267_ai_CurrentMapAlcoveOrnamentIndices
- int16 _currMapFountainOrnIndices[kFountainOrnCount] = {0}; // @ G0268_ai_CurrentMapFountainOrnamentIndices
- int16 _currMapWallOrnInfo[16][2] = {0}; // @ G0101_aai_CurrentMapWallOrnamentsInfo
- int16 _currMapFloorOrnInfo[16][2] = {0}; // @ G0102_aai_CurrentMapFloorOrnamentsInfo
- int16 _currMapDoorOrnInfo[17][2] = {0}; // @ G0103_aai_CurrentMapDoorOrnamentsInfo
- byte *_currMapAllowedCreatureTypes = NULL; // @ G0264_puc_CurrentMapAllowedCreatureTypes
- byte _currMapWallOrnIndices[16] = {0}; // @ G0261_auc_CurrentMapWallOrnamentIndices
- byte _currMapFloorOrnIndices[16] = {0}; // @ G0262_auc_CurrentMapFloorOrnamentIndices
- byte _currMapDoorOrnIndices[18] = {0}; // @ G0263_auc_CurrentMapDoorOrnamentIndices
+ int16 _championPortraitOrdinal; // @ G0289_i_DungeonView_ChampionPortraitOrdinal
+ int16 _currMapAlcoveOrnIndices[kAlcoveOrnCount]; // @ G0267_ai_CurrentMapAlcoveOrnamentIndices
+ int16 _currMapFountainOrnIndices[kFountainOrnCount]; // @ G0268_ai_CurrentMapFountainOrnamentIndices
+ int16 _currMapWallOrnInfo[16][2]; // @ G0101_aai_CurrentMapWallOrnamentsInfo
+ int16 _currMapFloorOrnInfo[16][2]; // @ G0102_aai_CurrentMapFloorOrnamentsInfo
+ int16 _currMapDoorOrnInfo[17][2]; // @ G0103_aai_CurrentMapDoorOrnamentsInfo
+ byte *_currMapAllowedCreatureTypes; // @ G0264_puc_CurrentMapAllowedCreatureTypes
+ byte _currMapWallOrnIndices[16]; // @ G0261_auc_CurrentMapWallOrnamentIndices
+ byte _currMapFloorOrnIndices[16]; // @ G0262_auc_CurrentMapFloorOrnamentIndices
+ byte _currMapDoorOrnIndices[18]; // @ G0263_auc_CurrentMapDoorOrnamentIndices
- int16 _currMapViAltarIndex = 0; // @ G0266_i_CurrentMapViAltarWallOrnamentIndex
+ int16 _currMapViAltarIndex; // @ G0266_i_CurrentMapViAltarWallOrnamentIndex
- Thing _inscriptionThing = Thing::thingNone; // @ G0290_T_DungeonView_InscriptionThing
+ Thing _inscriptionThing; // @ G0290_T_DungeonView_InscriptionThing
};
}