diff options
author | Yehonal <yehonal.azeroth@gmail.com> | 2017-12-20 20:48:35 +0100 |
---|---|---|
committer | Yehonal <yehonal.azeroth@gmail.com> | 2017-12-21 00:20:29 +0100 |
commit | 17332304fdf129076d0196010602350d5750c808 (patch) | |
tree | d161f8845df9e5c8ec0b149bd846646c2b112d49 /src/common/Configuration/Config.cpp | |
parent | 0fc4a6a153ca3a09ccb6e1311131b12a59c6cba3 (diff) |
Using TC structure allowing easier patches importing
Diffstat (limited to 'src/common/Configuration/Config.cpp')
-rw-r--r-- | src/common/Configuration/Config.cpp | 145 |
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; +} |