You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
119 lines
3.2 KiB
119 lines
3.2 KiB
//========= Copyright Valve Corporation, All rights reserved. ============//
|
|
//
|
|
// Purpose: loads additional command line options from a config file
|
|
//
|
|
// $NoKeywords: $
|
|
//=============================================================================//
|
|
|
|
#include "KeyValues.h"
|
|
#include "tier1/strtools.h"
|
|
#include "FileSystem_Tools.h"
|
|
#include "tier1/utlstring.h"
|
|
|
|
// So we know whether or not we own argv's memory
|
|
static bool sFoundConfigArgs = false;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Parses arguments and adds them to argv and argc
|
|
//-----------------------------------------------------------------------------
|
|
static void AddArguments( int &argc, char **&argv, const char *str )
|
|
{
|
|
char **args = 0;
|
|
char *argList = 0;
|
|
int argCt = argc;
|
|
|
|
argList = V_strdup( str );
|
|
|
|
// Parse the arguments out of the string
|
|
char *token = strtok( argList, " " );
|
|
while( token )
|
|
{
|
|
++argCt;
|
|
token = strtok( NULL, " " );
|
|
}
|
|
|
|
// Make sure someting was actually found in the file
|
|
if( argCt > argc )
|
|
{
|
|
sFoundConfigArgs = true;
|
|
|
|
// Allocate a new array for argv
|
|
args = new char*[ argCt ];
|
|
|
|
// Copy original arguments, up to the last one
|
|
int i;
|
|
for( i = 0; i < argc - 1; ++i )
|
|
{
|
|
args[ i ] = V_strdup( argv[ i ] );
|
|
}
|
|
|
|
// copy new arguments
|
|
Q_strcpy( argList, str );
|
|
token = strtok( argList, " " );
|
|
for( ; i < argCt - 1; ++i )
|
|
{
|
|
args[ i ] = V_strdup( token );
|
|
token = strtok( NULL, " " );
|
|
}
|
|
|
|
// Copy the last original argument
|
|
args[ i ] = V_strdup( argv[ argc - 1 ] );
|
|
|
|
argc = argCt;
|
|
argv = args;
|
|
}
|
|
|
|
delete [] argList;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Loads additional commandline arguments from a config file for an app.
|
|
// Filesystem must be initialized before calling this function.
|
|
// keyname: Name of the block containing the key/args pairs (ie map or model name)
|
|
// appname: Keyname for the commandline arguments to be loaded - typically the exe name.
|
|
//-----------------------------------------------------------------------------
|
|
void LoadCmdLineFromFile( int &argc, char **&argv, const char *keyname, const char *appname )
|
|
{
|
|
sFoundConfigArgs = false;
|
|
|
|
assert( g_pFileSystem );
|
|
if( !g_pFileSystem )
|
|
return;
|
|
|
|
// Load the cfg file, and find the keyname
|
|
KeyValues *kv = new KeyValues( "CommandLine" );
|
|
|
|
char filename[512];
|
|
Q_snprintf( filename, sizeof( filename ), "%s/cfg/commandline.cfg", gamedir );
|
|
|
|
if ( kv->LoadFromFile( g_pFileSystem, filename ) )
|
|
{
|
|
// Load the commandline arguments for this app
|
|
KeyValues *appKey = kv->FindKey( keyname );
|
|
if( appKey )
|
|
{
|
|
const char *str = appKey->GetString( appname );
|
|
Msg( "Command Line found: %s\n", str );
|
|
|
|
AddArguments( argc, argv, str );
|
|
}
|
|
}
|
|
|
|
kv->deleteThis();
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Purpose: Cleans up any memory allocated for the new argv. Pass in the app's
|
|
// argc and argv - this is safe even if no extra arguments were loaded.
|
|
//-----------------------------------------------------------------------------
|
|
void DeleteCmdLine( int argc, char **argv )
|
|
{
|
|
if( !sFoundConfigArgs )
|
|
return;
|
|
|
|
for( int i = 0; i < argc; ++i )
|
|
{
|
|
delete [] argv[i];
|
|
}
|
|
delete [] argv;
|
|
}
|