- Blood: Savegame fully transitioned to JSON

not tested yet.
This commit is contained in:
Christoph Oelckers 2020-11-22 16:47:08 +01:00
parent 572d3c9944
commit 9a4073508d
29 changed files with 763 additions and 912 deletions

View file

@ -46,7 +46,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "gib.h" #include "gib.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "player.h" #include "player.h"
#include "seq.h" #include "seq.h"
#include "sound.h" #include "sound.h"

View file

@ -41,7 +41,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "gib.h" #include "gib.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "player.h" #include "player.h"
#include "seq.h" #include "seq.h"
#include "sound.h" #include "sound.h"
@ -1773,56 +1772,13 @@ FSerializer& Serialize(FSerializer& arc, const char* keyname, DUDEEXTRA& w, DUDE
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
FSerializer& Serialize(FSerializer& arc, const char* keyname, GENDUDEEXTRA& w, GENDUDEEXTRA* def)
{
if (arc.BeginObject(keyname))
{
arc.Array("initvals", w.initVals, 3)
.Array("availdeaths", w.availDeaths, kDamageMax)
("movespeed", w.moveSpeed)
("firedist", w.fireDist)
("throwdist", w.throwDist)
("curweapon", w.curWeapon)
("weapontype", w.weaponType)
("basedispersion", w.baseDispersion)
("slavecount", w.slaveCount)
("lifeleech", w.nLifeLeech)
.Array("slaves", w.slave, w.slaveCount)
.Array("dmgcontrol", w.dmgControl, kDamageMax)
.Array("updreq", w.updReq, kGenDudePropertyMax)
("flags", w.flags)
.EndObject();
}
return arc;
}
//---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
void SerializeAI(FSerializer& arc) void SerializeAI(FSerializer& arc)
{ {
if (arc.BeginObject("ai")) if (arc.BeginObject("ai"))
{ {
arc.SparseArray("dudeslope", gDudeSlope, kMaxSprites, activeXSprites) arc.SparseArray("dudeslope", gDudeSlope, kMaxSprites, activeXSprites)
.SparseArray("dudeextra", gDudeExtra, kMaxSprites, activeXSprites); .SparseArray("dudeextra", gDudeExtra, kMaxSprites, activeXSprites)
.EndObject();
// the GenDudeArray only contains valid info for kDudeModernCustom and kDudeModernCustomBurning so only save the relevant entries as these are not small.
bool foundsome = false;
for (int i = 0; i < kMaxSprites; i++)
{
if (activeSprites[i] && (sprite[i].type == kDudeModernCustom || sprite[i].type == kDudeModernCustomBurning))
{
if (!foundsome) arc.BeginArray("gendudeextra");
foundsome = true;
arc(nullptr, gGenDudeExtra[i]);
}
}
if (foundsome) arc.EndArray();
arc.EndObject();
} }
} }

View file

@ -33,7 +33,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "endgame.h" #include "endgame.h"
#include "aistate.h" #include "aistate.h"
#include "loadsave.h"
#include "sectorfx.h" #include "sectorfx.h"
#include "choke.h" #include "choke.h"
#include "view.h" #include "view.h"

View file

@ -31,7 +31,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "db.h" #include "db.h"
#include "player.h" #include "player.h"
#include "sound.h" #include "sound.h"
#include "loadsave.h"
#include "raze_sound.h" #include "raze_sound.h"
BEGIN_BLD_NS BEGIN_BLD_NS

View file

@ -40,7 +40,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "gib.h" #include "gib.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "sectorfx.h" #include "sectorfx.h"
#include "seq.h" #include "seq.h"
#include "sound.h" #include "sound.h"
@ -502,7 +501,6 @@ void GameInterface::app_init()
FireInit(); FireInit();
Printf(PRINT_NONOTIFY, "Initializing weapon animations\n"); Printf(PRINT_NONOTIFY, "Initializing weapon animations\n");
WeaponInit(); WeaponInit();
LoadSaveSetup();
myconnectindex = connecthead = 0; myconnectindex = connecthead = 0;
gNetPlayers = numplayers = 1; gNetPlayers = numplayers = 1;

View file

@ -82,8 +82,6 @@ struct GameInterface : ::GameInterface
void MenuClosed() override; void MenuClosed() override;
bool CanSave() override; bool CanSave() override;
bool StartGame(FNewGameStartup& gs) override; bool StartGame(FNewGameStartup& gs) override;
bool SaveGame() override;
bool LoadGame() override;
void QuitToTitle() override; void QuitToTitle() override;
FString GetCoordString() override; FString GetCoordString() override;
ReservedSpace GetReservedScreenSpace(int viewsize) override; ReservedSpace GetReservedScreenSpace(int viewsize) override;

View file

@ -463,13 +463,8 @@ struct LOCATION {
int ang; int ang;
}; };
struct POINT2D { using POINT2D = vec2_t;
int x, y; using POINT3D = vec3_t;
};
struct POINT3D {
int x, y, z;
};
struct VECTOR2D { struct VECTOR2D {
int dx, dy; int dx, dy;

View file

@ -47,6 +47,9 @@ XSPRITE xsprite[kMaxXSprites];
XSECTOR xsector[kMaxXSectors]; XSECTOR xsector[kMaxXSectors];
XWALL xwall[kMaxXWalls]; XWALL xwall[kMaxXWalls];
XSECTOR xsectorbackup[kMaxXSectors];
XWALL xwallbackup[kMaxXWalls];
SPRITEHIT gSpriteHit[kMaxXSprites]; SPRITEHIT gSpriteHit[kMaxXSprites];
int xvel[kMaxSprites], yvel[kMaxSprites], zvel[kMaxSprites]; int xvel[kMaxSprites], yvel[kMaxSprites], zvel[kMaxSprites];
@ -274,6 +277,20 @@ void InitFreeList(unsigned short *pList, int nCount)
pList[0] = nCount - 1; pList[0] = nCount - 1;
} }
void InitFreeList(unsigned short* pList, int nCount, FixedBitArray<MAXSPRITES>&used)
{
int lastfree = 0;
for (int i = 1; i < nCount; i++)
{
if (!used[i])
{
pList[i] = lastfree;
lastfree = i;
}
}
pList[0] = lastfree;
}
void InsertFree(unsigned short *pList, int nIndex) void InsertFree(unsigned short *pList, int nIndex)
{ {
pList[nIndex] = pList[0]; pList[nIndex] = pList[0];
@ -391,14 +408,13 @@ void PropagateMarkerReferences(void)
} }
} }
bool byte_1A76C6, byte_1A76C7, byte_1A76C8; bool drawtile2048, encrypted;
MAPHEADER2 byte_19AE44; MAPHEADER2 byte_19AE44;
unsigned int dbReadMapCRC(const char *pPath) unsigned int dbReadMapCRC(const char *pPath)
{ {
byte_1A76C7 = 0; encrypted = 0;
byte_1A76C8 = 0;
FString mapname = pPath; FString mapname = pPath;
DefaultExtension(mapname, ".map"); DefaultExtension(mapname, ".map");
@ -422,7 +438,7 @@ unsigned int dbReadMapCRC(const char *pPath)
} }
else if ((ver & 0xff00) == 0x700) else if ((ver & 0xff00) == 0x700)
{ {
byte_1A76C8 = 1; encrypted = 1;
} }
else else
{ {
@ -432,7 +448,7 @@ unsigned int dbReadMapCRC(const char *pPath)
return fr.ReadInt32(); return fr.ReadInt32();
} }
int gMapRev, gSongId, gSkyCount; int gMapRev, gMattId, gSkyCount;
//char byte_19AE44[128]; //char byte_19AE44[128];
const int nXSectorSize = 60; const int nXSectorSize = 60;
const int nXSpriteSize = 56; const int nXSpriteSize = 56;
@ -517,9 +533,9 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
{ {
I_Error("%s: Map file corrupted", mapname.GetChars()); I_Error("%s: Map file corrupted", mapname.GetChars());
} }
byte_1A76C8 = 0; encrypted = 0;
if ((LittleShort(header.version) & 0xff00) == 0x700) { if ((LittleShort(header.version) & 0xff00) == 0x700) {
byte_1A76C8 = 1; encrypted = 1;
#ifdef NOONE_EXTENSIONS #ifdef NOONE_EXTENSIONS
// indicate if the map requires modern features to work properly // indicate if the map requires modern features to work properly
@ -536,7 +552,6 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
fr.Read(&mapHeader,37/* sizeof(mapHeader)*/); fr.Read(&mapHeader,37/* sizeof(mapHeader)*/);
if (mapHeader.mattid != 0 && mapHeader.mattid != 0x7474614d && mapHeader.mattid != 0x4d617474) { if (mapHeader.mattid != 0 && mapHeader.mattid != 0x7474614d && mapHeader.mattid != 0x4d617474) {
dbCrypt((char*)&mapHeader, sizeof(mapHeader), 0x7474614d); dbCrypt((char*)&mapHeader, sizeof(mapHeader), 0x7474614d);
byte_1A76C7 = 1;
} }
mapHeader.x = LittleLong(mapHeader.x); mapHeader.x = LittleLong(mapHeader.x);
@ -558,16 +573,16 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
*pAngle = mapHeader.ang; *pAngle = mapHeader.ang;
*pSector = mapHeader.sect; *pSector = mapHeader.sect;
gVisibility = g_visibility = mapHeader.visibility; gVisibility = g_visibility = mapHeader.visibility;
gSongId = mapHeader.mattid; gMattId = mapHeader.mattid;
if (byte_1A76C8) if (encrypted)
{ {
if (mapHeader.mattid == 0x7474614d || mapHeader.mattid == 0x4d617474) if (mapHeader.mattid == 0x7474614d || mapHeader.mattid == 0x4d617474)
{ {
byte_1A76C6 = 1; drawtile2048 = 1;
} }
else if (!mapHeader.mattid) else if (!mapHeader.mattid)
{ {
byte_1A76C6 = 0; drawtile2048 = 0;
} }
else else
{ {
@ -583,7 +598,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
numsectors = mapHeader.numsectors; numsectors = mapHeader.numsectors;
numwalls = mapHeader.numwalls; numwalls = mapHeader.numwalls;
dbInit(); dbInit();
if (byte_1A76C8) if (encrypted)
{ {
fr.Read(&byte_19AE44, 128); fr.Read(&byte_19AE44, 128);
dbCrypt((char*)&byte_19AE44, 128, numwalls); dbCrypt((char*)&byte_19AE44, 128, numwalls);
@ -598,7 +613,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
} }
gSkyCount = 1<< mapHeader.pskybits; gSkyCount = 1<< mapHeader.pskybits;
fr.Read(tpskyoff, gSkyCount*sizeof(tpskyoff[0])); fr.Read(tpskyoff, gSkyCount*sizeof(tpskyoff[0]));
if (byte_1A76C8) if (encrypted)
{ {
dbCrypt((char*)tpskyoff, gSkyCount*sizeof(tpskyoff[0]), gSkyCount*2); dbCrypt((char*)tpskyoff, gSkyCount*sizeof(tpskyoff[0]), gSkyCount*2);
} }
@ -616,7 +631,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
sectortype *pSector = &sector[i]; sectortype *pSector = &sector[i];
sectortypedisk load; sectortypedisk load;
fr.Read(&load, sizeof(sectortypedisk)); fr.Read(&load, sizeof(sectortypedisk));
if (byte_1A76C8) if (encrypted)
{ {
dbCrypt((char*)&load, sizeof(sectortypedisk), gMapRev*sizeof(sectortypedisk)); dbCrypt((char*)&load, sizeof(sectortypedisk), gMapRev*sizeof(sectortypedisk));
} }
@ -652,7 +667,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
XSECTOR *pXSector = &xsector[nXSector]; XSECTOR *pXSector = &xsector[nXSector];
memset(pXSector, 0, sizeof(XSECTOR)); memset(pXSector, 0, sizeof(XSECTOR));
int nCount; int nCount;
if (!byte_1A76C8) if (!encrypted)
{ {
nCount = nXSectorSize; nCount = nXSectorSize;
} }
@ -750,7 +765,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
walltype *pWall = &wall[i]; walltype *pWall = &wall[i];
walltypedisk load; walltypedisk load;
fr.Read(&load, sizeof(walltypedisk)); fr.Read(&load, sizeof(walltypedisk));
if (byte_1A76C8) if (encrypted)
{ {
dbCrypt((char*)&load, sizeof(walltypedisk), (gMapRev*sizeof(sectortypedisk)) | 0x7474614d); dbCrypt((char*)&load, sizeof(walltypedisk), (gMapRev*sizeof(sectortypedisk)) | 0x7474614d);
} }
@ -779,7 +794,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
XWALL *pXWall = &xwall[nXWall]; XWALL *pXWall = &xwall[nXWall];
memset(pXWall, 0, sizeof(XWALL)); memset(pXWall, 0, sizeof(XWALL));
int nCount; int nCount;
if (!byte_1A76C8) if (!encrypted)
{ {
nCount = nXWallSize; nCount = nXWallSize;
} }
@ -833,7 +848,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
spritetypedisk load; spritetypedisk load;
spritetype *pSprite = &sprite[i]; spritetype *pSprite = &sprite[i];
fr.Read(&load, sizeof(spritetypedisk)); // load into an intermediate buffer so that spritetype is no longer bound by file formats. fr.Read(&load, sizeof(spritetypedisk)); // load into an intermediate buffer so that spritetype is no longer bound by file formats.
if (byte_1A76C8) // What were these people thinking? :( if (encrypted) // What were these people thinking? :(
{ {
dbCrypt((char*)&load, sizeof(spritetypedisk), (gMapRev*sizeof(spritetypedisk)) | 0x7474614d); dbCrypt((char*)&load, sizeof(spritetypedisk), (gMapRev*sizeof(spritetypedisk)) | 0x7474614d);
} }
@ -874,7 +889,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
XSPRITE *pXSprite = &xsprite[nXSprite]; XSPRITE *pXSprite = &xsprite[nXSprite];
memset(pXSprite, 0, sizeof(XSPRITE)); memset(pXSprite, 0, sizeof(XSPRITE));
int nCount; int nCount;
if (!byte_1A76C8) if (!encrypted)
{ {
nCount = nXSpriteSize; nCount = nXSpriteSize;
} }
@ -948,7 +963,7 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
bitReader.skipBits(32); bitReader.skipBits(32);
xsprite[sprite[i].extra].reference = i; xsprite[sprite[i].extra].reference = i;
xsprite[sprite[i].extra].busy = IntToFixed(xsprite[sprite[i].extra].state); xsprite[sprite[i].extra].busy = IntToFixed(xsprite[sprite[i].extra].state);
if (!byte_1A76C8) { if (!encrypted) {
xsprite[sprite[i].extra].lT |= xsprite[sprite[i].extra].lB; xsprite[sprite[i].extra].lT |= xsprite[sprite[i].extra].lB;
} }
@ -978,22 +993,22 @@ void dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, shor
if (pCRC) if (pCRC)
*pCRC = nCRC; *pCRC = nCRC;
PropagateMarkerReferences(); PropagateMarkerReferences();
if (byte_1A76C8) if (encrypted)
{ {
if (gSongId == 0x7474614d || gSongId == 0x4d617474) if (gMattId == 0x7474614d || gMattId == 0x4d617474)
{ {
byte_1A76C6 = 1; drawtile2048 = 1;
} }
else if (!gSongId) else if (!gMattId)
{ {
byte_1A76C6 = 0; drawtile2048 = 0;
} }
else else
{ {
I_Error("%s: Corrupted Map file", mapname.GetChars()); I_Error("%s: Corrupted Map file", mapname.GetChars());
} }
} }
else if (gSongId != 0) else if (gMattId != 0)
{ {
I_Error("%s: Corrupted Map file", mapname.GetChars()); I_Error("%s: Corrupted Map file", mapname.GetChars());
} }

View file

@ -298,13 +298,17 @@ struct SPRITEHIT {
extern unsigned short gStatCount[kMaxStatus + 1];; extern unsigned short gStatCount[kMaxStatus + 1];;
extern bool byte_1A76C6, byte_1A76C7, byte_1A76C8; extern bool drawtile2048, encrypted;
extern MAPHEADER2 byte_19AE44; extern MAPHEADER2 byte_19AE44;
extern XSPRITE xsprite[kMaxXSprites]; extern XSPRITE xsprite[kMaxXSprites];
extern XSECTOR xsector[kMaxXSectors]; extern XSECTOR xsector[kMaxXSectors];
extern XWALL xwall[kMaxXWalls]; extern XWALL xwall[kMaxXWalls];
extern XSECTOR xsectorbackup[kMaxXSectors];
extern XWALL xwallbackup[kMaxXWalls];
extern FixedBitArray<MAXSPRITES> activeXSprites;
extern SPRITEHIT gSpriteHit[kMaxXSprites]; extern SPRITEHIT gSpriteHit[kMaxXSprites];
extern char qsector_filler[kMaxSectors]; extern char qsector_filler[kMaxSectors];
@ -312,7 +316,7 @@ extern char qsector_filler[kMaxSectors];
extern int xvel[kMaxSprites], yvel[kMaxSprites], zvel[kMaxSprites]; extern int xvel[kMaxSprites], yvel[kMaxSprites], zvel[kMaxSprites];
extern int gVisibility; extern int gVisibility;
extern int gMapRev, gSongId, gSkyCount; extern int gMapRev, gMattId, gSkyCount;
extern const char *gItemText[]; extern const char *gItemText[];
extern const char *gAmmoText[]; extern const char *gAmmoText[];
extern const char *gWeaponText[]; extern const char *gWeaponText[];
@ -366,6 +370,7 @@ int qchangespritesect(short nSprite, short nSector);
int ChangeSpriteStat(int nSprite, int nStatus); int ChangeSpriteStat(int nSprite, int nStatus);
int qchangespritestat(short nSprite, short nStatus); int qchangespritestat(short nSprite, short nStatus);
void InitFreeList(unsigned short *pList, int nCount); void InitFreeList(unsigned short *pList, int nCount);
void InitFreeList(unsigned short* pList, int nCount, FixedBitArray<MAXSPRITES>& activeXSprites);
void InsertFree(unsigned short *pList, int nIndex); void InsertFree(unsigned short *pList, int nIndex);
unsigned short dbInsertXSprite(int nSprite); unsigned short dbInsertXSprite(int nSprite);
void dbDeleteXSprite(int nXSprite); void dbDeleteXSprite(int nXSprite);

View file

@ -31,7 +31,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "endgame.h" #include "endgame.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "player.h" #include "player.h"
#include "sound.h" #include "sound.h"
#include "view.h" #include "view.h"

View file

@ -33,7 +33,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "endgame.h" #include "endgame.h"
#include "aistate.h" #include "aistate.h"
#include "loadsave.h"
#include "sectorfx.h" #include "sectorfx.h"
#include "choke.h" #include "choke.h"
#include "view.h" #include "view.h"

View file

@ -32,7 +32,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "endgame.h" #include "endgame.h"
#include "inifile.h" #include "inifile.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "messages.h" #include "messages.h"
#include "seq.h" #include "seq.h"
#include "sound.h" #include "sound.h"
@ -45,7 +44,7 @@ BEGIN_BLD_NS
GAMEOPTIONS gGameOptions; GAMEOPTIONS gGameOptions;
GAMEOPTIONS gSingleGameOptions = { GAMEOPTIONS gSingleGameOptions = {
0, 2, 2, 0, 0, 0, 0, 0, 0, 0, 2, 3600, 1800, 1800, 7200 0, 2, 0, 0, 0, 0, 0, 0, 2, 3600, 1800, 1800, 7200
}; };
EPISODEINFO gEpisodeInfo[kMaxEpisodes+1]; EPISODEINFO gEpisodeInfo[kMaxEpisodes+1];

View file

@ -49,8 +49,6 @@ enum EGameFlag
struct GAMEOPTIONS { struct GAMEOPTIONS {
unsigned char nGameType; unsigned char nGameType;
unsigned char nDifficulty; unsigned char nDifficulty;
short nSaveGameSlot;
int picEntry;
char nMonsterSettings; char nMonsterSettings;
int uGameFlags; int uGameFlags;
int uNetGameFlags; int uNetGameFlags;

File diff suppressed because it is too large Load diff

View file

@ -27,23 +27,5 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
struct FSavegameNode; struct FSavegameNode;
BEGIN_BLD_NS BEGIN_BLD_NS
class LoadSave {
public:
static LoadSave head;
static FileWriter *hSFile;
static FileReader hLFile;
static TDeletingArray<LoadSave*> loadSaves;
LoadSave() {
loadSaves.Push(this);
}
virtual ~LoadSave() = default;
virtual void Save(void);
virtual void Load(void);
void Read(void *, int);
void Write(const void *, int);
};
void LoadSaveSetup(void);
extern FixedBitArray<MAXSPRITES> activeXSprites;
END_BLD_NS END_BLD_NS

View file

@ -31,7 +31,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "eventq.h" #include "eventq.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "messages.h" #include "messages.h"
#include "player.h" #include "player.h"
#include "view.h" #include "view.h"

View file

@ -28,7 +28,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "blood.h" #include "blood.h"
#include "db.h" #include "db.h"
#include "gameutil.h" #include "gameutil.h"
#include "loadsave.h"
#include "player.h" #include "player.h"
#include "view.h" #include "view.h"

View file

@ -32,7 +32,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "nnexts.h" #include "nnexts.h"
#ifdef NOONE_EXTENSIONS #ifdef NOONE_EXTENSIONS
#include <random> #include <random>
#include "loadsave.h"
#include "player.h" #include "player.h"
#include "aiunicult.h" #include "aiunicult.h"
#include "triggers.h" #include "triggers.h"
@ -45,6 +44,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "sound.h" #include "sound.h"
#include "seq.h" #include "seq.h"
#include "ai.h" #include "ai.h"
#include "savegamehelp.h"
BEGIN_BLD_NS BEGIN_BLD_NS
@ -5286,43 +5286,83 @@ void callbackGenDudeUpdate(int nSprite) // 24
} }
class NNLoadSave : public LoadSave
{
virtual void Load(void);
virtual void Save(void);
};
void NNLoadSave::Load(void) //---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
FSerializer& Serialize(FSerializer& arc, const char* keyname, GENDUDEEXTRA& w, GENDUDEEXTRA* def)
{ {
Read(gSpriteMass, sizeof(gSpriteMass)); if (arc.BeginObject(keyname))
Read(&gProxySpritesCount, sizeof(gProxySpritesCount)); {
Read(gProxySpritesList, sizeof(gProxySpritesList)); arc.Array("initvals", w.initVals, 3)
Read(&gSightSpritesCount, sizeof(gSightSpritesCount)); .Array("availdeaths", w.availDeaths, kDamageMax)
Read(gSightSpritesList, sizeof(gSightSpritesList)); ("movespeed", w.moveSpeed)
Read(&gPhysSpritesCount, sizeof(gPhysSpritesCount)); ("firedist", w.fireDist)
Read(gPhysSpritesList, sizeof(gPhysSpritesList)); ("throwdist", w.throwDist)
Read(&gImpactSpritesCount, sizeof(gImpactSpritesCount)); ("curweapon", w.curWeapon)
Read(gImpactSpritesList, sizeof(gImpactSpritesList)); ("weapontype", w.weaponType)
Read(&gEventRedirectsUsed, sizeof(gEventRedirectsUsed)); ("basedispersion", w.baseDispersion)
("slavecount", w.slaveCount)
("lifeleech", w.nLifeLeech)
.Array("slaves", w.slave, w.slaveCount)
.Array("dmgcontrol", w.dmgControl, kDamageMax)
.Array("updreq", w.updReq, kGenDudePropertyMax)
("flags", w.flags)
.EndObject();
}
return arc;
} }
void NNLoadSave::Save(void) FSerializer& Serialize(FSerializer& arc, const char* keyname, SPRITEMASS& w, SPRITEMASS* def)
{ {
Write(gSpriteMass, sizeof(gSpriteMass)); static SPRITEMASS nul;
Write(&gProxySpritesCount, sizeof(gProxySpritesCount)); if (arc.isReading()) w = {};
Write(gProxySpritesList, sizeof(gProxySpritesList)); if (arc.BeginObject(keyname))
Write(&gSightSpritesCount, sizeof(gSightSpritesCount)); {
Write(gSightSpritesList, sizeof(gSightSpritesList)); arc ("seq", w.seqId, &nul.seqId)
Write(&gPhysSpritesCount, sizeof(gPhysSpritesCount)); ("picnum", w.picnum, &nul.picnum)
Write(gPhysSpritesList, sizeof(gPhysSpritesList)); ("xrepeat", w.xrepeat, &nul.xrepeat)
Write(&gImpactSpritesCount, sizeof(gImpactSpritesCount)); ("yrepeat", w.yrepeat, &nul.yrepeat)
Write(gImpactSpritesList, sizeof(gImpactSpritesList)); ("clipdist", w.clipdist)
Write(&gEventRedirectsUsed, sizeof(gEventRedirectsUsed)); ("mass", w.mass)
("airvel", w.airVel)
("fraction", w.fraction)
.EndObject();
}
return arc;
} }
void NNLoadSaveConstruct(void) void SerializeNNExts(FSerializer& arc)
{ {
new NNLoadSave(); if (arc.BeginObject("nnexts"))
{
// the GenDudeArray only contains valid info for kDudeModernCustom and kDudeModernCustomBurning so only save the relevant entries as these are not small.
bool foundsome = false;
for (int i = 0; i < kMaxSprites; i++)
{
if (activeSprites[i] && (sprite[i].type == kDudeModernCustom || sprite[i].type == kDudeModernCustomBurning))
{
if (!foundsome) arc.BeginArray("gendudeextra");
foundsome = true;
arc(nullptr, gGenDudeExtra[i]);
}
}
if (foundsome) arc.EndArray();
arc.SparseArray("spritemass", gSpriteMass, kMaxSprites, activeXSprites)
("proxyspritescount", gProxySpritesCount)
.Array("proxyspriteslist", gProxySpritesList, gProxySpritesCount)
("sightspritescount", gSightSpritesCount)
.Array("sightspriteslist", gSightSpritesList, gSightSpritesCount)
("physspritescount", gPhysSpritesCount)
.Array("physspriteslist", gPhysSpritesList, gPhysSpritesCount)
("impactspritescount", gImpactSpritesCount)
.Array("impactspriteslist", gImpactSpritesList, gImpactSpritesCount)
("eventredirects", gEventRedirectsUsed)
.EndObject();
}
} }
/////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////

View file

@ -36,7 +36,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "gib.h" #include "gib.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "player.h" #include "player.h"
#include "seq.h" #include "seq.h"
#include "sound.h" #include "sound.h"

View file

@ -33,7 +33,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "endgame.h" #include "endgame.h"
#include "aistate.h" #include "aistate.h"
#include "loadsave.h"
#include "sectorfx.h" #include "sectorfx.h"
#include "choke.h" #include "choke.h"
#include "view.h" #include "view.h"

View file

@ -33,7 +33,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "endgame.h" #include "endgame.h"
#include "aistate.h" #include "aistate.h"
#include "loadsave.h"
#include "sectorfx.h" #include "sectorfx.h"
#include "choke.h" #include "choke.h"
#include "view.h" #include "view.h"

View file

@ -34,7 +34,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "eventq.h" #include "eventq.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "sound.h" #include "sound.h"
#include "seq.h" #include "seq.h"
#include "gameutil.h" #include "gameutil.h"

View file

@ -41,7 +41,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "gib.h" #include "gib.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "player.h" #include "player.h"
#include "seq.h" #include "seq.h"
#include "qav.h" #include "qav.h"

View file

@ -33,7 +33,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "endgame.h" #include "endgame.h"
#include "aistate.h" #include "aistate.h"
#include "loadsave.h"
#include "sectorfx.h" #include "sectorfx.h"
#include "choke.h" #include "choke.h"
#include "view.h" #include "view.h"
@ -481,8 +480,8 @@ void UpdateBlend()
videoTintBlood(nRed, nGreen, nBlue); videoTintBlood(nRed, nGreen, nBlue);
} }
char otherMirrorGotpic[2]; uint8_t otherMirrorGotpic[2];
char bakMirrorGotpic[2]; uint8_t bakMirrorGotpic[2];
// int gVisibility; // int gVisibility;
int deliriumTilt, deliriumTurn, deliriumPitch; int deliriumTilt, deliriumTurn, deliriumPitch;
@ -988,7 +987,7 @@ void viewDrawScreen(bool sceneonly)
gChoke.animateChoke(160, zn, (int)gInterpolate); gChoke.animateChoke(160, zn, (int)gInterpolate);
} }
#if 0 #if 0
if (byte_1A76C6) if (drawtile_2048)
{ {
DrawStatSprite(2048, xdim-15, 20); DrawStatSprite(2048, xdim-15, 20);
} }
@ -1065,36 +1064,17 @@ bool GameInterface::DrawAutomapPlayer(int x, int y, int z, int a)
return true; return true;
} }
void SerializeView(FSerializer& arc)
class ViewLoadSave : public LoadSave {
public:
void Load(void);
void Save(void);
};
void ViewLoadSave::Load(void)
{ {
Read(otherMirrorGotpic, sizeof(otherMirrorGotpic)); if (arc.BeginObject("view"))
Read(bakMirrorGotpic, sizeof(bakMirrorGotpic)); {
Read(&gScreenTilt, sizeof(gScreenTilt)); arc("screentilt", gScreenTilt)
Read(&deliriumTilt, sizeof(deliriumTilt)); ("deliriumtilt", deliriumTilt)
Read(&deliriumTurn, sizeof(deliriumTurn)); ("deliriumturn", deliriumTurn)
Read(&deliriumPitch, sizeof(deliriumPitch)); ("deliriumpitch", deliriumPitch)
.EndObject();
}
} }
void ViewLoadSave::Save(void)
{
Write(otherMirrorGotpic, sizeof(otherMirrorGotpic));
Write(bakMirrorGotpic, sizeof(bakMirrorGotpic));
Write(&gScreenTilt, sizeof(gScreenTilt));
Write(&deliriumTilt, sizeof(deliriumTilt));
Write(&deliriumTurn, sizeof(deliriumTurn));
Write(&deliriumPitch, sizeof(deliriumPitch));
}
void ViewLoadSaveConstruct(void)
{
new ViewLoadSave();
}
END_BLD_NS END_BLD_NS

View file

@ -29,7 +29,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "db.h" #include "db.h"
#include "gameutil.h" #include "gameutil.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "view.h" #include "view.h"
#include "nnexts.h" #include "nnexts.h"
@ -333,33 +332,4 @@ void SerializeWarp(FSerializer& arc)
} }
} }
class WarpLoadSave : public LoadSave
{
public:
virtual void Load();
virtual void Save();
};
void WarpLoadSave::Load()
{
Read(gStartZone, sizeof(gStartZone));
Read(gUpperLink, sizeof(gUpperLink));
Read(gLowerLink, sizeof(gLowerLink));
}
void WarpLoadSave::Save()
{
Write(gStartZone, sizeof(gStartZone));
Write(gUpperLink, sizeof(gUpperLink));
Write(gLowerLink, sizeof(gLowerLink));
}
void WarpLoadSaveConstruct(void)
{
new WarpLoadSave();
}
END_BLD_NS END_BLD_NS

