static int ReadGameFileInfo (CFile& cf, int nStartOffset) { gameTopFileInfo.fileinfo_signature = cf.ReadShort (); gameTopFileInfo.fileinfoVersion = cf.ReadShort (); gameTopFileInfo.fileinfo_sizeof = cf.ReadInt (); // Check signature if (gameTopFileInfo.fileinfo_signature != 0x6705) return -1; // Check version number if (gameTopFileInfo.fileinfoVersion < GAME_COMPATIBLE_VERSION) return -1; // Now, Read in the fileinfo if (cf.Seek (nStartOffset, SEEK_SET)) Error ("Error seeking to gameFileInfo in gamesave.c"); gameFileInfo.fileinfo_signature = cf.ReadShort (); gameFileInfo.fileinfoVersion = cf.ReadShort (); gameFileInfo.fileinfo_sizeof = cf.ReadInt (); cf.Read (gameFileInfo.mine_filename, sizeof (char), 15); gameFileInfo.level = cf.ReadInt (); gameFileInfo.player.offset = cf.ReadInt (); // Player info gameFileInfo.player.size = cf.ReadInt (); gameFileInfo.objects.offset = cf.ReadInt (); // Object info gameFileInfo.objects.count = cf.ReadInt (); gameFileInfo.objects.size = cf.ReadInt (); gameFileInfo.walls.offset = cf.ReadInt (); gameFileInfo.walls.count = cf.ReadInt (); gameFileInfo.walls.size = cf.ReadInt (); gameFileInfo.doors.offset = cf.ReadInt (); gameFileInfo.doors.count = cf.ReadInt (); gameFileInfo.doors.size = cf.ReadInt (); gameFileInfo.triggers.offset = cf.ReadInt (); gameFileInfo.triggers.count = cf.ReadInt (); gameFileInfo.triggers.size = cf.ReadInt (); gameFileInfo.links.offset = cf.ReadInt (); gameFileInfo.links.count = cf.ReadInt (); gameFileInfo.links.size = cf.ReadInt (); gameFileInfo.control.offset = cf.ReadInt (); gameFileInfo.control.count = cf.ReadInt (); gameFileInfo.control.size = cf.ReadInt (); gameFileInfo.botGen.offset = cf.ReadInt (); gameFileInfo.botGen.count = cf.ReadInt (); gameFileInfo.botGen.size = cf.ReadInt (); if (gameTopFileInfo.fileinfoVersion >= 29) { gameFileInfo.lightDeltaIndices.offset = cf.ReadInt (); gameFileInfo.lightDeltaIndices.count = cf.ReadInt (); gameFileInfo.lightDeltaIndices.size = cf.ReadInt (); gameFileInfo.lightDeltas.offset = cf.ReadInt (); gameFileInfo.lightDeltas.count = cf.ReadInt (); gameFileInfo.lightDeltas.size = cf.ReadInt (); } if (gameData.segs.nLevelVersion >= 17) { gameFileInfo.equipGen.offset = cf.ReadInt (); gameFileInfo.equipGen.count = cf.ReadInt (); gameFileInfo.equipGen.size = cf.ReadInt (); } return 0; }
/* * reads n jointlist structs from a CFile */ static int ReadJointLists (jointlist *jl, int n, CFile& cf) { int i; for (i = 0; i < n; i++) { jl [i].n_joints = cf.ReadShort (); jl [i].offset = cf.ReadShort (); } return i; }
int ReadReactorTriggers (CFile& cf) { int i, j; for (i = 0; i < gameFileInfo.control.count; i++) { gameData.reactor.triggers.nLinks = cf.ReadShort (); for (j = 0; j < MAX_CONTROLCEN_LINKS; j++) gameData.reactor.triggers.segments [j] = cf.ReadShort (); for (j = 0; j < MAX_CONTROLCEN_LINKS; j++) gameData.reactor.triggers.sides [j] = cf.ReadShort (); } return gameFileInfo.control.count; }
static int ReadLevelInfo (CFile& cf) { if (gameTopFileInfo.fileinfoVersion >= 31) { //load mine filename // read newline-terminated string, not sure what version this changed. cf.GetS (gameData.missions.szCurrentLevel, sizeof (gameData.missions.szCurrentLevel)); if (gameData.missions.szCurrentLevel [strlen (gameData.missions.szCurrentLevel) - 1] == '\n') gameData.missions.szCurrentLevel [strlen (gameData.missions.szCurrentLevel) - 1] = 0; } else if (gameTopFileInfo.fileinfoVersion >= 14) { //load mine filename // read null-terminated string char *p = gameData.missions.szCurrentLevel; //must do read one char at a time, since no cf.GetS() do { *p = cf.GetC (); } while (*p++); } else gameData.missions.szCurrentLevel [0] = 0; if (gameTopFileInfo.fileinfoVersion >= 19) { //load pof names nSavePOFNames = cf.ReadShort (); if ((nSavePOFNames != 0x614d) && (nSavePOFNames != 0x5547)) { // "Ma"de w/DMB beta/"GU"ILE if (nSavePOFNames >= MAX_POLYGON_MODELS) return -1; cf.Read (szSavePOFNames, nSavePOFNames, SHORT_FILENAME_LEN); } } return 0; }
/* * reads n tBitmapIndex structs from a CFile */ int BitmapIndexReadN (tBitmapIndex *pbi, int n, CFile& cf) { int i; for (i = 0; i < n; i++) pbi [i].index = cf.ReadShort (); return i; }
void CTrigger::LoadState (CFile& cf, bool bObjTrigger) { m_info.nType = (ubyte) cf.ReadByte (); if (bObjTrigger && (saveGameManager.Version () >= 41)) m_info.flags = cf.ReadShort (); else m_info.flags = short (cf.ReadByte ()); m_info.nLinks = cf.ReadByte (); m_info.value = cf.ReadFix (); m_info.time = cf.ReadFix (); for (int i = 0; i < MAX_TRIGGER_TARGETS; i++) { m_info.segments [i] = cf.ReadShort (); m_info.sides [i] = cf.ReadShort (); } m_info.nChannel = -1; m_info.tOperated = (saveGameManager.Version () < 44) ? -1 : cf.ReadFix (); }
void ReadEffectClip (tEffectClip& ec, CFile& cf) { ReadVideoClip (ec.vClipInfo, cf); ec.xTimeLeft = cf.ReadFix (); ec.nCurFrame = cf.ReadInt (); ec.changingWallTexture = cf.ReadShort (); ec.changingObjectTexture = cf.ReadShort (); ec.flags = cf.ReadInt (); ec.nCritClip = cf.ReadInt (); ec.nDestBm = cf.ReadInt (); ec.nDestVClip = cf.ReadInt (); ec.nDestEClip = cf.ReadInt (); ec.xDestSize = cf.ReadFix (); ec.nSound = cf.ReadInt (); ec.nSegment = cf.ReadInt (); ec.nSide = cf.ReadInt (); }
/* * reads n tBitmapIndex structs from a CFile */ int ReadBitmapIndices (CArray<tBitmapIndex>& bi, int n, CFile& cf, int o) { int i; for (i = 0; i < n; i++) bi [i + o].index = cf.ReadShort (); return i; }
/* * reads n tTexMapInfo structs from a CFile */ int ReadTMapInfoN (CArray<tTexMapInfo>& ti, int n, CFile& cf) { int i; for (i = 0;i < n;i++) { ti [i].flags = cf.ReadByte (); ti [i].pad [0] = cf.ReadByte (); ti [i].pad [1] = cf.ReadByte (); ti [i].pad [2] = cf.ReadByte (); ti [i].lighting = cf.ReadFix (); ti [i].damage = cf.ReadFix (); ti [i].nEffectClip = cf.ReadShort (); ti [i].destroyed = cf.ReadShort (); ti [i].slide_u = cf.ReadShort (); ti [i].slide_v = cf.ReadShort (); } return i; }
/* * reads n tJointPos structs from a CFile */ int ReadJointPositions (CArray<tJointPos>& jp, int n, CFile& cf, int o) { int i; for (i = 0; i < n; i++) { jp [i + o].jointnum = cf.ReadShort (); cf.ReadAngVec (jp [i + o].angles); } return i; }
void BMReadWeaponInfoD1N (CFile& cf, int i) { CD1WeaponInfo* wiP = gameData.weapons.infoD1 + i; wiP->renderType = cf.ReadByte (); wiP->nModel = cf.ReadByte (); wiP->nInnerModel = cf.ReadByte (); wiP->persistent = cf.ReadByte (); wiP->nFlashVClip = cf.ReadByte (); wiP->flashSound = cf.ReadShort (); wiP->nRobotHitVClip = cf.ReadByte (); wiP->nRobotHitSound = cf.ReadShort (); wiP->nWallHitVClip = cf.ReadByte (); wiP->nWallHitSound = cf.ReadShort (); wiP->fireCount = cf.ReadByte (); wiP->nAmmoUsage = cf.ReadByte (); wiP->nVClipIndex = cf.ReadByte (); wiP->destructible = cf.ReadByte (); wiP->matter = cf.ReadByte (); wiP->bounce = cf.ReadByte (); wiP->homingFlag = cf.ReadByte (); wiP->dum1 = cf.ReadByte (); wiP->dum2 = cf.ReadByte (); wiP->dum3 = cf.ReadByte (); wiP->xEnergyUsage = cf.ReadFix (); wiP->xFireWait = cf.ReadFix (); wiP->bitmap.index = cf.ReadShort (); wiP->blob_size = cf.ReadFix (); wiP->xFlashSize = cf.ReadFix (); wiP->xImpactSize = cf.ReadFix (); for (i = 0; i < NDL; i++) wiP->strength [i] = cf.ReadFix (); for (i = 0; i < NDL; i++) wiP->speed [i] = cf.ReadFix (); wiP->mass = cf.ReadFix (); wiP->drag = cf.ReadFix (); wiP->thrust = cf.ReadFix (); wiP->poLenToWidthRatio = cf.ReadFix (); wiP->light = cf.ReadFix (); wiP->lifetime = cf.ReadFix (); wiP->xDamageRadius = cf.ReadFix (); wiP->picture.index = cf.ReadShort (); }
grsBitmap *PiggyLoadBitmap (const char *pszFile) { CFile cf; grsBitmap *bmp; tBitmapFileHeader bfh; tBitmapInfoHeader bih; if (!cf.Open (pszFile, gameFolders.szDataDir, "rb", 0)) return NULL; bfh.bfType = cf.ReadShort (); bfh.bfSize = (unsigned int) cf.ReadInt (); bfh.bfReserved1 = cf.ReadShort (); bfh.bfReserved2 = cf.ReadShort (); bfh.bfOffBits = (unsigned int) cf.ReadInt (); bih.biSize = (unsigned int) cf.ReadInt (); bih.biWidth = (unsigned int) cf.ReadInt (); bih.biHeight = (unsigned int) cf.ReadInt (); bih.biPlanes = cf.ReadShort (); bih.biBitCount = cf.ReadShort (); bih.biCompression = (unsigned int) cf.ReadInt (); bih.biSizeImage = (unsigned int) cf.ReadInt (); bih.biXPelsPerMeter = (unsigned int) cf.ReadInt (); bih.biYPelsPerMeter = (unsigned int) cf.ReadInt (); bih.biClrUsed = (unsigned int) cf.ReadInt (); bih.biClrImportant = (unsigned int) cf.ReadInt (); if (!(bmp = GrCreateBitmap (bih.biWidth, bih.biHeight, 1))) { cf.Close (); return NULL; } cf.Seek (bfh.bfOffBits, SEEK_SET); if (cf.Read (bmp->bmTexBuf, bih.biWidth * bih.biHeight, 1) != 1) { GrFreeBitmap (bmp); return NULL; } cf.Close (); return bmp; }
CBitmap *PiggyLoadBitmap (const char *pszFile) { CFile cf; CBitmap *bmP; tBitmapFileHeader bfh; tBitmapInfoHeader bih; if (!cf.Open (pszFile, gameFolders.szDataDir, "rb", 0)) return NULL; bfh.bfType = cf.ReadShort (); bfh.bfSize = (uint) cf.ReadInt (); bfh.bfReserved1 = cf.ReadShort (); bfh.bfReserved2 = cf.ReadShort (); bfh.bfOffBits = (uint) cf.ReadInt (); bih.biSize = (uint) cf.ReadInt (); bih.biWidth = (uint) cf.ReadInt (); bih.biHeight = (uint) cf.ReadInt (); bih.biPlanes = cf.ReadShort (); bih.biBitCount = cf.ReadShort (); bih.biCompression = (uint) cf.ReadInt (); bih.biSizeImage = (uint) cf.ReadInt (); bih.biXPelsPerMeter = (uint) cf.ReadInt (); bih.biYPelsPerMeter = (uint) cf.ReadInt (); bih.biClrUsed = (uint) cf.ReadInt (); bih.biClrImportant = (uint) cf.ReadInt (); if (!(bmP = CBitmap::Create (0, bih.biWidth, bih.biHeight, 1))) { cf.Close (); return NULL; } cf.Seek (bfh.bfOffBits, SEEK_SET); if (bmP->Read (cf, bih.biWidth * bih.biHeight) != bih.biWidth * bih.biHeight) { delete bmP; return NULL; } cf.Close (); return bmP; }
void CSegment::ReadType (CFile& cf, ubyte flags) { if (flags & (1 << MAX_SIDES_PER_SEGMENT)) { m_nType = cf.ReadByte (); m_nMatCen = cf.ReadByte (); m_value = char (cf.ReadShort ()); } else { m_nType = 0; m_nMatCen = -1; m_value = 0; } }
void CSegment::Read (CFile& cf) { #if DBG if (Index () == nDbgSeg) nDbgSeg = nDbgSeg; #endif if (gameStates.app.bD2XLevel) { m_owner = cf.ReadByte (); m_group = cf.ReadByte (); } else { m_owner = -1; m_group = -1; } ubyte flags = bNewFileFormat ? cf.ReadByte () : 0x7f; if (gameData.segs.nLevelVersion == 5) { // d2 SHAREWARE level ReadType (cf, flags); ReadVerts (cf); ReadChildren (cf, flags); } else { ReadChildren (cf, flags); ReadVerts (cf); if (gameData.segs.nLevelVersion <= 1) { // descent 1 level ReadType (cf, flags); } } m_objects = -1; if (gameData.segs.nLevelVersion <= 5) // descent 1 thru d2 SHAREWARE level m_xAvgSegLight = fix (cf.ReadShort ()) << 4; // Read the walls as a 6 byte array flags = bNewFileFormat ? cf.ReadByte () : 0x3f; int i; for (i = 0; i < MAX_SIDES_PER_SEGMENT; i++) m_sides [i].ReadWallNum (cf, (flags & (1 << i)) != 0); ushort sideVerts [4]; for (i = 0; i < MAX_SIDES_PER_SEGMENT; i++) { ::GetCorners (Index (), i, sideVerts); m_sides [i].Read (cf, sideVerts, m_children [i] == -1); } }
void BMReadD1TMapNums (CFile& cf) { int i, d1_index; FreeD1TMapNums (); cf.Seek (8, SEEK_SET); MALLOC (d1_tmap_nums, short, D1_MAX_TMAP_NUM); for (i = 0; i < D1_MAX_TMAP_NUM; i++) d1_tmap_nums [i] = -1; for (i = 0; i < D1_MAX_TEXTURES; i++) { d1_index = cf.ReadShort (); Assert (d1_index >= 0 && d1_index < D1_MAX_TMAP_NUM); d1_tmap_nums [d1_index] = i; } atexit (FreeD1TMapNums); }
int LoadMineSegmentsCompiled (CFile& cf) { int i, nSegments, nVertices; ubyte nCompiledVersion; char *psz; gameData.segs.vMin.Set (0x7fffffff, 0x7fffffff, 0x7fffffff); /* [X] = gameData.segs.vMin[Y] = gameData.segs.vMin[Y] = 0x7fffffff;*/ gameData.segs.vMax.Set (-0x7fffffff, -0x7fffffff, -0x7fffffff); /*[X] = gameData.segs.vMax[X] = gameData.segs.vMax[Y] = gameData.segs.vMax[Y] = -0x7fffffff;*/ gameStates.render.bColored = 0; bD1PigPresent = CFile::Exist (D1_PIGFILE, gameFolders.szDataDir, 0); psz = strchr (gameData.segs.szLevelFilename, '.'); bNewFileFormat = !psz || strcmp (psz, ".sdl"); // For compiled levels, textures map to themselves, prevent nTexOverride always being gray, // bug which Matt and John refused to acknowledge, so here is Mike, fixing it. //=============================== Reading part ============================== nCompiledVersion = cf.ReadByte (); //Assert ( nCompiledVersion==COMPILED_MINE_VERSION ); #if TRACE if (nCompiledVersion != COMPILED_MINE_VERSION) console.printf (CON_DBG, "compiled mine version=%i\n", nCompiledVersion); //many levels have "wrong" versions. Theres no point in aborting because of it, I think. console.printf (CON_DBG, " compiled mine version = %d\n", nCompiledVersion); #endif nVertices = bNewFileFormat ? cf.ReadShort () : cf.ReadInt (); Assert (nVertices <= MAX_VERTICES); #if TRACE console.printf (CON_DBG, " %d vertices\n", gameData.segs.nVertices); #endif nSegments = bNewFileFormat ? cf.ReadShort () : cf.ReadInt (); if (nSegments >= MAX_SEGMENTS) { Warning (TXT_LEVEL_TOO_LARGE); return -1; } if (!InitGame (nSegments, nVertices)) return -1; #if TRACE console.printf (CON_DBG, " %d segments\n", gameData.segs.nSegments); #endif for (i = 0; i < gameData.segs.nVertices; i++) { cf.ReadVector (gameData.segs.vertices [i]); #if !FLOAT_COORD gameData.segs.fVertices [i][X] = X2F (gameData.segs.vertices [i][X]); gameData.segs.fVertices [i][Y] = X2F (gameData.segs.vertices [i][Y]); gameData.segs.fVertices [i][Z] = X2F (gameData.segs.vertices [i][Z]); #endif if (gameData.segs.vMin [X] > gameData.segs.vertices [i][X]) gameData.segs.vMin [X] = gameData.segs.vertices [i][X]; if (gameData.segs.vMin [Y] > gameData.segs.vertices [i][Y]) gameData.segs.vMin [Y] = gameData.segs.vertices [i][Y]; if (gameData.segs.vMin [Z] > gameData.segs.vertices [i][Z]) gameData.segs.vMin [Z] = gameData.segs.vertices [i][Z]; if (gameData.segs.vMax [X] < gameData.segs.vertices [i][X]) gameData.segs.vMax [X] = gameData.segs.vertices [i][X]; if (gameData.segs.vMax [Y] < gameData.segs.vertices [i][Y]) gameData.segs.vMax [Y] = gameData.segs.vertices [i][Y]; if (gameData.segs.vMax [Z] < gameData.segs.vertices [i][Z]) gameData.segs.vMax [Z] = gameData.segs.vertices [i][Z]; } SEGMENTS.Clear (); #if TRACE console.printf (CON_DBG, " loading segments ...\n"); #endif gameData.segs.nLastVertex = gameData.segs.nVertices - 1; gameData.segs.nLastSegment = gameData.segs.nSegments - 1; if (gameStates.app.bProgressBars && gameOpts->menus.nStyle) LoadSegmentsGauge (cf); else { LoadSegmentsCompiled (-1, cf); SetupSegments (); // Fill in side type and normals. LoadExtSegmentsCompiled (cf); LoadVertLightsCompiled (-1, cf); LoadSideLightsCompiled (-1, cf); LoadTexColorsCompiled (-1, cf); ComputeSegSideCenters (-1); } gameData.segs.fRad = X2F (CFixVector::Dist(gameData.segs.vMax, gameData.segs.vMin)); ResetObjects (1); //one CObject, the player return 0; }
void CSegment::ReadChildren (CFile& cf, ubyte flags) { for (int i = 0; i < MAX_SIDES_PER_SEGMENT; i++) m_children [i] = (flags & (1 << i)) ? cf.ReadShort () : -1; }
void CSegment::ReadVerts (CFile& cf) { for (int i = 0; i < MAX_VERTICES_PER_SEGMENT; i++) m_verts [i] = cf.ReadShort (); }
void BMReadAll (CFile& cf) { int i, t; gameData.pig.tex.nTextures [0] = cf.ReadInt (); /*---*/PrintLog (" Loading %d texture indices\n", gameData.pig.tex.nTextures [0]); ReadBitmapIndices (gameData.pig.tex.bmIndex [0], gameData.pig.tex.nTextures [0], cf); BuildTextureIndex (0, gameData.pig.tex.nTextures [0]); ReadTMapInfoN (gameData.pig.tex.tMapInfo [0], gameData.pig.tex.nTextures [0], cf); t = cf.ReadInt (); /*---*/PrintLog (" Loading %d sound indices\n", t); cf.Read (Sounds [0], sizeof (ubyte), t); cf.Read (AltSounds [0], sizeof (ubyte), t); gameData.eff.nClips [0] = cf.ReadInt (); /*---*/PrintLog (" Loading %d animation clips\n", gameData.eff.nClips [0]); ReadVideoClips (gameData.eff.vClips [0], gameData.eff.nClips [0], cf); gameData.eff.nEffects [0] = cf.ReadInt (); /*---*/PrintLog (" Loading %d animation descriptions\n", gameData.eff.nEffects [0]); ReadEffectClips (gameData.eff.effects [0], gameData.eff.nEffects [0], cf); // red glow texture animates way too fast gameData.eff.effects [0][32].vClipInfo.xTotalTime *= 10; gameData.eff.effects [0][32].vClipInfo.xFrameTime *= 10; gameData.walls.nAnims [0] = cf.ReadInt (); /*---*/PrintLog (" Loading %d CWall animations\n", gameData.walls.nAnims [0]); ReadWallClips (gameData.walls.anims [0], gameData.walls.nAnims [0], cf); gameData.bots.nTypes [0] = cf.ReadInt (); /*---*/PrintLog (" Loading %d robot descriptions\n", gameData.bots.nTypes [0]); ReadRobotInfos (gameData.bots.info [0], gameData.bots.nTypes [0], cf); gameData.bots.nDefaultTypes = gameData.bots.nTypes [0]; gameData.bots.defaultInfo = gameData.bots.info [0]; gameData.bots.nJoints = cf.ReadInt (); /*---*/PrintLog (" Loading %d robot joint descriptions\n", gameData.bots.nJoints); ReadJointPositions (gameData.bots.joints, gameData.bots.nJoints, cf); gameData.bots.nDefaultJoints = gameData.bots.nJoints; gameData.bots.defaultJoints = gameData.bots.joints; gameData.weapons.nTypes [0] = cf.ReadInt (); /*---*/PrintLog (" Loading %d weapon descriptions\n", gameData.weapons.nTypes [0]); ReadWeaponInfos (0, gameData.weapons.nTypes [0], cf, gameData.pig.tex.nHamFileVersion); BMSetAfterburnerSizes (); gameData.objs.pwrUp.nTypes = cf.ReadInt (); /*---*/PrintLog (" Loading %d powerup descriptions\n", gameData.objs.pwrUp.nTypes); ReadPowerupTypeInfos (gameData.objs.pwrUp.info.Buffer (), gameData.objs.pwrUp.nTypes, cf); gameData.models.nPolyModels = cf.ReadInt (); /*---*/PrintLog (" Loading %d CPolyModel descriptions\n", gameData.models.nPolyModels); ReadPolyModels (gameData.models.polyModels [0], gameData.models.nPolyModels, cf); gameData.models.nDefPolyModels = gameData.models.nPolyModels; memcpy (gameData.models.polyModels [1].Buffer (), gameData.models.polyModels [0].Buffer (), gameData.models.nPolyModels * sizeof (CPolyModel)); /*---*/PrintLog (" Loading poly model data\n"); for (i = 0; i < gameData.models.nPolyModels; i++) { gameData.models.polyModels [0][i].SetBuffer (NULL); gameData.models.polyModels [1][i].SetBuffer (NULL); gameData.models.polyModels [0][i].ReadData (gameData.models.polyModels [1] + i, cf); } for (i = 0; i < gameData.models.nPolyModels; i++) gameData.models.nDyingModels [i] = cf.ReadInt (); for (i = 0; i < gameData.models.nPolyModels; i++) gameData.models.nDeadModels [i] = cf.ReadInt (); t = cf.ReadInt (); /*---*/PrintLog (" Loading %d cockpit gauges\n", t); ReadBitmapIndices (gameData.cockpit.gauges [1], t, cf); ReadBitmapIndices (gameData.cockpit.gauges [0], t, cf); gameData.pig.tex.nObjBitmaps = cf.ReadInt (); /*---*/PrintLog (" Loading %d CObject bitmap indices\n", gameData.pig.tex.nObjBitmaps); ReadBitmapIndices (gameData.pig.tex.objBmIndex, gameData.pig.tex.nObjBitmaps, cf); gameData.pig.tex.defaultObjBmIndex = gameData.pig.tex.objBmIndex; for (i = 0; i < gameData.pig.tex.nObjBitmaps; i++) gameData.pig.tex.objBmIndexP [i] = cf.ReadShort (); /*---*/PrintLog (" Loading CPlayerData ship description\n"); PlayerShipRead (&gameData.pig.ship.only, cf); gameData.models.nCockpits = cf.ReadInt (); /*---*/PrintLog (" Loading %d cockpit bitmaps\n", gameData.models.nCockpits); ReadBitmapIndices (gameData.pig.tex.cockpitBmIndex, gameData.models.nCockpits, cf); gameData.pig.tex.nFirstMultiBitmap = cf.ReadInt (); gameData.reactor.nReactors = cf.ReadInt (); /*---*/PrintLog (" Loading %d reactor descriptions\n", gameData.reactor.nReactors); ReadReactors (cf); gameData.models.nMarkerModel = cf.ReadInt (); if (gameData.pig.tex.nHamFileVersion < 3) { gameData.endLevel.exit.nModel = cf.ReadInt (); gameData.endLevel.exit.nDestroyedModel = cf.ReadInt (); } else gameData.endLevel.exit.nModel = gameData.endLevel.exit.nDestroyedModel = gameData.models.nPolyModels; }
void CObject::Read (CFile& cf) { #if DBG if (OBJ_IDX (this) == nDbgObj) nDbgObj = nDbgObj; #endif info.nType = cf.ReadByte (); info.nId = cf.ReadByte (); info.controlType = cf.ReadByte (); info.movementType = cf.ReadByte (); info.renderType = cf.ReadByte (); info.nFlags = cf.ReadByte (); info.nSegment = cf.ReadShort (); info.nAttachedObj = -1; cf.ReadVector (info.position.vPos); cf.ReadMatrix (info.position.mOrient); info.xSize = cf.ReadFix (); info.xShields = cf.ReadFix (); cf.ReadVector (info.vLastPos); info.contains.nType = cf.ReadByte (); info.contains.nId = cf.ReadByte (); info.contains.nCount = cf.ReadByte (); switch (info.movementType) { case MT_PHYSICS: cf.ReadVector (mType.physInfo.velocity); cf.ReadVector (mType.physInfo.thrust); mType.physInfo.mass = cf.ReadFix (); mType.physInfo.drag = cf.ReadFix (); mType.physInfo.brakes = cf.ReadFix (); cf.ReadVector (mType.physInfo.rotVel); cf.ReadVector (mType.physInfo.rotThrust); mType.physInfo.turnRoll = cf.ReadFixAng (); mType.physInfo.flags = cf.ReadShort (); break; case MT_SPINNING: cf.ReadVector (mType.spinRate); break; case MT_NONE: break; default: Int3(); } int i; switch (info.controlType) { case CT_AI: cType.aiInfo.behavior = cf.ReadByte (); for (i = 0; i < MAX_AI_FLAGS; i++) cType.aiInfo.flags [i] = cf.ReadByte (); cType.aiInfo.nHideSegment = cf.ReadShort (); cType.aiInfo.nHideIndex = cf.ReadShort (); cType.aiInfo.nPathLength = cf.ReadShort (); cType.aiInfo.nCurPathIndex = (char) cf.ReadShort (); if (gameTopFileInfo.fileinfoVersion <= 25) { cf.ReadShort (); // cType.aiInfo.follow_path_start_seg = cf.ReadShort (); // cType.aiInfo.follow_path_end_seg = } break; case CT_EXPLOSION: cType.explInfo.nSpawnTime = cf.ReadFix (); cType.explInfo.nDeleteTime = cf.ReadFix (); cType.explInfo.nDeleteObj = cf.ReadShort (); cType.explInfo.attached.nNext = cType.explInfo.attached.nPrev = cType.explInfo.attached.nParent = -1; break; case CT_WEAPON: //do I really need to read these? Are they even saved to disk? cType.laserInfo.parent.nType = cf.ReadShort (); cType.laserInfo.parent.nObject = cf.ReadShort (); cType.laserInfo.parent.nSignature = cf.ReadInt (); break; case CT_LIGHT: cType.lightInfo.intensity = cf.ReadFix (); break; case CT_POWERUP: if (gameTopFileInfo.fileinfoVersion >= 25) cType.powerupInfo.nCount = cf.ReadInt (); else cType.powerupInfo.nCount = 1; if (info.nId == POW_VULCAN) cType.powerupInfo.nCount = VULCAN_WEAPON_AMMO_AMOUNT; else if (info.nId == POW_GAUSS) cType.powerupInfo.nCount = VULCAN_WEAPON_AMMO_AMOUNT; else if (info.nId == POW_OMEGA) cType.powerupInfo.nCount = MAX_OMEGA_CHARGE; break; case CT_NONE: case CT_FLYING: case CT_DEBRIS: break; case CT_SLEW: //the CPlayerData is generally saved as slew break; case CT_CNTRLCEN: break; case CT_MORPH: case CT_FLYTHROUGH: case CT_REPAIRCEN: default: Int3(); } switch (info.renderType) { case RT_NONE: break; case RT_MORPH: case RT_POLYOBJ: { rType.polyObjInfo.nModel = cf.ReadInt (); for (int i = 0; i <MAX_SUBMODELS; i++) cf.ReadAngVec(rType.polyObjInfo.animAngles [i]); rType.polyObjInfo.nSubObjFlags = cf.ReadInt (); int tmo = cf.ReadInt (); rType.polyObjInfo.nTexOverride = tmo; rType.polyObjInfo.nAltTextures = 0; break; } case RT_WEAPON_VCLIP: case RT_HOSTAGE: case RT_POWERUP: case RT_FIREBALL: rType.vClipInfo.nClipIndex = cf.ReadInt (); rType.vClipInfo.xFrameTime = cf.ReadFix (); rType.vClipInfo.nCurFrame = cf.ReadByte (); break; case RT_THRUSTER: case RT_LASER: break; case RT_SMOKE: rType.particleInfo.nLife = cf.ReadInt (); rType.particleInfo.nSize [0] = cf.ReadInt (); rType.particleInfo.nParts = cf.ReadInt (); rType.particleInfo.nSpeed = cf.ReadInt (); rType.particleInfo.nDrift = cf.ReadInt (); rType.particleInfo.nBrightness = cf.ReadInt (); rType.particleInfo.color.red = cf.ReadByte (); rType.particleInfo.color.green = cf.ReadByte (); rType.particleInfo.color.blue = cf.ReadByte (); rType.particleInfo.color.alpha = cf.ReadByte (); rType.particleInfo.nSide = cf.ReadByte (); if (gameData.segs.nLevelVersion < 18) rType.particleInfo.nType = 0; else rType.particleInfo.nType = cf.ReadByte (); break; case RT_LIGHTNING: rType.lightningInfo.nLife = cf.ReadInt (); rType.lightningInfo.nDelay = cf.ReadInt (); rType.lightningInfo.nLength = cf.ReadInt (); rType.lightningInfo.nAmplitude = cf.ReadInt (); rType.lightningInfo.nOffset = cf.ReadInt (); rType.lightningInfo.nLightnings = cf.ReadShort (); rType.lightningInfo.nId = cf.ReadShort (); rType.lightningInfo.nTarget = cf.ReadShort (); rType.lightningInfo.nNodes = cf.ReadShort (); rType.lightningInfo.nChildren = cf.ReadShort (); rType.lightningInfo.nSteps = cf.ReadShort (); rType.lightningInfo.nAngle = cf.ReadByte (); rType.lightningInfo.nStyle = cf.ReadByte (); rType.lightningInfo.nSmoothe = cf.ReadByte (); rType.lightningInfo.bClamp = cf.ReadByte (); rType.lightningInfo.bPlasma = cf.ReadByte (); rType.lightningInfo.bSound = cf.ReadByte (); rType.lightningInfo.bRandom = cf.ReadByte (); rType.lightningInfo.bInPlane = cf.ReadByte (); rType.lightningInfo.color.red = cf.ReadByte (); rType.lightningInfo.color.green = cf.ReadByte (); rType.lightningInfo.color.blue = cf.ReadByte (); rType.lightningInfo.color.alpha = cf.ReadByte (); break; default: Int3(); } }
void CObject::LoadState (CFile& cf) { info.nSignature = cf.ReadInt (); info.nType = (ubyte) cf.ReadByte (); info.nId = (ubyte) cf.ReadByte (); info.nNextInSeg = cf.ReadShort (); info.nPrevInSeg = cf.ReadShort (); info.controlType = (ubyte) cf.ReadByte (); info.movementType = (ubyte) cf.ReadByte (); info.renderType = (ubyte) cf.ReadByte (); info.nFlags = (ubyte) cf.ReadByte (); info.nSegment = cf.ReadShort (); info.nAttachedObj = cf.ReadShort (); cf.ReadVector (info.position.vPos); cf.ReadMatrix (info.position.mOrient); info.xSize = cf.ReadFix (); info.xShields = cf.ReadFix (); cf.ReadVector (info.vLastPos); info.contains.nType = cf.ReadByte (); info.contains.nId = cf.ReadByte (); info.contains.nCount = cf.ReadByte (); info.nCreator = cf.ReadByte (); info.xLifeLeft = cf.ReadFix (); if (info.movementType == MT_PHYSICS) { cf.ReadVector (mType.physInfo.velocity); cf.ReadVector (mType.physInfo.thrust); mType.physInfo.mass = cf.ReadFix (); mType.physInfo.drag = cf.ReadFix (); mType.physInfo.brakes = cf.ReadFix (); cf.ReadVector (mType.physInfo.rotVel); cf.ReadVector (mType.physInfo.rotThrust); mType.physInfo.turnRoll = cf.ReadFixAng (); mType.physInfo.flags = (ushort) cf.ReadShort (); } else if (info.movementType == MT_SPINNING) { cf.ReadVector (mType.spinRate); } switch (info.controlType) { case CT_WEAPON: cType.laserInfo.parent.nType = cf.ReadShort (); cType.laserInfo.parent.nObject = cf.ReadShort (); cType.laserInfo.parent.nSignature = cf.ReadInt (); cType.laserInfo.xCreationTime = cf.ReadFix (); cType.laserInfo.nLastHitObj = cf.ReadShort (); if (cType.laserInfo.nLastHitObj < 0) cType.laserInfo.nLastHitObj = 0; else { gameData.objs.nHitObjects [Index () * MAX_HIT_OBJECTS] = cType.laserInfo.nLastHitObj; cType.laserInfo.nLastHitObj = 1; } cType.laserInfo.nHomingTarget = cf.ReadShort (); cType.laserInfo.xScale = cf.ReadFix (); break; case CT_EXPLOSION: cType.explInfo.nSpawnTime = cf.ReadFix (); cType.explInfo.nDeleteTime = cf.ReadFix (); cType.explInfo.nDeleteObj = cf.ReadShort (); cType.explInfo.attached.nParent = cf.ReadShort (); cType.explInfo.attached.nPrev = cf.ReadShort (); cType.explInfo.attached.nNext = cf.ReadShort (); break; case CT_AI: cType.aiInfo.behavior = (ubyte) cf.ReadByte (); cf.Read (cType.aiInfo.flags, 1, MAX_AI_FLAGS); cType.aiInfo.nHideSegment = cf.ReadShort (); cType.aiInfo.nHideIndex = cf.ReadShort (); cType.aiInfo.nPathLength = cf.ReadShort (); cType.aiInfo.nCurPathIndex = cf.ReadByte (); cType.aiInfo.bDyingSoundPlaying = cf.ReadByte (); cType.aiInfo.nDangerLaser = cf.ReadShort (); cType.aiInfo.nDangerLaserSig = cf.ReadInt (); cType.aiInfo.xDyingStartTime = cf.ReadFix (); break; case CT_LIGHT: cType.lightInfo.intensity = cf.ReadFix (); break; case CT_POWERUP: cType.powerupInfo.nCount = cf.ReadInt (); cType.powerupInfo.xCreationTime = cf.ReadFix (); cType.powerupInfo.nFlags = cf.ReadInt (); break; } switch (info.renderType) { case RT_MORPH: case RT_POLYOBJ: { int i; rType.polyObjInfo.nModel = cf.ReadInt (); for (i = 0; i < MAX_SUBMODELS; i++) cf.ReadAngVec (rType.polyObjInfo.animAngles [i]); rType.polyObjInfo.nSubObjFlags = cf.ReadInt (); rType.polyObjInfo.nTexOverride = cf.ReadInt (); rType.polyObjInfo.nAltTextures = cf.ReadInt (); break; } case RT_WEAPON_VCLIP: case RT_HOSTAGE: case RT_POWERUP: case RT_FIREBALL: case RT_THRUSTER: rType.vClipInfo.nClipIndex = cf.ReadInt (); rType.vClipInfo.xFrameTime = cf.ReadFix (); rType.vClipInfo.nCurFrame = cf.ReadByte (); break; case RT_LASER: break; } }
void BMReadGameDataD1 (CFile& cf) { int h, i, j, v10DataOffset; #if 1 tD1WallClip w; D1_tmap_info t; //D1Robot_info r; #endif tWallClip *pw; tTexMapInfo *pt; tRobotInfo *pr; CPolyModel model; ubyte tmpSounds [D1_MAX_SOUNDS]; v10DataOffset = cf.ReadInt (); cf.Read (&gameData.pig.tex.nTextures [1], sizeof (int), 1); j = (gameData.pig.tex.nTextures [1] == 70) ? 70 : D1_MAX_TEXTURES; /*---*/PrintLog (" Loading %d texture indices\n", j); //cf.Read (gameData.pig.tex.bmIndex [1], sizeof (tBitmapIndex), D1_MAX_TEXTURES); ReadBitmapIndices (gameData.pig.tex.bmIndex [1], D1_MAX_TEXTURES, cf); BuildTextureIndex (1, D1_MAX_TEXTURES); /*---*/PrintLog (" Loading %d texture descriptions\n", j); for (i = 0, pt = &gameData.pig.tex.tMapInfo [1][0]; i < j; i++, pt++) { #if DBG cf.Read (t.filename, sizeof (t.filename), 1); #else cf.Seek (sizeof (t.filename), SEEK_CUR); #endif pt->flags = (ubyte) cf.ReadByte (); pt->lighting = cf.ReadFix (); pt->damage = cf.ReadFix (); pt->nEffectClip = cf.ReadInt (); pt->slide_u = pt->slide_v = 0; pt->destroyed = -1; } cf.Read (Sounds [1], sizeof (ubyte), D1_MAX_SOUNDS); cf.Read (AltSounds [1], sizeof (ubyte), D1_MAX_SOUNDS); /*---*/PrintLog (" Initializing %d sounds\n", D1_MAX_SOUNDS); if (gameOpts->sound.bUseD1Sounds) { memcpy (Sounds [1] + D1_MAX_SOUNDS, Sounds [0] + D1_MAX_SOUNDS, MAX_SOUNDS - D1_MAX_SOUNDS); memcpy (AltSounds [1] + D1_MAX_SOUNDS, AltSounds [0] + D1_MAX_SOUNDS, MAX_SOUNDS - D1_MAX_SOUNDS); } else { memcpy (Sounds [1], Sounds [0], MAX_SOUNDS); memcpy (AltSounds [1], AltSounds [0], MAX_SOUNDS); } for (i = 0; i < D1_MAX_SOUNDS; i++) { if (Sounds [1][i] == 255) Sounds [1][i] = Sounds [0][i]; if (AltSounds [1][i] == 255) AltSounds [1][i] = AltSounds [0][i]; } gameData.eff.nClips [1] = cf.ReadInt (); /*---*/PrintLog (" Loading %d animation clips\n", gameData.eff.nClips [1]); ReadVideoClips (gameData.eff.vClips [1], D1_VCLIP_MAXNUM, cf); gameData.eff.nEffects [1] = cf.ReadInt (); /*---*/PrintLog (" Loading %d animation descriptions\n", gameData.eff.nClips [1]); ReadEffectClips (gameData.eff.effects [1], D1_MAX_EFFECTS, cf); gameData.walls.nAnims [1] = cf.ReadInt (); /*---*/PrintLog (" Loading %d CWall animations\n", gameData.walls.nAnims [1]); for (i = 0, pw = &gameData.walls.anims [1][0]; i < D1_MAX_WALL_ANIMS; i++, pw++) { //cf.Read (&w, sizeof (w), 1); pw->xTotalTime = cf.ReadFix (); pw->nFrameCount = cf.ReadShort (); for (j = 0; j < D1_MAX_CLIP_FRAMES; j++) pw->frames [j] = cf.ReadShort (); pw->openSound = cf.ReadShort (); pw->closeSound = cf.ReadShort (); pw->flags = cf.ReadShort (); cf.Read (pw->filename, sizeof (w.filename), 1); pw->pad = (char) cf.ReadByte (); } cf.Read (&gameData.bots.nTypes [1], sizeof (int), 1); /*---*/PrintLog (" Loading %d robot descriptions\n", gameData.bots.nTypes [1]); gameData.bots.info [1] = gameData.bots.info [0]; if (!gameOpts->sound.bUseD1Sounds) return; for (i = 0, pr = &gameData.bots.info [1][0]; i < D1_MAX_ROBOT_TYPES; i++, pr++) { //cf.Read (&r, sizeof (r), 1); cf.Seek ( sizeof (int) * 3 + (sizeof (CFixVector) + sizeof (ubyte)) * MAX_GUNS + sizeof (short) * 5 + sizeof (sbyte) * 7 + sizeof (fix) * 4 + sizeof (fix) * 7 * NDL + sizeof (sbyte) * 2 * NDL, SEEK_CUR); pr->seeSound = (ubyte) cf.ReadByte (); pr->attackSound = (ubyte) cf.ReadByte (); pr->clawSound = (ubyte) cf.ReadByte (); cf.Seek ( JOINTLIST_SIZE * (MAX_GUNS + 1) * N_ANIM_STATES + sizeof (int), SEEK_CUR); pr->always_0xabcd = 0xabcd; } cf.Seek ( sizeof (int) + JOINTPOS_SIZE * D1_MAX_ROBOT_JOINTS + sizeof (int) + D1_WEAPON_INFO_SIZE * D1_MAX_WEAPON_TYPES + sizeof (int) + POWERUP_TYPE_INFO_SIZE * MAX_POWERUP_TYPES_D1, SEEK_CUR); i = cf.ReadInt (); /*---*/PrintLog (" Acquiring model data size of %d polymodels\n", i); for (h = 0; i; i--) { cf.Seek (MODEL_DATA_SIZE_OFFS, SEEK_CUR); model.SetDataSize (cf.ReadInt ()); h += model.DataSize (); cf.Seek (POLYMODEL_SIZE - MODEL_DATA_SIZE_OFFS - sizeof (int), SEEK_CUR); } cf.Seek ( h + sizeof (tBitmapIndex) * D1_MAX_GAUGE_BMS + sizeof (int) * 2 * D1_MAX_POLYGON_MODELS + sizeof (tBitmapIndex) * D1_MAX_OBJ_BITMAPS + sizeof (ushort) * D1_MAX_OBJ_BITMAPS + PLAYER_SHIP_SIZE + sizeof (int) + sizeof (tBitmapIndex) * D1_N_COCKPIT_BITMAPS, SEEK_CUR); /*---*/PrintLog (" Loading sound data\n", i); cf.Read (tmpSounds, sizeof (ubyte), D1_MAX_SOUNDS); //for (i = 0, pr = &gameData.bots.info [1][0]; i < gameData.bots.nTypes [1]; i++, pr++) pr = gameData.bots.info [1] + 17; /*---*/PrintLog (" Initializing sound data\n", i); for (i = 0; i < D1_MAX_SOUNDS; i++) { if (Sounds [1][i] == tmpSounds [pr->seeSound]) pr->seeSound = i; if (Sounds [1][i] == tmpSounds [pr->attackSound]) pr->attackSound = i; if (Sounds [1][i] == tmpSounds [pr->clawSound]) pr->clawSound = i; } pr = gameData.bots.info [1] + 23; for (i = 0; i < D1_MAX_SOUNDS; i++) { if (Sounds [1][i] == tmpSounds [pr->seeSound]) pr->seeSound = i; if (Sounds [1][i] == tmpSounds [pr->attackSound]) pr->attackSound = i; if (Sounds [1][i] == tmpSounds [pr->clawSound]) pr->clawSound = i; } cf.Read (tmpSounds, sizeof (ubyte), D1_MAX_SOUNDS); // for (i = 0, pr = &gameData.bots.info [1][0]; i < gameData.bots.nTypes [1]; i++, pr++) { pr = gameData.bots.info [1] + 17; for (i = 0; i < D1_MAX_SOUNDS; i++) { if (AltSounds [1][i] == tmpSounds [pr->seeSound]) pr->seeSound = i; if (AltSounds [1][i] == tmpSounds [pr->attackSound]) pr->attackSound = i; if (AltSounds [1][i] == tmpSounds [pr->clawSound]) pr->clawSound = i; } pr = gameData.bots.info [1] + 23; for (i = 0; i < D1_MAX_SOUNDS; i++) { if (AltSounds [1][i] == tmpSounds [pr->seeSound]) pr->seeSound = i; if (AltSounds [1][i] == tmpSounds [pr->attackSound]) pr->attackSound = i; if (AltSounds [1][i] == tmpSounds [pr->clawSound]) pr->clawSound = i; } #if 0 cf.Seek (v10DataOffset, SEEK_SET); i = cf.ReadInt (); j = cf.ReadInt (); cf.Seek (i * sizeof (tD1TextureHeader), SEEK_CUR); gameStates.app.bD1Mission = 1; for (i = 0; i < j; i++) { cf.Read (&gameData.pig.sound.sounds [1][i].szName, sizeof (gameData.pig.sound.sounds [1][i].szName), 1); cf.Seek (sizeof (tD1SoundHeader) - sizeof (gameData.pig.sound.sounds [1][i].szName), SEEK_CUR); } #endif }
/* * reads n tRobotInfo structs from a CFile */ int ReadRobotInfos (CArray<tRobotInfo>& botInfo, int n, CFile& cf, int o) { int h, i, j; for (i = 0; i < n; i++) { h = i + o; botInfo [h].nModel = cf.ReadInt (); for (j = 0; j < MAX_GUNS; j++) cf.ReadVector (botInfo [h].gunPoints [j]); cf.Read (botInfo [h].gunSubModels, MAX_GUNS, 1); botInfo [h].nExp1VClip = cf.ReadShort (); botInfo [h].nExp1Sound = cf.ReadShort (); botInfo [h].nExp2VClip = cf.ReadShort (); botInfo [h].nExp2Sound = cf.ReadShort (); botInfo [h].nWeaponType = cf.ReadByte (); botInfo [h].nSecWeaponType = cf.ReadByte (); botInfo [h].nGuns = cf.ReadByte (); botInfo [h].containsId = cf.ReadByte (); botInfo [h].containsCount = cf.ReadByte (); botInfo [h].containsProb = cf.ReadByte (); botInfo [h].containsType = cf.ReadByte (); botInfo [h].kamikaze = cf.ReadByte (); botInfo [h].scoreValue = cf.ReadShort (); botInfo [h].badass = cf.ReadByte (); botInfo [h].energyDrain = cf.ReadByte (); botInfo [h].lighting = cf.ReadFix (); botInfo [h].strength = cf.ReadFix (); botInfo [h].mass = cf.ReadFix (); botInfo [h].drag = cf.ReadFix (); for (j = 0; j < NDL; j++) botInfo [h].fieldOfView [j] = cf.ReadFix (); for (j = 0; j < NDL; j++) botInfo [h].primaryFiringWait [j] = cf.ReadFix (); for (j = 0; j < NDL; j++) botInfo [h].secondaryFiringWait [j] = cf.ReadFix (); for (j = 0; j < NDL; j++) botInfo [h].turnTime [j] = cf.ReadFix (); for (j = 0; j < NDL; j++) botInfo [h].xMaxSpeed [j] = cf.ReadFix (); for (j = 0; j < NDL; j++) botInfo [h].circleDistance [j] = cf.ReadFix (); cf.Read (botInfo [h].nRapidFireCount, NDL, 1); cf.Read (botInfo [h].evadeSpeed, NDL, 1); botInfo [h].cloakType = cf.ReadByte (); botInfo [h].attackType = cf.ReadByte (); botInfo [h].seeSound = cf.ReadByte (); botInfo [h].attackSound = cf.ReadByte (); botInfo [h].clawSound = cf.ReadByte (); botInfo [h].tauntSound = cf.ReadByte (); botInfo [h].bossFlag = cf.ReadByte (); botInfo [h].companion = cf.ReadByte (); botInfo [h].smartBlobs = cf.ReadByte (); botInfo [h].energyBlobs = cf.ReadByte (); botInfo [h].thief = cf.ReadByte (); botInfo [h].pursuit = cf.ReadByte (); botInfo [h].lightcast = cf.ReadByte (); botInfo [h].bDeathRoll = cf.ReadByte (); botInfo [h].flags = cf.ReadByte (); cf.Read(botInfo [h].pad, 3, 1); botInfo [h].deathrollSound = cf.ReadByte (); botInfo [h].glow = cf.ReadByte (); botInfo [h].behavior = cf.ReadByte (); botInfo [h].aim = cf.ReadByte (); for (j = 0; j < MAX_GUNS + 1; j++) ReadJointLists (botInfo [h].animStates [j], N_ANIM_STATES, cf); botInfo [h].always_0xabcd = cf.ReadInt (); } return i; }
static int ReadTriggerInfo (CFile& cf) { int h, i, j; CTrigger *trigP; if (gameFileInfo.triggers.count && (gameFileInfo.triggers.offset > -1)) { #if TRACE console.printf(CON_DBG, " loading CTrigger data ...\n"); #endif if (!gameData.trigs.Create (gameFileInfo.triggers.count, false)) { Error ("Not enough memory for trigger data"); return -1; } if (cf.Seek (gameFileInfo.triggers.offset, SEEK_SET)) { Error ("Error seeking to trigger data\n(file damaged or invalid)"); return -1; } for (i = 0, trigP = TRIGGERS.Buffer (); i < gameFileInfo.triggers.count; i++, trigP++) { trigP->m_info.flagsD1 = 0; if (gameTopFileInfo.fileinfoVersion >= 31) trigP->Read (cf, 0); else { tTriggerV30 trig; int t, nType = 0, flags = 0; if (gameTopFileInfo.fileinfoVersion == 30) V30TriggerRead (trig, cf); else { tTriggerV29 trig29; V29TriggerRead (trig29, cf); trigP->m_info.flagsD1 = trig.flags = trig29.flags; trig.nLinks = (char) trig29.nLinks; trig.value = trig29.value; trig.time = trig29.time; for (t = 0; t < trig.nLinks; t++) { trig.segments [t] = trig29.segments [t]; trig.sides [t] = trig29.sides [t]; } } #if 1 if (gameStates.app.bD1Mission) nType = TT_DESCENT1; #else //Assert(trig.flags & TRIGGER_ON); trig.flags &= ~TRIGGER_ON; if (trig.flags & TRIGGER_CONTROL_DOORS) nType = TT_OPEN_DOOR; else if (trig.flags & TRIGGER_SHIELD_DAMAGE) nType = TT_SHIELD_DAMAGE; else if (trig.flags & TRIGGER_ENERGY_DRAIN) nType = TT_ENERGY_DRAIN; else if (trig.flags & TRIGGER_EXIT) nType = TT_EXIT; else if (trig.flags & TRIGGER_MATCEN) nType = TT_MATCEN; else if (trig.flags & TRIGGER_ILLUSION_OFF) nType = TT_ILLUSION_OFF; else if (trig.flags & TRIGGER_SECRET_EXIT) nType = TT_SECRET_EXIT; else if (trig.flags & TRIGGER_ILLUSION_ON) nType = TT_ILLUSION_ON; #endif else if (trig.flags & TRIGGER_UNLOCK_DOORS) nType = TT_UNLOCK_DOOR; else if (trig.flags & TRIGGER_OPEN_WALL) nType = TT_OPEN_WALL; else if (trig.flags & TRIGGER_CLOSE_WALL) nType = TT_CLOSE_WALL; else if (trig.flags & TRIGGER_ILLUSORY_WALL) nType = TT_ILLUSORY_WALL; else Int3(); if (trig.flags & TRIGGER_ONE_SHOT) flags = TF_ONE_SHOT; trigP->m_info.nType = nType; trigP->m_info.flags = flags; trigP->m_info.nLinks = trig.nLinks; trigP->m_info.nLinks = trig.nLinks; trigP->m_info.value = trig.value; trigP->m_info.time = trig.time; for (t = 0; t < trig.nLinks; t++) { trigP->m_info.segments [t] = trig.segments [t]; trigP->m_info.sides [t] = trig.sides [t]; } } if (trigP->m_info.nLinks < 0) trigP->m_info.nLinks = 0; else if (trigP->m_info.nLinks > MAX_TRIGGER_TARGETS) trigP->m_info.nLinks = MAX_TRIGGER_TARGETS; for (h = trigP->m_info.nLinks, j = 0; j < h; ) { if ((trigP->m_info.segments [j] >= 0) && (trigP->m_info.segments [j] < gameData.segs.nSegments) && (trigP->m_info.sides [j] >= 0) && (trigP->m_info.sides [j] < 6)) j++; else if (--h) { trigP->m_info.segments [j] = trigP->m_info.segments [h]; trigP->m_info.sides [j] = trigP->m_info.sides [h]; } } trigP->m_info.nLinks = h; } } if (gameTopFileInfo.fileinfoVersion >= 33) { gameData.trigs.m_nObjTriggers = cf.ReadInt (); if (gameData.trigs.m_nObjTriggers) { if (!gameData.trigs.Create (gameData.trigs.m_nObjTriggers, true)) { Error ("Not enough memory for object trigger data"); return -1; } for (i = 0; i < gameData.trigs.m_nObjTriggers; i++) OBJTRIGGERS [i].Read (cf, 1); for (i = 0; i < gameData.trigs.m_nObjTriggers; i++) { gameData.trigs.objTriggerRefs [i].prev = cf.ReadShort (); gameData.trigs.objTriggerRefs [i].next = cf.ReadShort (); gameData.trigs.objTriggerRefs [i].nObject = cf.ReadShort (); } } if (gameTopFileInfo.fileinfoVersion < 36) { if (!gameData.trigs.firstObjTrigger.Create (700)) { Error ("Not enough memory for object trigger data"); return -1; } for (i = 0; i < 700; i++) gameData.trigs.firstObjTrigger [i] = cf.ReadShort (); } else { gameData.trigs.firstObjTrigger.Clear (0xff); if (!gameData.trigs.firstObjTrigger.Create (LEVEL_OBJECTS)) { Error ("Not enough memory for object trigger data"); return -1; } for (i = cf.ReadShort (); i; i--) { j = cf.ReadShort (); gameData.trigs.firstObjTrigger [j] = cf.ReadShort (); } } } else { gameData.trigs.m_nObjTriggers = 0; OBJTRIGGERS.Clear (); gameData.trigs.objTriggerRefs.Clear (0xff); gameData.trigs.firstObjTrigger.Clear (0xff); } return 0; }
// ---------------------------------------------------------------------------- //loads a level (.LVL) file from disk //returns 0 if success, else error code int LoadLevelData (char * pszFilename, int nLevel) { CFile cf; char filename [128]; int sig, nMineDataOffset, nGameDataOffset; int nError; SetDataVersion (-1); gameData.segs.bHaveSlideSegs = 0; if (gameData.app.nGameMode & GM_NETWORK) { gameData.multiplayer.maxPowerupsAllowed.Clear (0); gameData.multiplayer.powerupsInMine.Clear (0); } #if DBG Level_being_loaded = pszFilename; #endif gameStates.render.nMeshQuality = gameOpts->render.nMeshQuality; for (;;) { strcpy (filename, pszFilename); if (!cf.Open (filename, "", "rb", gameStates.app.bD1Mission)) return 1; strcpy(gameData.segs.szLevelFilename, filename); // #ifdef NEWDEMO // if (gameData.demo.nState == ND_STATE_RECORDING) // NDRecordStartDemo(); // #endif sig = cf.ReadInt (); gameData.segs.nLevelVersion = cf.ReadInt (); gameStates.app.bD2XLevel = (gameData.segs.nLevelVersion >= 10); #if TRACE console.printf (CON_DBG, "gameData.segs.nLevelVersion = %d\n", gameData.segs.nLevelVersion); #endif nMineDataOffset = cf.ReadInt (); nGameDataOffset = cf.ReadInt (); Assert(sig == MAKE_SIG('P','L','V','L')); if (gameData.segs.nLevelVersion >= 8) { //read dummy data cf.ReadInt (); cf.ReadShort (); cf.ReadByte (); } if (gameData.segs.nLevelVersion < 5) cf.ReadInt (); //was hostagetext_offset if (gameData.segs.nLevelVersion > 1) { cf.GetS (szCurrentLevelPalette, sizeof (szCurrentLevelPalette)); if (szCurrentLevelPalette [strlen(szCurrentLevelPalette) - 1] == '\n') szCurrentLevelPalette [strlen(szCurrentLevelPalette) - 1] = 0; } if ((gameData.segs.nLevelVersion <= 1) || (szCurrentLevelPalette [0] == 0)) // descent 1 level strcpy (szCurrentLevelPalette, DEFAULT_LEVEL_PALETTE); //D1_PALETTE if (gameData.segs.nLevelVersion >= 3) gameStates.app.nBaseCtrlCenExplTime = cf.ReadInt (); else gameStates.app.nBaseCtrlCenExplTime = DEFAULT_CONTROL_CENTER_EXPLOSION_TIME; if (gameData.segs.nLevelVersion >= 4) gameData.reactor.nStrength = cf.ReadInt (); else gameData.reactor.nStrength = -1; //use old defaults if (gameData.segs.nLevelVersion >= 7) { #if TRACE console.printf (CON_DBG, " loading dynamic lights ...\n"); #endif if (0 > ReadVariableLights (cf)) { cf.Close (); return 5; } } if (gameData.segs.nLevelVersion < 6) { gameData.segs.secret.nReturnSegment = 0; gameData.segs.secret.returnOrient = CFixMatrix::IDENTITY; } else { gameData.segs.secret.nReturnSegment = cf.ReadInt (); for (int i = 0; i < 9; i++) gameData.segs.secret.returnOrient [i] = cf.ReadInt (); } //NOTE LINK TO ABOVE!! cf.Seek (nGameDataOffset, SEEK_SET); nError = LoadMineDataCompiled (cf, 1); cf.Seek (nMineDataOffset, SEEK_SET); nError = LoadMineSegmentsCompiled (cf); if (nError == -1) { //error!! cf.Close (); return 2; } cf.Seek (nGameDataOffset, SEEK_SET); gameData.objs.lists.Init (); nError = LoadMineDataCompiled (cf, 0); if (nError == -1) { //error!! cf.Close (); return 3; } cf.Close (); networkData.nSegmentCheckSum = CalcSegmentCheckSum (); if (meshBuilder.Build (nLevel)) break; if (gameStates.render.nMeshQuality <= 0) return 6; gameStates.render.nMeshQuality--; } gameStates.render.nMeshQuality = gameOpts->render.nMeshQuality; #if 0 if (!(gameData.render.lights.Create () && gameData.render.color.Create () && gameData.render.shadows.Create ())) return 7; #endif if (!gameData.render.mine.Create ()) return 4; lightManager.Setup (nLevel); //moved to loadgame.cpp::LoadLevel() SetAmbientSoundFlags (); return 0; }
void LoadReplacementBitmaps (const char *pszLevelName) { char szFilename [SHORT_FILENAME_LEN]; CFile cf; int i, j; CBitmap bm; //first, free up data allocated for old bitmaps PrintLog (" loading replacement textures\n"); CFile::ChangeFilenameExtension (szFilename, pszLevelName, ".pog"); if (cf.Open (szFilename, gameFolders.szDataDir, "rb", 0)) { int id, version, nBitmapNum, bTGA; int bmDataSize, bmDataOffset, bmOffset; ushort *indices; tPIGBitmapHeader *bmh; id = cf.ReadInt (); version = cf.ReadInt (); if (id != MAKE_SIG ('G','O','P','D') || version != 1) { cf.Close (); return; } nBitmapNum = cf.ReadInt (); indices = new ushort [nBitmapNum]; bmh = new tPIGBitmapHeader [nBitmapNum]; #if 0 cf.Read (indices, nBitmapNum * sizeof (ushort), 1); cf.Read (bmh, nBitmapNum * sizeof (tPIGBitmapHeader), 1); #else for (i = 0; i < nBitmapNum; i++) indices [i] = cf.ReadShort (); for (i = 0; i < nBitmapNum; i++) PIGBitmapHeaderRead (bmh + i, cf); #endif bmDataOffset = cf.Tell (); bmDataSize = cf.Length () - bmDataOffset; for (i = 0; i < nBitmapNum; i++) { bmOffset = bmh [i].offset; memset (&bm, 0, sizeof (CBitmap)); bm.AddFlags (bmh [i].flags & (BM_FLAGS_TO_COPY | BM_FLAG_TGA)); bm.SetWidth (bmh [i].width + ((short) (bmh [i].wh_extra & 0x0f) << 8)); bm.SetRowSize (bm.Width ()); if ((bTGA = (bm.Flags () & BM_FLAG_TGA)) && (bm.Width () > 256)) bm.SetHeight (bm.Width () * bmh [i].height); else bm.SetHeight (bmh [i].height + ((short) (bmh [i].wh_extra & 0xf0) << 4)); bm.SetBPP (bTGA ? 4 : 1); if (!(bm.Width () * bm.Width ())) continue; bm.SetAvgColorIndex (bmh [i].avgColor); bm.SetType (BM_TYPE_ALT); if (!bm.CreateBuffer ()) break; cf.Seek (bmDataOffset + bmOffset, SEEK_SET); #if DBG if (indices [i] == nDbgTexture) nDbgTexture = nDbgTexture; #endif if (bTGA) { int nFrames = bm.Height () / bm.Width (); tTgaHeader h; h.width = bm.Width (); h.height = bm.Width (); h.bits = 32; if (!ReadTGAImage (cf, &h, &bm, -1, 1.0, 0, 1)) { bm.DestroyBuffer (); break; } bm.SetFrameCount ((ubyte) nFrames); if (nFrames > 1) { tEffectClip *ecP = NULL; tWallClip *wcP; tVideoClip *vcP; while ((ecP = FindEffect (ecP, indices [i]))) { //e->vc.nFrameCount = nFrames; ecP->flags |= EF_ALTFMT | EF_FROMPOG; } if (!ecP) { if ((wcP = FindWallAnim (indices [i]))) { //w->nFrameCount = nFrames; wcP->flags |= WCF_ALTFMT | WCF_FROMPOG; } else if ((vcP = FindVClip (i))) { //v->nFrameCount = nFrames; vcP->flags |= WCF_ALTFMT | WCF_FROMPOG; } } } j = indices [i]; bm.SetId (j); } else { #if DBG if (j == nDbgTexture) nDbgTexture = nDbgTexture; #endif ReadBitmap (&bm, int (bm.Width ()) * int (bm.Height ()), &cf, true, false); j = indices [i]; bm.SetId (j); bm.RLEExpand (NULL, 0); *bm.Props () = *gameData.pig.tex.bitmapP [j].Props (); bm.Remap (paletteManager.Game (), TRANSPARENCY_COLOR, SUPER_TRANSP_COLOR); } #if DBG if (j == nDbgTexture) nDbgTexture = nDbgTexture; #endif gameData.pig.tex.bitmapP [j].Unload (j, 0); bm.SetFromPog (1); char szName [20]; if (*gameData.pig.tex.bitmapP [j].Name ()) sprintf (szName, "[%s]", gameData.pig.tex.bitmapP [j].Name ()); else sprintf (szName, "POG#%04d", j); bm.SetName (szName); gameData.pig.tex.altBitmapP [j] = bm; gameData.pig.tex.altBitmapP [j].SetBuffer (bm.Buffer (), 0, bm.Length ()); bm.SetBuffer (NULL); gameData.pig.tex.bitmapP [j].SetOverride (gameData.pig.tex.altBitmapP + j); CBitmap* bmP = gameData.pig.tex.altBitmapP + j; tRgbColorf color; if (0 <= bmP->AvgColor (&color)) bmP->SetAvgColorIndex (bmP->Palette ()->ClosestColor (&color)); UseBitmapCache (gameData.pig.tex.altBitmapP + j, (int) bm.Width () * (int) bm.RowSize ()); } delete[] indices; delete[] bmh; cf.Close (); paletteManager.SetLastPig (""); TexMergeFlush (); //for re-merging with new textures } }
/* * reads a tBitmapIndex structure from a CFile */ void BitmapIndexRead (tBitmapIndex *bi, CFile& cf) { bi->index = cf.ReadShort (); }