27 namespace po = boost::program_options;
30 namespace Configuration {
36 auto& manager_ptr = manager_map[id];
37 if (manager_ptr ==
nullptr) {
50 if (config_pair.second.find(root) != config_pair.second.end()) {
53 for (
auto& config : config_pair.second) {
57 for (
auto& type : found) {
68 logger.
debug() <<
"Cleaning dependencies of unregistered configurations...";
70 for (
auto& pair : dep_map) {
71 if (dict.find(pair.first) == dict.end()) {
76 for (
auto& value : pair.second) {
77 if (dict.find(value) == dict.end()) {
81 for (
auto& to_remove : unregistered_values) {
82 logger.
info() <<
"Removing configuration dependency " << pair.first.name() <<
" -> " << to_remove.name();
83 pair.second.erase(to_remove);
86 for (
auto& to_remove : unregistered_keys) {
87 for (
auto& value : dep_map.at(to_remove)) {
88 logger.
info() <<
"Removing configuration dependency " << to_remove.name() <<
" -> " << value.name();
90 dep_map.erase(to_remove);
99 m_dependency_map[pair.first].
insert(pair.second->getDependencies().begin(), pair.second->getDependencies().end());
106 for (
auto& pair : m_config_dictionary) {
108 if (!found.empty()) {
109 logger.
error() <<
"Found circular dependency between configurations:";
111 logger.
error() <<
" " << ++count <<
" : " << pair.first.name();
112 for (
auto& type : found) {
113 logger.
error() <<
" " << ++count <<
" : " << type.name();
120 for (
auto& config : m_config_dictionary) {
121 for (
auto& pair : config.second->getProgramOptions()) {
122 if (all_options.find(pair.first) == all_options.end()) {
124 all_options.
emplace(pair.first, po::options_description{pair.first});
126 auto& group = all_options.at(pair.first);
127 for (
auto& option : pair.second) {
128 group.add(boost::shared_ptr<po::option_description>{
new po::option_description{option}});
133 po::options_description result{};
134 for (
auto& pair : all_options) {
135 result.add(pair.second);
145 if (dictionary.at(config)->getCurrentState() >= Configuration::State::INITIALIZED) {
149 for (
auto& dependency : dependency_map.at(config)) {
153 dictionary.at(config)->initialize(user_values);
154 dictionary.at(config)->getCurrentState() = Configuration::State::INITIALIZED;
158 m_state = State::INITIALIZED;
159 for (
auto& pair : m_config_dictionary) {
160 logger.
debug() <<
"Pre-Initializing configuration :" << pair.first.name();
161 pair.second->preInitialize(user_values);
162 pair.second->getCurrentState() = Configuration::State::PRE_INITIALIZED;
164 for (
auto& pair : m_config_dictionary) {
165 logger.
debug() <<
"Initializing configuration :" << pair.first.name();
168 for (
auto& pair : m_config_dictionary) {
169 logger.
debug() <<
"Post-Initializing configuration :" << pair.first.name();
170 pair.second->postInitialize(user_values);
171 pair.second->getCurrentState() = Configuration::State::FINAL;
static void recursiveInitialization(const std::map< std::type_index, std::unique_ptr< Configuration >> &dictionary, const std::map< std::type_index, std::set< std::type_index >> &dependency_map, const std::map< std::string, po::variable_value > &user_values, const std::type_index &config)
std::map< std::type_index, std::set< std::type_index > > m_dependency_map
static ConfigManager & getInstance(long id)
Returns a reference to the ConfigManager with the given ID.
static void cleanupNonRegisteredDependencies(std::map< std::type_index, std::set< std::type_index >> &dep_map, const std::map< std::type_index, std::unique_ptr< Configuration >> &dict)
void info(const std::string &logMessage)
void debug(const std::string &logMessage)
static Elements::Logging logger
Logger.
static Elements::Logging logger
Manages a set of configuration classes.
boost::program_options::options_description closeRegistration()
Terminates the manager registration phase.
std::vector< std::type_index > hasCircularDependencies(const std::map< std::type_index, std::set< std::type_index >> &dependency_map, const std::type_index &root, const std::pair< const std::type_index, std::set< std::type_index >> &config_pair)
void error(const std::string &logMessage)
static Logging getLogger(const std::string &name="")
std::map< std::type_index, std::unique_ptr< Configuration > > m_config_dictionary