[Base/Core] Add support for transient cvars.

This commit is contained in:
gibbed 2019-08-04 02:12:46 -05:00
parent 9a9a55aa49
commit 7ba460552c
2 changed files with 34 additions and 17 deletions

View File

@ -20,6 +20,7 @@ class ICommandVar {
class IConfigVar : virtual public ICommandVar { class IConfigVar : virtual public ICommandVar {
public: public:
virtual std::string GetCategory() = 0; virtual std::string GetCategory() = 0;
virtual bool GetIsTransient() = 0;
virtual std::string GetConfigValue() = 0; virtual std::string GetConfigValue() = 0;
virtual void LoadConfigValue(std::shared_ptr<cpptoml::base> result) = 0; virtual void LoadConfigValue(std::shared_ptr<cpptoml::base> result) = 0;
virtual void LoadGameConfigValue(std::shared_ptr<cpptoml::base> result) = 0; virtual void LoadGameConfigValue(std::shared_ptr<cpptoml::base> result) = 0;
@ -53,9 +54,10 @@ template <class T>
class ConfigVar : public CommandVar<T>, virtual public IConfigVar { class ConfigVar : public CommandVar<T>, virtual public IConfigVar {
public: public:
ConfigVar<T>(const char* name, T* defaultValue, const char* description, ConfigVar<T>(const char* name, T* defaultValue, const char* description,
const char* category); const char* category, bool is_transient);
std::string GetConfigValue() override; std::string GetConfigValue() override;
std::string GetCategory() override; std::string GetCategory() override;
bool GetIsTransient() override;
void AddToLaunchOptions(cxxopts::Options* options) override; void AddToLaunchOptions(cxxopts::Options* options) override;
void LoadConfigValue(std::shared_ptr<cpptoml::base> result) override; void LoadConfigValue(std::shared_ptr<cpptoml::base> result) override;
void LoadGameConfigValue(std::shared_ptr<cpptoml::base> result) override; void LoadGameConfigValue(std::shared_ptr<cpptoml::base> result) override;
@ -64,6 +66,7 @@ class ConfigVar : public CommandVar<T>, virtual public IConfigVar {
private: private:
std::string category_; std::string category_;
bool is_transient_;
std::unique_ptr<T> configValue_ = nullptr; std::unique_ptr<T> configValue_ = nullptr;
std::unique_ptr<T> gameConfigValue_ = nullptr; std::unique_ptr<T> gameConfigValue_ = nullptr;
void UpdateValue() override; void UpdateValue() override;
@ -110,8 +113,11 @@ CommandVar<T>::CommandVar(const char* name, T* defaultValue,
template <class T> template <class T>
ConfigVar<T>::ConfigVar(const char* name, T* defaultValue, ConfigVar<T>::ConfigVar(const char* name, T* defaultValue,
const char* description, const char* category) const char* description, const char* category,
: CommandVar<T>(name, defaultValue, description), category_(category) {} bool is_transient)
: CommandVar<T>(name, defaultValue, description),
category_(category),
is_transient_(is_transient) {}
template <class T> template <class T>
void CommandVar<T>::UpdateValue() { void CommandVar<T>::UpdateValue() {
@ -157,6 +163,10 @@ std::string ConfigVar<T>::GetCategory() {
return category_; return category_;
} }
template <class T> template <class T>
bool ConfigVar<T>::GetIsTransient() {
return is_transient_;
}
template <class T>
std::string ConfigVar<T>::GetConfigValue() { std::string ConfigVar<T>::GetConfigValue() {
if (this->configValue_) return this->ToString(*this->configValue_); if (this->configValue_) return this->ToString(*this->configValue_);
return this->ToString(this->defaultValue_); return this->ToString(this->defaultValue_);
@ -192,9 +202,9 @@ void ParseLaunchArguments(int argc, char** argv);
template <typename T> template <typename T>
T* define_configvar(const char* name, T* defaultValue, const char* description, T* define_configvar(const char* name, T* defaultValue, const char* description,
const char* category) { const char* category, bool is_transient) {
IConfigVar* cfgVar = IConfigVar* cfgVar =
new ConfigVar<T>(name, defaultValue, description, category); new ConfigVar<T>(name, defaultValue, description, category, is_transient);
AddConfigVar(cfgVar); AddConfigVar(cfgVar);
return defaultValue; return defaultValue;
} }
@ -206,27 +216,31 @@ T* define_cmdvar(const char* name, T* defaultValue, const char* description) {
return defaultValue; return defaultValue;
} }
#define DEFINE_double(name, defaultValue, description, category) \ #define DEFINE_double(name, defaultValue, description, category) \
DEFINE_CVar(name, defaultValue, description, category, double) DEFINE_CVar(name, defaultValue, description, category, false, double)
#define DEFINE_int32(name, defaultValue, description, category) \ #define DEFINE_int32(name, defaultValue, description, category) \
DEFINE_CVar(name, defaultValue, description, category, int32_t) DEFINE_CVar(name, defaultValue, description, category, false, int32_t)
#define DEFINE_uint64(name, defaultValue, description, category) \ #define DEFINE_uint64(name, defaultValue, description, category) \
DEFINE_CVar(name, defaultValue, description, category, uint64_t) DEFINE_CVar(name, defaultValue, description, category, false, uint64_t)
#define DEFINE_string(name, defaultValue, description, category) \ #define DEFINE_string(name, defaultValue, description, category) \
DEFINE_CVar(name, defaultValue, description, category, std::string) DEFINE_CVar(name, defaultValue, description, category, false, std::string)
#define DEFINE_transient_string(name, defaultValue, description, category) \
DEFINE_CVar(name, defaultValue, description, category, true, std::string)
#define DEFINE_bool(name, defaultValue, description, category) \ #define DEFINE_bool(name, defaultValue, description, category) \
DEFINE_CVar(name, defaultValue, description, category, bool) DEFINE_CVar(name, defaultValue, description, category, false, bool)
#define DEFINE_CVar(name, defaultValue, description, category, type) \ #define DEFINE_CVar(name, defaultValue, description, category, is_transient, \
type) \
namespace cvars { \ namespace cvars { \
type name = defaultValue; \ type name = defaultValue; \
} \ } \
namespace cv { \ namespace cv { \
static auto cv_##name = \ static auto cv_##name = cvar::define_configvar( \
cvar::define_configvar(#name, &cvars::name, description, category); \ #name, &cvars::name, description, category, is_transient); \
} }
// CmdVars can only be strings for now, we don't need any others // CmdVars can only be strings for now, we don't need any others

View File

@ -61,6 +61,9 @@ void SaveConfig() {
std::ostringstream output; std::ostringstream output;
std::string lastCategory; std::string lastCategory;
for (auto configVar : vars) { for (auto configVar : vars) {
if (configVar->GetIsTransient()) {
continue;
}
if (lastCategory != configVar->GetCategory()) { if (lastCategory != configVar->GetCategory()) {
if (!lastCategory.empty()) { if (!lastCategory.empty()) {
output << std::endl; output << std::endl;