Merge branch 'fix-ingame-join' into 'next'

Fix netgame joining

See merge request STJr/SRB2!2288
This commit is contained in:
Sal 2024-02-04 06:07:39 +00:00
commit 3bd53b6ca3

View file

@ -4612,6 +4612,8 @@ void G_LoadGameData(gamedata_t *data)
// Saves the main data file, which stores information such as emblems found, etc. // Saves the main data file, which stores information such as emblems found, etc.
void G_SaveGameData(gamedata_t *data) void G_SaveGameData(gamedata_t *data)
{ {
UINT8 *data_p;
size_t length; size_t length;
INT32 i, j; INT32 i, j;
UINT8 btemp; UINT8 btemp;
@ -4621,8 +4623,8 @@ void G_SaveGameData(gamedata_t *data)
if (!data->loaded) if (!data->loaded)
return; // If never loaded (-nodata), don't save return; // If never loaded (-nodata), don't save
save_p = savebuffer = (UINT8 *)malloc(GAMEDATASIZE); data_p = savebuffer = (UINT8 *)malloc(GAMEDATASIZE);
if (!save_p) if (!data_p)
{ {
CONS_Alert(CONS_ERROR, M_GetText("No more free memory for saving game data\n")); CONS_Alert(CONS_ERROR, M_GetText("No more free memory for saving game data\n"));
return; return;
@ -4631,20 +4633,20 @@ void G_SaveGameData(gamedata_t *data)
if (usedCheats) if (usedCheats)
{ {
free(savebuffer); free(savebuffer);
save_p = savebuffer = NULL; savebuffer = NULL;
return; return;
} }
// Version test // Version test
WRITEUINT32(save_p, GAMEDATA_ID); WRITEUINT32(data_p, GAMEDATA_ID);
WRITEUINT32(save_p, data->totalplaytime); WRITEUINT32(data_p, data->totalplaytime);
WRITEUINT32(save_p, quickncasehash(timeattackfolder, sizeof timeattackfolder)); WRITEUINT32(data_p, quickncasehash(timeattackfolder, sizeof timeattackfolder));
// TODO put another cipher on these things? meh, I don't care... // TODO put another cipher on these things? meh, I don't care...
for (i = 0; i < NUMMAPS; i++) for (i = 0; i < NUMMAPS; i++)
WRITEUINT8(save_p, (data->mapvisited[i] & MV_MAX)); WRITEUINT8(data_p, (data->mapvisited[i] & MV_MAX));
// To save space, use one bit per collected/achieved/unlocked flag // To save space, use one bit per collected/achieved/unlocked flag
for (i = 0; i < MAXEMBLEMS;) for (i = 0; i < MAXEMBLEMS;)
@ -4652,7 +4654,7 @@ void G_SaveGameData(gamedata_t *data)
btemp = 0; btemp = 0;
for (j = 0; j < 8 && j+i < MAXEMBLEMS; ++j) for (j = 0; j < 8 && j+i < MAXEMBLEMS; ++j)
btemp |= (data->collected[j+i] << j); btemp |= (data->collected[j+i] << j);
WRITEUINT8(save_p, btemp); WRITEUINT8(data_p, btemp);
i += j; i += j;
} }
for (i = 0; i < MAXEXTRAEMBLEMS;) for (i = 0; i < MAXEXTRAEMBLEMS;)
@ -4660,7 +4662,7 @@ void G_SaveGameData(gamedata_t *data)
btemp = 0; btemp = 0;
for (j = 0; j < 8 && j+i < MAXEXTRAEMBLEMS; ++j) for (j = 0; j < 8 && j+i < MAXEXTRAEMBLEMS; ++j)
btemp |= (data->extraCollected[j+i] << j); btemp |= (data->extraCollected[j+i] << j);
WRITEUINT8(save_p, btemp); WRITEUINT8(data_p, btemp);
i += j; i += j;
} }
for (i = 0; i < MAXUNLOCKABLES;) for (i = 0; i < MAXUNLOCKABLES;)
@ -4668,7 +4670,7 @@ void G_SaveGameData(gamedata_t *data)
btemp = 0; btemp = 0;
for (j = 0; j < 8 && j+i < MAXUNLOCKABLES; ++j) for (j = 0; j < 8 && j+i < MAXUNLOCKABLES; ++j)
btemp |= (data->unlocked[j+i] << j); btemp |= (data->unlocked[j+i] << j);
WRITEUINT8(save_p, btemp); WRITEUINT8(data_p, btemp);
i += j; i += j;
} }
for (i = 0; i < MAXCONDITIONSETS;) for (i = 0; i < MAXCONDITIONSETS;)
@ -4676,30 +4678,30 @@ void G_SaveGameData(gamedata_t *data)
btemp = 0; btemp = 0;
for (j = 0; j < 8 && j+i < MAXCONDITIONSETS; ++j) for (j = 0; j < 8 && j+i < MAXCONDITIONSETS; ++j)
btemp |= (data->achieved[j+i] << j); btemp |= (data->achieved[j+i] << j);
WRITEUINT8(save_p, btemp); WRITEUINT8(data_p, btemp);
i += j; i += j;
} }
WRITEUINT32(save_p, data->timesBeaten); WRITEUINT32(data_p, data->timesBeaten);
WRITEUINT32(save_p, data->timesBeatenWithEmeralds); WRITEUINT32(data_p, data->timesBeatenWithEmeralds);
WRITEUINT32(save_p, data->timesBeatenUltimate); WRITEUINT32(data_p, data->timesBeatenUltimate);
// Main records // Main records
for (i = 0; i < NUMMAPS; i++) for (i = 0; i < NUMMAPS; i++)
{ {
if (data->mainrecords[i]) if (data->mainrecords[i])
{ {
WRITEUINT32(save_p, data->mainrecords[i]->score); WRITEUINT32(data_p, data->mainrecords[i]->score);
WRITEUINT32(save_p, data->mainrecords[i]->time); WRITEUINT32(data_p, data->mainrecords[i]->time);
WRITEUINT16(save_p, data->mainrecords[i]->rings); WRITEUINT16(data_p, data->mainrecords[i]->rings);
} }
else else
{ {
WRITEUINT32(save_p, 0); WRITEUINT32(data_p, 0);
WRITEUINT32(save_p, 0); WRITEUINT32(data_p, 0);
WRITEUINT16(save_p, 0); WRITEUINT16(data_p, 0);
} }
WRITEUINT8(save_p, 0); // compat WRITEUINT8(data_p, 0); // compat
} }
// NiGHTS records // NiGHTS records
@ -4707,25 +4709,25 @@ void G_SaveGameData(gamedata_t *data)
{ {
if (!data->nightsrecords[i] || !data->nightsrecords[i]->nummares) if (!data->nightsrecords[i] || !data->nightsrecords[i]->nummares)
{ {
WRITEUINT8(save_p, 0); WRITEUINT8(data_p, 0);
continue; continue;
} }
WRITEUINT8(save_p, data->nightsrecords[i]->nummares); WRITEUINT8(data_p, data->nightsrecords[i]->nummares);
for (curmare = 0; curmare < (data->nightsrecords[i]->nummares + 1); ++curmare) for (curmare = 0; curmare < (data->nightsrecords[i]->nummares + 1); ++curmare)
{ {
WRITEUINT32(save_p, data->nightsrecords[i]->score[curmare]); WRITEUINT32(data_p, data->nightsrecords[i]->score[curmare]);
WRITEUINT8(save_p, data->nightsrecords[i]->grade[curmare]); WRITEUINT8(data_p, data->nightsrecords[i]->grade[curmare]);
WRITEUINT32(save_p, data->nightsrecords[i]->time[curmare]); WRITEUINT32(data_p, data->nightsrecords[i]->time[curmare]);
} }
} }
length = save_p - savebuffer; length = data_p - savebuffer;
FIL_WriteFile(va(pandf, srb2home, gamedatafilename), savebuffer, length); FIL_WriteFile(va(pandf, srb2home, gamedatafilename), savebuffer, length);
free(savebuffer); free(savebuffer);
save_p = savebuffer = NULL; savebuffer = NULL;
} }
#define VERSIONSIZE 16 #define VERSIONSIZE 16