mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-28 04:00:41 +00:00
Fix replay recording memory leak
This commit is contained in:
parent
79c299bf31
commit
5c13727aac
1 changed files with 15 additions and 2 deletions
17
src/g_game.c
17
src/g_game.c
|
@ -6326,8 +6326,8 @@ void G_RecordDemo(const char *name)
|
||||||
maxsize = 1024*1024*2;
|
maxsize = 1024*1024*2;
|
||||||
if (M_CheckParm("-maxdemo") && M_IsNextParm())
|
if (M_CheckParm("-maxdemo") && M_IsNextParm())
|
||||||
maxsize = atoi(M_GetNextParm()) * 1024;
|
maxsize = atoi(M_GetNextParm()) * 1024;
|
||||||
// if (demobuffer)
|
if (demobuffer)
|
||||||
// free(demobuffer);
|
free(demobuffer);
|
||||||
demo_p = NULL;
|
demo_p = NULL;
|
||||||
demobuffer = malloc(maxsize);
|
demobuffer = malloc(maxsize);
|
||||||
demoend = demobuffer + maxsize;
|
demoend = demobuffer + maxsize;
|
||||||
|
@ -7153,6 +7153,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7181,6 +7182,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7193,6 +7195,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7212,6 +7215,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7272,6 +7276,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7342,6 +7347,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7355,6 +7361,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7379,6 +7386,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7422,6 +7430,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7477,6 +7486,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -7491,6 +7501,7 @@ void G_DoPlayDemo(char *defdemoname)
|
||||||
M_StartMessage(msg, NULL, MM_NOTHING);
|
M_StartMessage(msg, NULL, MM_NOTHING);
|
||||||
Z_Free(pdemoname);
|
Z_Free(pdemoname);
|
||||||
Z_Free(demobuffer);
|
Z_Free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.playback = false;
|
demo.playback = false;
|
||||||
demo.title = false;
|
demo.title = false;
|
||||||
return;
|
return;
|
||||||
|
@ -8140,6 +8151,7 @@ ATTRNORETURN void FUNCNORETURN G_StopMetalRecording(void)
|
||||||
saved = FIL_WriteFile(va("%sMS.LMP", G_BuildMapName(gamemap)), demobuffer, demo_p - demobuffer); // finally output the file.
|
saved = FIL_WriteFile(va("%sMS.LMP", G_BuildMapName(gamemap)), demobuffer, demo_p - demobuffer); // finally output the file.
|
||||||
}
|
}
|
||||||
free(demobuffer);
|
free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
metalrecording = false;
|
metalrecording = false;
|
||||||
if (saved)
|
if (saved)
|
||||||
I_Error("Saved to %sMS.LMP", G_BuildMapName(gamemap));
|
I_Error("Saved to %sMS.LMP", G_BuildMapName(gamemap));
|
||||||
|
@ -8320,6 +8332,7 @@ void G_SaveDemo(void)
|
||||||
if (FIL_WriteFile(va(pandf, srb2home, demoname), demobuffer, demo_p - demobuffer)) // finally output the file.
|
if (FIL_WriteFile(va(pandf, srb2home, demoname), demobuffer, demo_p - demobuffer)) // finally output the file.
|
||||||
demo.savemode = DSM_SAVED;
|
demo.savemode = DSM_SAVED;
|
||||||
free(demobuffer);
|
free(demobuffer);
|
||||||
|
demobuffer = NULL;
|
||||||
demo.recording = false;
|
demo.recording = false;
|
||||||
|
|
||||||
if (modeattacking != ATTACKING_RECORD)
|
if (modeattacking != ATTACKING_RECORD)
|
||||||
|
|
Loading…
Reference in a new issue