[HACK] Save correct lap count on netreplays

This commit is contained in:
fickleheart 2019-01-27 15:45:42 -06:00
parent ab226c1e39
commit 26770c5103
5 changed files with 18 additions and 8 deletions

View file

@ -1355,7 +1355,7 @@ static void Got_NetVar(UINT8 **p, INT32 playernum)
Setvalue(cvar, svalue, stealth); Setvalue(cvar, svalue, stealth);
} }
void CV_SaveNetVars(UINT8 **p) void CV_SaveNetVars(UINT8 **p, boolean demorecording)
{ {
consvar_t *cvar; consvar_t *cvar;
UINT8 *count_p = *p; UINT8 *count_p = *p;
@ -1365,10 +1365,20 @@ void CV_SaveNetVars(UINT8 **p)
// the client will reset all netvars to default before loading // the client will reset all netvars to default before loading
WRITEUINT16(*p, 0x0000); WRITEUINT16(*p, 0x0000);
for (cvar = consvar_vars; cvar; cvar = cvar->next) for (cvar = consvar_vars; cvar; cvar = cvar->next)
if ((cvar->flags & CV_NETVAR) && !CV_IsSetToDefault(cvar)) if (((cvar->flags & CV_NETVAR) && !CV_IsSetToDefault(cvar)) || (demorecording && cvar->netid == cv_numlaps.netid))
{ {
WRITEUINT16(*p, cvar->netid); WRITEUINT16(*p, cvar->netid);
// UGLY HACK: Save proper lap count in net replays
if (demorecording && cvar->netid == cv_numlaps.netid)
{
WRITESTRING(*p, cv_basenumlaps.string);
}
else
{
WRITESTRING(*p, cvar->string); WRITESTRING(*p, cvar->string);
}
WRITEUINT8(*p, false); WRITEUINT8(*p, false);
++count; ++count;
} }

View file

@ -160,7 +160,7 @@ void CV_AddValue(consvar_t *var, INT32 increment);
void CV_SaveVariables(FILE *f); void CV_SaveVariables(FILE *f);
// load/save gamesate (load and save option and for network join in game) // load/save gamesate (load and save option and for network join in game)
void CV_SaveNetVars(UINT8 **p); void CV_SaveNetVars(UINT8 **p, boolean demorecording);
void CV_LoadNetVars(UINT8 **p); void CV_LoadNetVars(UINT8 **p);
// reset cheat netvars after cheats is deactivated // reset cheat netvars after cheats is deactivated

View file

@ -1500,7 +1500,7 @@ static boolean SV_SendServerConfig(INT32 node)
op = p = netbuffer->u.servercfg.varlengthinputs; op = p = netbuffer->u.servercfg.varlengthinputs;
CV_SavePlayerNames(&p); CV_SavePlayerNames(&p);
CV_SaveNetVars(&p); CV_SaveNetVars(&p, false);
{ {
const size_t len = sizeof (serverconfig_pak) + (size_t)(p - op); const size_t len = sizeof (serverconfig_pak) + (size_t)(p - op);

View file

@ -5494,7 +5494,7 @@ void G_BeginRecording(void)
if (demoflags & DF_MULTIPLAYER) { if (demoflags & DF_MULTIPLAYER) {
// Netvars first :) // Netvars first :)
CV_SaveNetVars(&demo_p); CV_SaveNetVars(&demo_p, true);
// Now store a SIMPLIFIED data struct for each in-game player // Now store a SIMPLIFIED data struct for each in-game player
for (p = 0; p < MAXPLAYERS; p++) { for (p = 0; p < MAXPLAYERS; p++) {
@ -5576,7 +5576,7 @@ void G_BeginRecording(void)
WRITEFIXED(demo_p, player->jumpfactor); WRITEFIXED(demo_p, player->jumpfactor);
// Save netvar data (SONICCD, etc) // Save netvar data (SONICCD, etc)
CV_SaveNetVars(&demo_p); CV_SaveNetVars(&demo_p, false); //@TODO can this be true? it's not necessary for now but would be nice for consistency
memset(&oldcmd,0,sizeof(oldcmd)); memset(&oldcmd,0,sizeof(oldcmd));
memset(&oldghost,0,sizeof(oldghost)); memset(&oldghost,0,sizeof(oldghost));

View file

@ -3447,7 +3447,7 @@ void P_SaveNetGame(void)
mobj_t *mobj; mobj_t *mobj;
INT32 i = 1; // don't start from 0, it'd be confused with a blank pointer otherwise INT32 i = 1; // don't start from 0, it'd be confused with a blank pointer otherwise
CV_SaveNetVars(&save_p); CV_SaveNetVars(&save_p, false);
P_NetArchiveMisc(); P_NetArchiveMisc();
// Assign the mobjnumber for pointer tracking // Assign the mobjnumber for pointer tracking