2006-04-24 01:14:18 +02:00
|
|
|
#include "precompiled.h"
|
|
|
|
|
|
|
|
#include "ps/CLogger.h"
|
|
|
|
#include "ps/ConfigDB.h"
|
|
|
|
#include "ps/CConsole.h"
|
2006-12-09 15:39:52 +01:00
|
|
|
#include "ps/GameSetup/CmdLineArgs.h"
|
2006-04-24 01:14:18 +02:00
|
|
|
#include "lib/timer.h"
|
|
|
|
#include "lib/res/sound/snd_mgr.h"
|
2007-10-06 09:45:15 +02:00
|
|
|
#include "lib/res/file/archive/trace.h"
|
2006-04-26 19:08:08 +02:00
|
|
|
#include "lib/res/file/vfs.h"
|
2007-10-06 09:45:15 +02:00
|
|
|
#include "lib/res/file/archive/vfs_optimizer.h"
|
2006-04-24 01:14:18 +02:00
|
|
|
#include "Config.h"
|
|
|
|
|
|
|
|
#define LOG_CATEGORY "config"
|
|
|
|
|
2007-09-02 23:44:56 +02:00
|
|
|
|
|
|
|
// (these variables are documented in the header.)
|
|
|
|
|
2006-04-24 01:14:18 +02:00
|
|
|
CStr g_CursorName = "test";
|
|
|
|
CStr g_ActiveProfile = "default";
|
|
|
|
|
2007-09-02 23:44:56 +02:00
|
|
|
bool g_NoGLS3TC = false;
|
|
|
|
bool g_NoGLAutoMipmap = false;
|
|
|
|
bool g_NoGLVBO = false;
|
2006-04-24 01:14:18 +02:00
|
|
|
bool g_NoGLFramebufferObject = false;
|
2007-09-02 23:44:56 +02:00
|
|
|
|
|
|
|
bool g_Shadows = false;
|
|
|
|
bool g_FancyWater = false;
|
|
|
|
|
|
|
|
bool g_FixedFrameTiming = false;
|
|
|
|
|
2006-04-24 01:14:18 +02:00
|
|
|
float g_LodBias = 0.0f;
|
|
|
|
float g_Gamma = 1.0f;
|
2007-09-02 23:44:56 +02:00
|
|
|
|
2006-04-24 01:14:18 +02:00
|
|
|
bool g_EntGraph = false;
|
|
|
|
CStr g_RenderPath = "default";
|
|
|
|
|
|
|
|
int g_xres, g_yres;
|
|
|
|
int g_bpp;
|
|
|
|
int g_freq;
|
2007-09-02 23:44:56 +02:00
|
|
|
bool g_VSync = false;
|
2006-04-24 01:14:18 +02:00
|
|
|
|
2007-09-02 23:44:56 +02:00
|
|
|
bool g_Quickstart = false;
|
2006-04-24 01:14:18 +02:00
|
|
|
|
2007-10-09 09:27:45 +02:00
|
|
|
// flag to switch on drawing terrain overlays
|
|
|
|
bool g_showOverlay = false;
|
|
|
|
|
|
|
|
// If non-empty, specified map will be automatically loaded
|
2006-04-24 01:14:18 +02:00
|
|
|
CStr g_AutostartMap = "";
|
|
|
|
|
2007-09-02 23:44:56 +02:00
|
|
|
|
2006-04-24 01:14:18 +02:00
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
// config and profile
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
|
2006-07-20 16:37:58 +02:00
|
|
|
static void LoadProfile( const CStr& profile )
|
2006-04-24 01:14:18 +02:00
|
|
|
{
|
|
|
|
CStr base = CStr( "profiles/" ) + profile;
|
|
|
|
g_ConfigDB.SetConfigFile(CFG_USER, true, base + "/settings/user.cfg");
|
|
|
|
g_ConfigDB.Reload(CFG_USER);
|
|
|
|
|
2006-05-16 06:41:37 +02:00
|
|
|
int max_history_lines = 200;
|
2006-04-24 01:14:18 +02:00
|
|
|
CFG_GET_USER_VAL("console.history.size", Int, max_history_lines);
|
|
|
|
g_Console->UseHistoryFile(base+"/settings/history", max_history_lines);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Fill in the globals from the config files.
|
|
|
|
static void LoadGlobals()
|
|
|
|
{
|
|
|
|
CFG_GET_SYS_VAL("profile", String, g_ActiveProfile);
|
|
|
|
|
|
|
|
// Now load the profile before trying to retrieve the values of the rest of these.
|
|
|
|
|
|
|
|
LoadProfile( g_ActiveProfile );
|
|
|
|
|
|
|
|
CFG_GET_USER_VAL("xres", Int, g_xres);
|
|
|
|
CFG_GET_USER_VAL("yres", Int, g_yres);
|
|
|
|
CFG_GET_USER_VAL("vsync", Bool, g_VSync);
|
2007-09-02 23:44:56 +02:00
|
|
|
|
|
|
|
CFG_GET_USER_VAL("nos3tc", Bool, g_NoGLS3TC);
|
|
|
|
CFG_GET_USER_VAL("noautomipmap", Bool, g_NoGLAutoMipmap);
|
2006-04-24 01:14:18 +02:00
|
|
|
CFG_GET_USER_VAL("novbo", Bool, g_NoGLVBO);
|
|
|
|
CFG_GET_USER_VAL("noframebufferobject", Bool, g_NoGLFramebufferObject);
|
|
|
|
CFG_GET_USER_VAL("shadows", Bool, g_Shadows);
|
2006-05-17 05:53:54 +02:00
|
|
|
CFG_GET_USER_VAL("fancywater", Bool, g_FancyWater);
|
2006-04-24 01:14:18 +02:00
|
|
|
CFG_GET_USER_VAL("renderpath", String, g_RenderPath);
|
|
|
|
|
|
|
|
CFG_GET_USER_VAL("lodbias", Float, g_LodBias);
|
|
|
|
|
|
|
|
float gain = -1.0f;
|
|
|
|
CFG_GET_USER_VAL("sound.mastergain", Float, gain);
|
|
|
|
if(gain > 0.0f)
|
|
|
|
WARN_ERR(snd_set_master_gain(gain));
|
|
|
|
|
|
|
|
LOG(NORMAL, LOG_CATEGORY, "g_x/yres is %dx%d", g_xres, g_yres);
|
|
|
|
LOG(NORMAL, LOG_CATEGORY, "Active profile is %s", g_ActiveProfile.c_str());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-12-09 15:39:52 +01:00
|
|
|
static void ProcessCommandLineArgs(const CmdLineArgs& args)
|
2006-04-24 01:14:18 +02:00
|
|
|
{
|
2006-12-09 15:39:52 +01:00
|
|
|
// TODO: all these options (and the ones processed elsewhere) should
|
|
|
|
// be documented somewhere for users.
|
|
|
|
|
|
|
|
if (args.Has("autostart"))
|
|
|
|
g_AutostartMap = args.Get("autostart");
|
2006-04-24 01:14:18 +02:00
|
|
|
|
2006-12-09 15:39:52 +01:00
|
|
|
if (args.Has("buildarchive"))
|
|
|
|
{
|
|
|
|
// note: VFS init is sure to have been completed by now
|
|
|
|
// (since CONFIG_Init reads from file); therefore,
|
|
|
|
// it is safe to call this from here directly.
|
|
|
|
vfs_opt_rebuild_main_archive("mods/official/official1.zip", "../logs/trace.txt");
|
|
|
|
}
|
2006-04-24 01:14:18 +02:00
|
|
|
|
2006-12-09 15:39:52 +01:00
|
|
|
// Handle "-conf=key:value" (potentially multiple times)
|
|
|
|
std::vector<CStr> conf = args.GetMultiple("conf");
|
|
|
|
for (size_t i = 0; i < conf.size(); ++i)
|
|
|
|
{
|
|
|
|
CStr name_value = conf[i];
|
|
|
|
if (name_value.Find(':') != -1)
|
2006-04-24 01:14:18 +02:00
|
|
|
{
|
2006-12-09 15:39:52 +01:00
|
|
|
CStr name = name_value.BeforeFirst(":");
|
|
|
|
CStr value = name_value.AfterFirst(":");
|
|
|
|
g_ConfigDB.CreateValue(CFG_COMMAND, name)->m_String = value;
|
|
|
|
}
|
2006-04-24 01:14:18 +02:00
|
|
|
}
|
2006-12-09 15:39:52 +01:00
|
|
|
|
|
|
|
if (args.Has("entgraph"))
|
|
|
|
g_EntGraph = true;
|
|
|
|
|
|
|
|
if (args.Has("fixedframe"))
|
|
|
|
g_FixedFrameTiming = true;
|
|
|
|
|
|
|
|
if (args.Has("g"))
|
|
|
|
{
|
|
|
|
g_Gamma = (float)atof(args.Get("g"));
|
|
|
|
if (g_Gamma == 0.0f)
|
|
|
|
g_Gamma = 1.0f;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (args.Has("listfiles"))
|
|
|
|
trace_enable(true);
|
|
|
|
|
|
|
|
if (args.Has("profile"))
|
|
|
|
g_ConfigDB.CreateValue(CFG_COMMAND, "profile")->m_String = args.Get("profile");
|
|
|
|
|
|
|
|
if (args.Has("quickstart"))
|
|
|
|
g_Quickstart = true;
|
|
|
|
|
|
|
|
if (args.Has("shadows"))
|
|
|
|
g_ConfigDB.CreateValue(CFG_COMMAND, "shadows")->m_String = "true";
|
|
|
|
|
|
|
|
if (args.Has("xres"))
|
|
|
|
g_ConfigDB.CreateValue(CFG_COMMAND, "xres")->m_String = args.Get("xres");
|
|
|
|
|
|
|
|
if (args.Has("yres"))
|
|
|
|
g_ConfigDB.CreateValue(CFG_COMMAND, "yres")->m_String = args.Get("yres");
|
2007-09-02 23:44:56 +02:00
|
|
|
|
|
|
|
if (args.Has("vsync"))
|
|
|
|
g_ConfigDB.CreateValue(CFG_COMMAND, "vsync")->m_String = "true";
|
2007-10-09 09:27:45 +02:00
|
|
|
|
|
|
|
if (args.Has("showOverlay"))
|
|
|
|
g_showOverlay = true;
|
2006-04-24 01:14:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-12-09 15:39:52 +01:00
|
|
|
void CONFIG_Init(const CmdLineArgs& args)
|
2006-04-24 01:14:18 +02:00
|
|
|
{
|
|
|
|
TIMER("CONFIG_Init");
|
|
|
|
MICROLOG(L"init config");
|
|
|
|
|
|
|
|
new CConfigDB;
|
|
|
|
|
|
|
|
g_ConfigDB.SetConfigFile(CFG_SYSTEM, false, "config/system.cfg");
|
2006-06-26 14:47:23 +02:00
|
|
|
g_ConfigDB.Reload(CFG_SYSTEM); // 216ms
|
2006-04-24 01:14:18 +02:00
|
|
|
|
|
|
|
g_ConfigDB.SetConfigFile(CFG_MOD, true, "config/mod.cfg");
|
|
|
|
// No point in reloading mod.cfg here - we haven't mounted mods yet
|
|
|
|
|
2006-12-09 15:39:52 +01:00
|
|
|
ProcessCommandLineArgs(args);
|
2006-04-24 01:14:18 +02:00
|
|
|
|
|
|
|
// Collect information from system.cfg, the profile file,
|
|
|
|
// and any command-line overrides to fill in the globals.
|
2006-06-26 14:47:23 +02:00
|
|
|
LoadGlobals(); // 64ms
|
2006-04-24 01:14:18 +02:00
|
|
|
}
|