View file

@ -38,7 +38,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "gameutil.h" #include "gameutil.h"
#include "globals.h" #include "globals.h"
#include "levels.h" #include "levels.h"
#include "loadsave.h"
#include "player.h" #include "player.h"
#include "qav.h" #include "qav.h"
#include "seq.h" #include "seq.h"

View file

@ -307,7 +307,6 @@ typedef struct {
int16_t tileofs[MAXPSKYTILES]; // for 0 <= j < (1<<lognumtiles): tile offset relative to basetile int16_t tileofs[MAXPSKYTILES]; // for 0 <= j < (1<<lognumtiles): tile offset relative to basetile
int32_t yscale; int32_t yscale;
int combinedtile;
} psky_t; } psky_t;
// Index of map-global (legacy) multi-sky: // Index of map-global (legacy) multi-sky:

View file

@ -243,12 +243,24 @@ void bfirst_search_try(T *const list, uint8_t *const bitmap, T *const eltnumptr,
/* End dependence on compat.o object. */ /* End dependence on compat.o object. */
inline FSerializer& Serialize(FSerializer& arc, const char* key, vec3_t& c, vec3_t* def) inline FSerializer& Serialize(FSerializer& arc, const char* key, vec2_t& c, vec2_t* def)
{ {
if (def && !memcmp(&c, def, sizeof(c))) return arc; if (def && !memcmp(&c, def, sizeof(c))) return arc;
if (arc.BeginObject(key)) if (arc.BeginObject(key))
{ {
arc("x", c.x, def? &def->x : nullptr) arc("x", c.x, def? &def->x : nullptr)
("y", c.y, def ? &def->y : nullptr)
.EndObject();
}
return arc;
}
inline FSerializer& Serialize(FSerializer& arc, const char* key, vec3_t& c, vec3_t* def)
{
if (def && !memcmp(&c, def, sizeof(c))) return arc;
if (arc.BeginObject(key))
{
arc("x", c.x, def ? &def->x : nullptr)
("y", c.y, def ? &def->y : nullptr) ("y", c.y, def ? &def->y : nullptr)
("z", c.z, def ? &def->z : nullptr) ("z", c.z, def ? &def->z : nullptr)
.EndObject(); .EndObject();
@ -256,5 +268,4 @@ inline FSerializer& Serialize(FSerializer& arc, const char* key, vec3_t& c, vec3
return arc; return arc;
} }
#endif // compat_h_ #endif // compat_h_

View file

@ -808,14 +808,12 @@ psky_t * tileSetupSky(int32_t const tilenum)
for (auto& sky : multipskies) for (auto& sky : multipskies)
if (tilenum == sky.tilenum) if (tilenum == sky.tilenum)
{ {
sky.combinedtile = -1; // invalidate the old content
return &sky; return &sky;
} }
multipskies.Reserve(1); multipskies.Reserve(1);
multipskies.Last() = {}; multipskies.Last() = {};
multipskies.Last().tilenum = tilenum; multipskies.Last().tilenum = tilenum;
multipskies.Last().combinedtile = -1;
multipskies.Last().yscale = 65536; multipskies.Last().yscale = 65536;
return &multipskies.Last(); return &multipskies.Last();
} }