mirror of
https://github.com/ZDoom/gzdoom-gles.git
synced 2024-11-14 00:20:38 +00:00
- Changed DArgs to use a TArray of FStrings instead of doing its own string vector management
in preparation for doing GatherFiles the "right" way. SVN r2183 (trunk)
This commit is contained in:
parent
4e2ca33ea9
commit
5da2885d88
13 changed files with 284 additions and 170 deletions
|
@ -1035,6 +1035,32 @@ FString BuildString (int argc, char **argv)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FString BuildString (int argc, FString *argv)
|
||||||
|
{
|
||||||
|
if (argc == 1)
|
||||||
|
{
|
||||||
|
return *argv;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FString buf;
|
||||||
|
int arg;
|
||||||
|
|
||||||
|
for (arg = 0; arg < argc; arg++)
|
||||||
|
{
|
||||||
|
if (strchr (argv[arg], ' '))
|
||||||
|
{
|
||||||
|
buf << '"' << argv[arg] << "\" ";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
buf << argv[arg] << ' ';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//
|
//
|
||||||
// SubstituteAliasParams
|
// SubstituteAliasParams
|
||||||
|
|
|
@ -59,6 +59,7 @@ void C_SetAlias (const char *name, const char *cmd);
|
||||||
|
|
||||||
// build a single string out of multiple strings
|
// build a single string out of multiple strings
|
||||||
FString BuildString (int argc, char **argv);
|
FString BuildString (int argc, char **argv);
|
||||||
|
FString BuildString (int argc, FString *argv);
|
||||||
|
|
||||||
// Class that can parse command lines
|
// Class that can parse command lines
|
||||||
class FCommandLine
|
class FCommandLine
|
||||||
|
|
|
@ -1753,7 +1753,7 @@ static FString CheckGameInfo(TArray<FString> & pwads)
|
||||||
void D_DoomMain (void)
|
void D_DoomMain (void)
|
||||||
{
|
{
|
||||||
int p, flags;
|
int p, flags;
|
||||||
char *v;
|
const char *v;
|
||||||
const char *wad;
|
const char *wad;
|
||||||
DArgs *execFiles;
|
DArgs *execFiles;
|
||||||
TArray<FString> pwads;
|
TArray<FString> pwads;
|
||||||
|
@ -1965,21 +1965,23 @@ void D_DoomMain (void)
|
||||||
autostart = true;
|
autostart = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// [RH] Hack to handle +map
|
// [RH] Hack to handle +map. The standard console command line handler
|
||||||
p = Args->CheckParm ("+map");
|
// won't be able to handle it, so we take it out of the command line and set
|
||||||
if (p && p < Args->NumArgs()-1)
|
// it up like -warp.
|
||||||
|
FString mapvalue = Args->TakeValue("+map");
|
||||||
|
if (mapvalue.IsNotEmpty())
|
||||||
{
|
{
|
||||||
if (!P_CheckMapData(Args->GetArg (p+1)))
|
if (!P_CheckMapData(mapvalue))
|
||||||
{
|
{
|
||||||
Printf ("Can't find map %s\n", Args->GetArg (p+1));
|
Printf ("Can't find map %s\n", mapvalue.GetChars());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
startmap = Args->GetArg (p + 1);
|
startmap = mapvalue;
|
||||||
Args->GetArg (p)[0] = '-';
|
|
||||||
autostart = true;
|
autostart = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (devparm)
|
if (devparm)
|
||||||
{
|
{
|
||||||
Printf ("%s", GStrings("D_DEVSTR"));
|
Printf ("%s", GStrings("D_DEVSTR"));
|
||||||
|
@ -1998,16 +2000,11 @@ void D_DoomMain (void)
|
||||||
|
|
||||||
// turbo option // [RH] (now a cvar)
|
// turbo option // [RH] (now a cvar)
|
||||||
{
|
{
|
||||||
UCVarValue value;
|
double amt;
|
||||||
static char one_hundred[] = "100";
|
const char *value = Args->CheckValue("-turbo");
|
||||||
|
amt = value != NULL ? atof(value) : 100;
|
||||||
value.String = Args->CheckValue ("-turbo");
|
Printf ("turbo scale: %.0f%%\n", amt);
|
||||||
if (value.String == NULL)
|
turbo = (float)amt;
|
||||||
value.String = one_hundred;
|
|
||||||
else
|
|
||||||
Printf ("turbo scale: %s%%\n", value.String);
|
|
||||||
|
|
||||||
turbo.SetGenericRepDefault (value, CVAR_String);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
v = Args->CheckValue ("-timer");
|
v = Args->CheckValue ("-timer");
|
||||||
|
|
|
@ -2189,18 +2189,14 @@ void G_WriteDemoTiccmd (ticcmd_t *cmd, int player, int buf)
|
||||||
//
|
//
|
||||||
// G_RecordDemo
|
// G_RecordDemo
|
||||||
//
|
//
|
||||||
void G_RecordDemo (char* name)
|
void G_RecordDemo (const char* name)
|
||||||
{
|
{
|
||||||
char *v;
|
|
||||||
|
|
||||||
usergame = false;
|
usergame = false;
|
||||||
strcpy (demoname, name);
|
strcpy (demoname, name);
|
||||||
FixPathSeperator (demoname);
|
FixPathSeperator (demoname);
|
||||||
DefaultExtension (demoname, ".lmp");
|
DefaultExtension (demoname, ".lmp");
|
||||||
v = Args->CheckValue ("-maxdemo");
|
|
||||||
maxdemosize = 0x20000;
|
maxdemosize = 0x20000;
|
||||||
demobuffer = (BYTE *)M_Malloc (maxdemosize);
|
demobuffer = (BYTE *)M_Malloc (maxdemosize);
|
||||||
|
|
||||||
demorecording = true;
|
demorecording = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2285,7 +2281,7 @@ void G_BeginRecording (const char *startmap)
|
||||||
|
|
||||||
FString defdemoname;
|
FString defdemoname;
|
||||||
|
|
||||||
void G_DeferedPlayDemo (char *name)
|
void G_DeferedPlayDemo (const char *name)
|
||||||
{
|
{
|
||||||
defdemoname = name;
|
defdemoname = name;
|
||||||
gameaction = ga_playdemo;
|
gameaction = ga_playdemo;
|
||||||
|
@ -2513,7 +2509,7 @@ void G_DoPlayDemo (void)
|
||||||
//
|
//
|
||||||
// G_TimeDemo
|
// G_TimeDemo
|
||||||
//
|
//
|
||||||
void G_TimeDemo (char* name)
|
void G_TimeDemo (const char* name)
|
||||||
{
|
{
|
||||||
nodrawers = !!Args->CheckParm ("-nodraw");
|
nodrawers = !!Args->CheckParm ("-nodraw");
|
||||||
noblit = !!Args->CheckParm ("-noblit");
|
noblit = !!Args->CheckParm ("-noblit");
|
||||||
|
|
|
@ -32,7 +32,7 @@ struct PNGHandle;
|
||||||
//
|
//
|
||||||
void G_DeathMatchSpawnPlayer (int playernum);
|
void G_DeathMatchSpawnPlayer (int playernum);
|
||||||
|
|
||||||
void G_DeferedPlayDemo (char* demo);
|
void G_DeferedPlayDemo (const char* demo);
|
||||||
|
|
||||||
// Can be called by the startup code or M_Responder,
|
// Can be called by the startup code or M_Responder,
|
||||||
// calls P_SetupLevel or W_EnterWorld.
|
// calls P_SetupLevel or W_EnterWorld.
|
||||||
|
@ -44,12 +44,12 @@ void G_DoLoadGame (void);
|
||||||
void G_SaveGame (const char *filename, const char *description);
|
void G_SaveGame (const char *filename, const char *description);
|
||||||
|
|
||||||
// Only called by startup code.
|
// Only called by startup code.
|
||||||
void G_RecordDemo (char* name);
|
void G_RecordDemo (const char* name);
|
||||||
|
|
||||||
void G_BeginRecording (const char *startmap);
|
void G_BeginRecording (const char *startmap);
|
||||||
|
|
||||||
void G_PlayDemo (char* name);
|
void G_PlayDemo (char* name);
|
||||||
void G_TimeDemo (char* name);
|
void G_TimeDemo (const char* name);
|
||||||
bool G_CheckDemoStatus (void);
|
bool G_CheckDemoStatus (void);
|
||||||
|
|
||||||
void G_WorldDone (void);
|
void G_WorldDone (void);
|
||||||
|
|
|
@ -536,13 +536,14 @@ void FGameConfigFile::ArchiveGlobalData ()
|
||||||
|
|
||||||
FString FGameConfigFile::GetConfigPath (bool tryProg)
|
FString FGameConfigFile::GetConfigPath (bool tryProg)
|
||||||
{
|
{
|
||||||
char *pathval;
|
const char *pathval;
|
||||||
FString path;
|
FString path;
|
||||||
|
|
||||||
pathval = Args->CheckValue ("-config");
|
pathval = Args->CheckValue ("-config");
|
||||||
if (pathval != NULL)
|
if (pathval != NULL)
|
||||||
|
{
|
||||||
return FString(pathval);
|
return FString(pathval);
|
||||||
|
}
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
path = NULL;
|
path = NULL;
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
|
|
@ -338,20 +338,21 @@ void PreSend (const void *buffer, int bufferlen, const sockaddr_in *to)
|
||||||
sendto (mysocket, (const char *)buffer, bufferlen, 0, (const sockaddr *)to, sizeof(*to));
|
sendto (mysocket, (const char *)buffer, bufferlen, 0, (const sockaddr *)to, sizeof(*to));
|
||||||
}
|
}
|
||||||
|
|
||||||
void BuildAddress (sockaddr_in *address, char *name)
|
void BuildAddress (sockaddr_in *address, const char *name)
|
||||||
{
|
{
|
||||||
hostent *hostentry; // host information entry
|
hostent *hostentry; // host information entry
|
||||||
u_short port;
|
u_short port;
|
||||||
char *portpart;
|
const char *portpart;
|
||||||
bool isnamed = false;
|
bool isnamed = false;
|
||||||
int curchar;
|
int curchar;
|
||||||
char c;
|
char c;
|
||||||
|
FString target;
|
||||||
|
|
||||||
address->sin_family = AF_INET;
|
address->sin_family = AF_INET;
|
||||||
|
|
||||||
if ( (portpart = strchr (name, ':')) )
|
if ( (portpart = strchr (name, ':')) )
|
||||||
{
|
{
|
||||||
*portpart = 0;
|
target = FString(name, portpart - name);
|
||||||
port = atoi (portpart + 1);
|
port = atoi (portpart + 1);
|
||||||
if (!port)
|
if (!port)
|
||||||
{
|
{
|
||||||
|
@ -361,11 +362,12 @@ void BuildAddress (sockaddr_in *address, char *name)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
target = name;
|
||||||
port = DOOMPORT;
|
port = DOOMPORT;
|
||||||
}
|
}
|
||||||
address->sin_port = htons(port);
|
address->sin_port = htons(port);
|
||||||
|
|
||||||
for (curchar = 0; (c = name[curchar]) ; curchar++)
|
for (curchar = 0; (c = target[curchar]) ; curchar++)
|
||||||
{
|
{
|
||||||
if ((c < '0' || c > '9') && c != '.')
|
if ((c < '0' || c > '9') && c != '.')
|
||||||
{
|
{
|
||||||
|
@ -376,21 +378,18 @@ void BuildAddress (sockaddr_in *address, char *name)
|
||||||
|
|
||||||
if (!isnamed)
|
if (!isnamed)
|
||||||
{
|
{
|
||||||
address->sin_addr.s_addr = inet_addr (name);
|
address->sin_addr.s_addr = inet_addr (target);
|
||||||
Printf ("Node number %d, address %s\n", doomcom.numnodes, name);
|
Printf ("Node number %d, address %s\n", doomcom.numnodes, target.GetChars());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
hostentry = gethostbyname (name);
|
hostentry = gethostbyname (target);
|
||||||
if (!hostentry)
|
if (!hostentry)
|
||||||
I_FatalError ("gethostbyname: couldn't find %s\n%s", name, neterror());
|
I_FatalError ("gethostbyname: couldn't find %s\n%s", target.GetChars(), neterror());
|
||||||
address->sin_addr.s_addr = *(int *)hostentry->h_addr_list[0];
|
address->sin_addr.s_addr = *(int *)hostentry->h_addr_list[0];
|
||||||
Printf ("Node number %d, hostname %s\n",
|
Printf ("Node number %d, hostname %s\n",
|
||||||
doomcom.numnodes, hostentry->h_name);
|
doomcom.numnodes, hostentry->h_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (portpart)
|
|
||||||
*portpart = ':';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CloseNetwork (void)
|
void CloseNetwork (void)
|
||||||
|
@ -910,7 +909,7 @@ static bool NodesOnSameNetwork()
|
||||||
bool I_InitNetwork (void)
|
bool I_InitNetwork (void)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
char *v;
|
const char *v;
|
||||||
|
|
||||||
memset (&doomcom, 0, sizeof(doomcom));
|
memset (&doomcom, 0, sizeof(doomcom));
|
||||||
|
|
||||||
|
|
278
src/m_argv.cpp
278
src/m_argv.cpp
|
@ -38,138 +38,226 @@
|
||||||
|
|
||||||
IMPLEMENT_CLASS (DArgs)
|
IMPLEMENT_CLASS (DArgs)
|
||||||
|
|
||||||
DArgs::DArgs ()
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs Default Constructor
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
DArgs::DArgs()
|
||||||
{
|
{
|
||||||
m_ArgC = 0;
|
|
||||||
m_ArgV = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DArgs::DArgs (int argc, char **argv)
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs Copy Constructor
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
DArgs::DArgs(const DArgs &other)
|
||||||
{
|
{
|
||||||
CopyArgs (argc, argv);
|
Argv = other.Argv;
|
||||||
}
|
}
|
||||||
|
|
||||||
DArgs::DArgs (const DArgs &other)
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs Argv Constructor
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
DArgs::DArgs(int argc, char **argv)
|
||||||
{
|
{
|
||||||
CopyArgs (other.m_ArgC, other.m_ArgV);
|
SetArgs(argc, argv);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs Copy Operator
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
DArgs::~DArgs ()
|
DArgs &DArgs::operator=(const DArgs &other)
|
||||||
{
|
{
|
||||||
FlushArgs ();
|
Argv = other.Argv;
|
||||||
}
|
|
||||||
|
|
||||||
DArgs &DArgs::operator= (const DArgs &other)
|
|
||||||
{
|
|
||||||
FlushArgs ();
|
|
||||||
CopyArgs (other.m_ArgC, other.m_ArgV);
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DArgs::SetArgs (int argc, char **argv)
|
//===========================================================================
|
||||||
{
|
//
|
||||||
FlushArgs ();
|
// DArgs :: SetArgs
|
||||||
CopyArgs (argc, argv);
|
//
|
||||||
}
|
//===========================================================================
|
||||||
|
|
||||||
void DArgs::CopyArgs (int argc, char **argv)
|
void DArgs::SetArgs(int argc, char **argv)
|
||||||
{
|
{
|
||||||
int i;
|
Argv.Resize(argc);
|
||||||
|
for (int i = 0; i < argc; ++i)
|
||||||
m_ArgC = argc;
|
{
|
||||||
m_ArgV = new char *[argc];
|
Argv[i] = argv[i];
|
||||||
for (i = 0; i < argc; i++)
|
}
|
||||||
m_ArgV[i] = copystring (argv[i]);
|
}
|
||||||
}
|
|
||||||
|
//===========================================================================
|
||||||
void DArgs::FlushArgs ()
|
//
|
||||||
{
|
// DArgs :: FlushArgs
|
||||||
int i;
|
//
|
||||||
|
//===========================================================================
|
||||||
for (i = 0; i < m_ArgC; i++)
|
|
||||||
delete[] m_ArgV[i];
|
void DArgs::FlushArgs()
|
||||||
delete[] m_ArgV;
|
{
|
||||||
m_ArgC = 0;
|
Argv.Clear();
|
||||||
m_ArgV = NULL;
|
}
|
||||||
}
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs :: CheckParm
|
||||||
//
|
//
|
||||||
// CheckParm
|
|
||||||
// Checks for the given parameter in the program's command line arguments.
|
// Checks for the given parameter in the program's command line arguments.
|
||||||
// Returns the argument number (1 to argc-1) or 0 if not present
|
// Returns the argument number (1 to argc-1) or 0 if not present
|
||||||
//
|
//
|
||||||
int DArgs::CheckParm (const char *check, int start) const
|
//===========================================================================
|
||||||
{
|
|
||||||
for (int i = start; i < m_ArgC; ++i)
|
|
||||||
if (!stricmp (check, m_ArgV[i]))
|
|
||||||
return i;
|
|
||||||
|
|
||||||
|
int DArgs::CheckParm(const char *check, int start) const
|
||||||
|
{
|
||||||
|
for (unsigned i = start; i < Argv.Size(); ++i)
|
||||||
|
{
|
||||||
|
if (0 == stricmp(check, Argv[i]))
|
||||||
|
{
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *DArgs::CheckValue (const char *check) const
|
//===========================================================================
|
||||||
{
|
//
|
||||||
int i = CheckParm (check);
|
// DArgs :: CheckValue
|
||||||
|
//
|
||||||
|
// Like CheckParm, but it also checks that the parameter has a value after
|
||||||
|
// it and returns that or NULL if not present.
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
if (i > 0 && i < m_ArgC - 1)
|
const char *DArgs::CheckValue(const char *check) const
|
||||||
return m_ArgV[i+1][0] != '+' && m_ArgV[i+1][0] != '-' ? m_ArgV[i+1] : NULL;
|
|
||||||
else
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *DArgs::GetArg (int arg) const
|
|
||||||
{
|
{
|
||||||
if (arg >= 0 && arg < m_ArgC)
|
int i = CheckParm(check);
|
||||||
return m_ArgV[arg];
|
|
||||||
else
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
char **DArgs::GetArgList (int arg) const
|
if (i > 0 && i < (int)Argv.Size() - 1)
|
||||||
{
|
|
||||||
if (arg >= 0 && arg < m_ArgC)
|
|
||||||
return &m_ArgV[arg];
|
|
||||||
else
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
int DArgs::NumArgs () const
|
|
||||||
{
|
|
||||||
return m_ArgC;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DArgs::AppendArg (const char *arg)
|
|
||||||
{
|
|
||||||
char **temp = new char *[m_ArgC + 1];
|
|
||||||
if (m_ArgV)
|
|
||||||
{
|
{
|
||||||
memcpy (temp, m_ArgV, sizeof(*m_ArgV) * m_ArgC);
|
i++;
|
||||||
delete[] m_ArgV;
|
return Argv[i][0] != '+' && Argv[i][0] != '-' ? Argv[i].GetChars() : NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
temp[m_ArgC] = copystring (arg);
|
|
||||||
m_ArgV = temp;
|
|
||||||
m_ArgC++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs :: TakeValue
|
||||||
|
//
|
||||||
|
// Like CheckValue, except it also removes the parameter and its argument
|
||||||
|
// (if present) from argv.
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
FString DArgs::TakeValue(const char *check)
|
||||||
|
{
|
||||||
|
int i = CheckParm(check);
|
||||||
|
FString out;
|
||||||
|
|
||||||
|
if (i > 0 && i < (int)Argv.Size() - 1 &&
|
||||||
|
Argv[i+1][0] != '+' && Argv[i+1][0] != '-')
|
||||||
|
{
|
||||||
|
out = Argv[i+1];
|
||||||
|
Argv.Delete(i, 2); // Delete the parm and its value.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Argv.Delete(i); // Just delete the parm, since it has no value.
|
||||||
|
}
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs :: GetArg
|
||||||
|
//
|
||||||
|
// Gets the argument at a particular position.
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
const char *DArgs::GetArg(int arg) const
|
||||||
|
{
|
||||||
|
return ((unsigned)arg < Argv.Size()) ? Argv[arg].GetChars() : NULL;
|
||||||
|
return Argv[arg];
|
||||||
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs :: GetArgList
|
||||||
|
//
|
||||||
|
// Returns a pointer to the FString at a particular position.
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
FString *DArgs::GetArgList(int arg) const
|
||||||
|
{
|
||||||
|
return ((unsigned)arg < Argv.Size()) ? &Argv[arg] : NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs :: NumArgs
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
int DArgs::NumArgs() const
|
||||||
|
{
|
||||||
|
return (int)Argv.Size();
|
||||||
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs :: AppendArg
|
||||||
|
//
|
||||||
|
// Adds another argument to argv. Invalidates any previous results from
|
||||||
|
// GetArgList().
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
void DArgs::AppendArg(FString arg)
|
||||||
|
{
|
||||||
|
Argv.Push(arg);
|
||||||
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// DArgs :: GatherFiles
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
DArgs *DArgs::GatherFiles (const char *param, const char *extension, bool acceptNoExt) const
|
DArgs *DArgs::GatherFiles (const char *param, const char *extension, bool acceptNoExt) const
|
||||||
{
|
{
|
||||||
DArgs *out = new DArgs;
|
DArgs *out = new DArgs;
|
||||||
int i;
|
unsigned int i;
|
||||||
size_t extlen = strlen (extension);
|
size_t extlen = strlen (extension);
|
||||||
|
|
||||||
if (extlen > 0)
|
if (extlen > 0)
|
||||||
{
|
{
|
||||||
for (i = 1; i < m_ArgC && *m_ArgV[i] != '-' && *m_ArgV[i] != '+'; i++)
|
for (i = 1; i < Argv.Size() && Argv[i][0] != '-' && Argv[i][0] != '+'; i++)
|
||||||
{
|
{
|
||||||
size_t len = strlen (m_ArgV[i]);
|
size_t len = Argv[i].Len();
|
||||||
if (len >= extlen && stricmp (m_ArgV[i] + len - extlen, extension) == 0)
|
if (len >= extlen && stricmp(&Argv[i][0] + len - extlen, extension) == 0)
|
||||||
out->AppendArg (m_ArgV[i]);
|
{
|
||||||
|
out->AppendArg(Argv[i]);
|
||||||
|
}
|
||||||
else if (acceptNoExt)
|
else if (acceptNoExt)
|
||||||
{
|
{
|
||||||
const char *src = m_ArgV[i] + len - 1;
|
const char *src = &Argv[i][0] + len - 1;
|
||||||
|
|
||||||
while (src != m_ArgV[i] && *src != '/'
|
while (src != Argv[i] && *src != '/'
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
&& *src != '\\'
|
&& *src != '\\'
|
||||||
#endif
|
#endif
|
||||||
|
@ -179,7 +267,7 @@ DArgs *DArgs::GatherFiles (const char *param, const char *extension, bool accept
|
||||||
goto morefor; // it has an extension
|
goto morefor; // it has an extension
|
||||||
src--;
|
src--;
|
||||||
}
|
}
|
||||||
out->AppendArg (m_ArgV[i]);
|
out->AppendArg(Argv[i]);
|
||||||
morefor:
|
morefor:
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
@ -190,8 +278,8 @@ morefor:
|
||||||
i = 1;
|
i = 1;
|
||||||
while (0 != (i = CheckParm (param, i)))
|
while (0 != (i = CheckParm (param, i)))
|
||||||
{
|
{
|
||||||
for (++i; i < m_ArgC && *m_ArgV[i] != '-' && *m_ArgV[i] != '+'; ++i)
|
for (++i; i < Argv.Size() && Argv[i][0] != '-' && Argv[i][0] != '+'; ++i)
|
||||||
out->AppendArg (m_ArgV[i]);
|
out->Argv.Push(Argv[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return out;
|
return out;
|
||||||
|
|
38
src/m_argv.h
38
src/m_argv.h
|
@ -35,40 +35,38 @@
|
||||||
#define __M_ARGV_H__
|
#define __M_ARGV_H__
|
||||||
|
|
||||||
#include "dobject.h"
|
#include "dobject.h"
|
||||||
|
#include "zstring.h"
|
||||||
|
|
||||||
//
|
//
|
||||||
// MISC
|
// MISC
|
||||||
//
|
//
|
||||||
class DArgs : public DObject
|
class DArgs : public DObject
|
||||||
{
|
{
|
||||||
DECLARE_CLASS (DArgs, DObject)
|
DECLARE_CLASS(DArgs, DObject)
|
||||||
public:
|
public:
|
||||||
DArgs ();
|
DArgs();
|
||||||
DArgs (const DArgs &args);
|
DArgs(const DArgs &args);
|
||||||
DArgs (int argc, char **argv);
|
DArgs(int argc, char **argv);
|
||||||
~DArgs ();
|
|
||||||
|
|
||||||
DArgs &operator= (const DArgs &other);
|
DArgs &operator=(const DArgs &other);
|
||||||
|
|
||||||
void AppendArg (const char *arg);
|
void AppendArg(FString arg);
|
||||||
void SetArgs (int argc, char **argv);
|
void SetArgs(int argc, char **argv);
|
||||||
DArgs *GatherFiles (const char *param, const char *extension, bool acceptNoExt) const;
|
DArgs *GatherFiles(const char *param, const char *extension, bool acceptNoExt) const;
|
||||||
void SetArg (int argnum, const char *arg);
|
void SetArg(int argnum, const char *arg);
|
||||||
|
|
||||||
// Returns the position of the given parameter
|
// Returns the position of the given parameter
|
||||||
// in the arg list (0 if not found).
|
// in the arg list (0 if not found).
|
||||||
int CheckParm (const char *check, int start=1) const;
|
int CheckParm(const char *check, int start=1) const;
|
||||||
char *CheckValue (const char *check) const;
|
const char *CheckValue(const char *check) const;
|
||||||
char *GetArg (int arg) const;
|
const char *GetArg(int arg) const;
|
||||||
char **GetArgList (int arg) const;
|
FString *GetArgList(int arg) const;
|
||||||
int NumArgs () const;
|
FString TakeValue(const char *check);
|
||||||
void FlushArgs ();
|
int NumArgs() const;
|
||||||
|
void FlushArgs();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int m_ArgC;
|
TArray<FString> Argv;
|
||||||
char **m_ArgV;
|
|
||||||
|
|
||||||
void CopyArgs (int argc, char **argv);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern DArgs *Args;
|
extern DArgs *Args;
|
||||||
|
|
|
@ -159,7 +159,6 @@ void M_FindResponseFile (void)
|
||||||
char **argv;
|
char **argv;
|
||||||
char *file;
|
char *file;
|
||||||
int argc;
|
int argc;
|
||||||
int argcinresp;
|
|
||||||
FILE *handle;
|
FILE *handle;
|
||||||
int size;
|
int size;
|
||||||
long argsize;
|
long argsize;
|
||||||
|
@ -183,23 +182,32 @@ void M_FindResponseFile (void)
|
||||||
file[size] = 0;
|
file[size] = 0;
|
||||||
fclose (handle);
|
fclose (handle);
|
||||||
|
|
||||||
argsize = ParseCommandLine (file, &argcinresp, NULL);
|
argsize = ParseCommandLine (file, &argc, NULL);
|
||||||
argc = argcinresp + Args->NumArgs() - 1;
|
argc = Args->NumArgs() - 1;
|
||||||
|
|
||||||
if (argc != 0)
|
if (argc != 0)
|
||||||
{
|
{
|
||||||
argv = (char **)M_Malloc (argc*sizeof(char *) + argsize);
|
argv = (char **)M_Malloc (argc*sizeof(char *) + argsize);
|
||||||
argv[i] = (char *)argv + argc*sizeof(char *);
|
argv[0] = (char *)argv + argc*sizeof(char *);
|
||||||
ParseCommandLine (file, NULL, argv+i);
|
ParseCommandLine (file, NULL, argv);
|
||||||
|
|
||||||
|
// Create a new argument vector
|
||||||
|
DArgs *newargs = new DArgs;
|
||||||
|
|
||||||
|
// Copy parameters before response file.
|
||||||
for (index = 0; index < i; ++index)
|
for (index = 0; index < i; ++index)
|
||||||
argv[index] = Args->GetArg (index);
|
newargs->AppendArg(Args->GetArg(index));
|
||||||
|
|
||||||
for (index = i + 1, i += argcinresp; index < Args->NumArgs (); ++index)
|
// Copy parameters from response file.
|
||||||
argv[i++] = Args->GetArg (index);
|
for (index = 0; index < argc; ++i)
|
||||||
|
newargs->AppendArg(argv[index]);
|
||||||
|
|
||||||
Args->Destroy();
|
// Copy parameters after response file.
|
||||||
Args = new DArgs(i, argv);
|
for (index = i + 1, i = newargs->NumArgs(); index < Args->NumArgs(); ++index)
|
||||||
|
newargs->AppendArg(Args->GetArg(index));
|
||||||
|
|
||||||
|
// Use the new argument vector as the global Args object.
|
||||||
|
Args = newargs;
|
||||||
}
|
}
|
||||||
|
|
||||||
delete[] file;
|
delete[] file;
|
||||||
|
|
|
@ -2345,7 +2345,7 @@ CUSTOM_CVAR( Int, r_maxparticles, 4000, CVAR_ARCHIVE )
|
||||||
|
|
||||||
void R_InitParticles ()
|
void R_InitParticles ()
|
||||||
{
|
{
|
||||||
char *i;
|
const char *i;
|
||||||
|
|
||||||
if ((i = Args->CheckValue ("-numparticles")))
|
if ((i = Args->CheckValue ("-numparticles")))
|
||||||
NumParticles = atoi (i);
|
NumParticles = atoi (i);
|
||||||
|
|
|
@ -1523,7 +1523,7 @@ CCMD (vid_setmode)
|
||||||
|
|
||||||
void V_Init (void)
|
void V_Init (void)
|
||||||
{
|
{
|
||||||
char *i;
|
const char *i;
|
||||||
int width, height, bits;
|
int width, height, bits;
|
||||||
|
|
||||||
atterm (V_Shutdown);
|
atterm (V_Shutdown);
|
||||||
|
|
|
@ -233,7 +233,7 @@ static void I_SelectTimer()
|
||||||
if (NewTicArrived)
|
if (NewTicArrived)
|
||||||
{
|
{
|
||||||
UINT delay;
|
UINT delay;
|
||||||
char *cmdDelay;
|
const char *cmdDelay;
|
||||||
|
|
||||||
cmdDelay = Args->CheckValue("-timerdelay");
|
cmdDelay = Args->CheckValue("-timerdelay");
|
||||||
delay = 0;
|
delay = 0;
|
||||||
|
|
Loading…
Reference in a new issue