summaryrefslogtreecommitdiff
path: root/src/common/Configuration/Config.cpp
diff options
context:
space:
mode:
authorYehonal <yehonal.azeroth@gmail.com>2017-12-20 20:48:35 +0100
committerYehonal <yehonal.azeroth@gmail.com>2017-12-21 00:20:29 +0100
commit17332304fdf129076d0196010602350d5750c808 (patch)
treed161f8845df9e5c8ec0b149bd846646c2b112d49 /src/common/Configuration/Config.cpp
parent0fc4a6a153ca3a09ccb6e1311131b12a59c6cba3 (diff)
Using TC structure allowing easier patches importing
Diffstat (limited to 'src/common/Configuration/Config.cpp')
-rw-r--r--src/common/Configuration/Config.cpp145
1 files changed, 145 insertions, 0 deletions
diff --git a/src/common/Configuration/Config.cpp b/src/common/Configuration/Config.cpp
new file mode 100644
index 0000000000..e467fc3697
--- /dev/null
+++ b/src/common/Configuration/Config.cpp
@@ -0,0 +1,145 @@
+/*
+ * Copyright (C) 2016+ AzerothCore <www.azerothcore.org>, released under GNU GPL v2 license: http://github.com/azerothcore/azerothcore-wotlk/LICENSE-GPL2
+ * Copyright (C) 2008-2016 TrinityCore <http://www.trinitycore.org/>
+ * Copyright (C) 2005-2009 MaNGOS <http://getmangos.com/>
+ */
+
+#include "Config.h"
+#include "Errors.h"
+
+// Defined here as it must not be exposed to end-users.
+bool ConfigMgr::GetValueHelper(const char* name, ACE_TString &result)
+{
+ GuardType guard(_configLock);
+
+ if (_config.get() == 0)
+ return false;
+
+ ACE_TString section_name;
+ ACE_Configuration_Section_Key section_key;
+ const ACE_Configuration_Section_Key &root_key = _config->root_section();
+
+ int i = 0;
+ while (_config->enumerate_sections(root_key, i, section_name) == 0)
+ {
+ _config->open_section(root_key, section_name.c_str(), 0, section_key);
+ if (_config->get_string_value(section_key, name, result) == 0)
+ return true;
+ ++i;
+ }
+
+ return false;
+}
+
+bool ConfigMgr::LoadInitial(char const* file)
+{
+ ASSERT(file);
+
+ GuardType guard(_configLock);
+
+ _config.reset(new ACE_Configuration_Heap());
+ if (_config->open() == 0)
+ if (LoadData(file))
+ return true;
+
+ _config.reset();
+ return false;
+}
+
+bool ConfigMgr::LoadMore(char const* file)
+{
+ ASSERT(file);
+ ASSERT(_config);
+
+ GuardType guard(_configLock);
+
+ return LoadData(file);
+}
+
+bool ConfigMgr::Reload()
+{
+ for(std::vector<std::string>::iterator it = _confFiles.begin(); it != _confFiles.end(); ++it) {
+ if (it==_confFiles.begin()) {
+ if (!LoadInitial((*it).c_str()))
+ return false;
+ } else {
+ LoadMore((*it).c_str());
+ }
+ }
+
+ return true;
+}
+
+bool ConfigMgr::LoadData(char const* file)
+{
+ if(std::find(_confFiles.begin(), _confFiles.end(), file) == _confFiles.end()) {
+ _confFiles.push_back(file);
+ }
+
+ ACE_Ini_ImpExp config_importer(*_config.get());
+ if (config_importer.import_config(file) == 0)
+ return true;
+
+ return false;
+}
+
+std::string ConfigMgr::GetStringDefault(const char* name, const std::string &def)
+{
+ ACE_TString val;
+ return GetValueHelper(name, val) ? val.c_str() : def;
+}
+
+bool ConfigMgr::GetBoolDefault(const char* name, bool def)
+{
+ ACE_TString val;
+
+ if (!GetValueHelper(name, val))
+ return def;
+
+ return (val == "true" || val == "TRUE" || val == "yes" || val == "YES" ||
+ val == "1");
+}
+
+int ConfigMgr::GetIntDefault(const char* name, int def)
+{
+ ACE_TString val;
+ return GetValueHelper(name, val) ? atoi(val.c_str()) : def;
+}
+
+float ConfigMgr::GetFloatDefault(const char* name, float def)
+{
+ ACE_TString val;
+ return GetValueHelper(name, val) ? (float)atof(val.c_str()) : def;
+}
+
+std::list<std::string> ConfigMgr::GetKeysByString(std::string const& name)
+{
+ GuardType guard(_configLock);
+
+ std::list<std::string> keys;
+ if (_config.get() == 0)
+ return keys;
+
+ ACE_TString section_name;
+ ACE_Configuration_Section_Key section_key;
+ const ACE_Configuration_Section_Key &root_key = _config->root_section();
+
+ int i = 0;
+ while (_config->enumerate_sections(root_key, i++, section_name) == 0)
+ {
+ _config->open_section(root_key, section_name.c_str(), 0, section_key);
+
+ ACE_TString key_name;
+ ACE_Configuration::VALUETYPE type;
+ int j = 0;
+ while (_config->enumerate_values(section_key, j++, key_name, type) == 0)
+ {
+ std::string temp = key_name.c_str();
+
+ if (!temp.find(name))
+ keys.push_back(temp);
+ }
+ }
+
+ return keys;
+}