- shorten the struct for puser to what actually gets used from it.

This is preparation for making USER more serialization friendly as it was copied to puser.
This commit is contained in:
Christoph Oelckers 2020-12-01 16:22:32 +01:00
parent dd75c8dbe4
commit 6dfe869614
4 changed files with 29 additions and 10 deletions

View file

@ -514,10 +514,9 @@ void TerminateLevel(void)
pnum = stat - STAT_PLAYER0; pnum = stat - STAT_PLAYER0;
StatIterator it(stat); StatIterator it(stat);
while ((i = it.NextIndex()) >= 0) if ((i = it.NextIndex()) >= 0)
{ {
if (User[i]) if (User[i]) puser[pnum].CopyFromUser(User[i]);
memcpy(&puser[pnum], User[i], sizeof(USER));
} }
} }

View file

@ -1272,6 +1272,28 @@ typedef struct
uint8_t filler; uint8_t filler;
} USER,*USERp; } USER,*USERp;
struct USERSAVE
{
short Health;
int8_t WeaponNum;
int8_t LastWeaponNum;
void CopyFromUser(USER* u)
{
Health = u->Health;
WeaponNum = u->WeaponNum;
LastWeaponNum = u->LastWeaponNum;
}
void CopyToUser(USER* u)
{
u->Health = Health;
u->WeaponNum = WeaponNum;
u->LastWeaponNum = LastWeaponNum;
}
};
// sprite->extra flags // sprite->extra flags
// BUILD AND GAME - DO NOT MOVE THESE // BUILD AND GAME - DO NOT MOVE THESE
#define SPRX_SKILL (BIT(0) | BIT(1) | BIT(2)) #define SPRX_SKILL (BIT(0) | BIT(1) | BIT(2))
@ -1991,8 +2013,8 @@ extern short connecthead, connectpoint2[MAXPLAYERS];
*/ */
extern int *lastpacket2clock; extern int *lastpacket2clock;
// save player info when moving to a new level // save player info when moving to a new level (shortened to only cover the fields that actually are copied back.(
extern USER puser[MAX_SW_PLAYERS_REG]; extern USERSAVE puser[MAX_SW_PLAYERS_REG];
/////////////////////////// ///////////////////////////
// //

View file

@ -2444,10 +2444,8 @@ InitPlayerSprite(PLAYERp pp)
} }
else else
{ {
// save stuff from last level // restore stuff from last level
u->WeaponNum = puser[pnum].WeaponNum; puser[pnum].CopyToUser(u);
u->LastWeaponNum = puser[pnum].LastWeaponNum;
u->Health = puser[pnum].Health;
PlayerLevelReset(pp); PlayerLevelReset(pp);
} }

View file

@ -78,7 +78,7 @@ extern bool NoMeters;
#define PLAYER_MIN_HEIGHT (Z(20)) #define PLAYER_MIN_HEIGHT (Z(20))
#define PLAYER_CRAWL_WADE_DEPTH (30) #define PLAYER_CRAWL_WADE_DEPTH (30)
USER puser[MAX_SW_PLAYERS_REG]; USERSAVE puser[MAX_SW_PLAYERS_REG];
//int16_t gNet.MultiGameType = MULTI_GAME_NONE; //int16_t gNet.MultiGameType = MULTI_GAME_NONE;
bool NightVision = false; bool NightVision = false;