Merge branch 'responsefile-fix' into 'master'

Fix M_FindResponseFile returning garbage data

See merge request STJr/SRB2!254
This commit is contained in:
Monster Iestyn 2018-11-23 15:59:40 -05:00
commit d228e35fcb
5 changed files with 15 additions and 5 deletions

View file

@ -2,7 +2,7 @@
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// Copyright (C) 1993-1996 by id Software, Inc. // Copyright (C) 1993-1996 by id Software, Inc.
// Copyright (C) 1998-2000 by DooM Legacy Team. // Copyright (C) 1998-2000 by DooM Legacy Team.
// Copyright (C) 1999-2016 by Sonic Team Junior. // Copyright (C) 1999-2018 by Sonic Team Junior.
// //
// This program is free software distributed under the // This program is free software distributed under the
// terms of the GNU General Public License, version 2. // terms of the GNU General Public License, version 2.
@ -25,6 +25,10 @@ INT32 myargc;
*/ */
char **myargv; char **myargv;
/** \brief did we alloc myargv ourselves?
*/
boolean myargmalloc = false;
/** \brief founded the parm /** \brief founded the parm
*/ */
static INT32 found; static INT32 found;
@ -176,6 +180,7 @@ void M_FindResponseFile(void)
free(file); free(file);
I_Error("Not enough memory to read response file"); I_Error("Not enough memory to read response file");
} }
myargmalloc = true; // mark as having been allocated by us
memset(myargv, 0, sizeof (char *) * MAXARGVS); memset(myargv, 0, sizeof (char *) * MAXARGVS);
myargv[0] = firstargv; myargv[0] = firstargv;
@ -198,17 +203,15 @@ void M_FindResponseFile(void)
k++; k++;
} while (k < size); } while (k < size);
free(file);
for (k = 0; k < pindex; k++) for (k = 0; k < pindex; k++)
myargv[indexinfile++] = moreargs[k]; myargv[indexinfile++] = moreargs[k];
myargc = indexinfile; myargc = indexinfile;
// display arguments // display arguments
CONS_Printf(M_GetText("%d command-line args:\n"), myargc); CONS_Printf(M_GetText("%d command-line args:\n"), myargc-1); // -1 so @ don't actually get counted for
for (k = 1; k < myargc; k++) for (k = 1; k < myargc; k++)
CONS_Printf("%s\n", myargv[k]); CONS_Printf("%s\n", myargv[k]);
break; break;
} }
} }

View file

@ -19,6 +19,7 @@
// //
extern INT32 myargc; extern INT32 myargc;
extern char **myargv; extern char **myargv;
extern boolean myargmalloc;
// Returns the position of the given parameter in the arg list (0 if not found). // Returns the position of the given parameter in the arg list (0 if not found).
INT32 M_CheckParm(const char *check); INT32 M_CheckParm(const char *check);

View file

@ -2139,6 +2139,8 @@ void I_Quit(void)
printf("\r"); printf("\r");
ShowEndTxt(); ShowEndTxt();
} }
if (myargmalloc)
free(myargv); // Deallocate allocated memory
death: death:
W_Shutdown(); W_Shutdown();
exit(0); exit(0);

View file

@ -2301,6 +2301,8 @@ void I_Quit(void)
printf("\r"); printf("\r");
ShowEndTxt(); ShowEndTxt();
} }
if (myargmalloc)
free(myargv); // Deallocate allocated memory
death: death:
W_Shutdown(); W_Shutdown();
#ifdef GP2X #ifdef GP2X

View file

@ -771,6 +771,8 @@ void I_Quit(void)
ShowEndTxt(co); ShowEndTxt(co);
} }
fflush(stderr); fflush(stderr);
if (myargmalloc)
free(myargv); // Deallocate allocated memory
W_Shutdown(); W_Shutdown();
exit(0); exit(0);
} }