configuration: initialize undefined variables after all files were parsed
This commit is contained in:
@@ -66,6 +66,11 @@ bool option_parser::run(std::istream &is)
|
||||
}
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
bool option_parser::initialize_undefined()
|
||||
{
|
||||
for (auto &p : m_parsers)
|
||||
{
|
||||
if (!p.second.defined())
|
||||
@@ -73,7 +78,7 @@ bool option_parser::run(std::istream &is)
|
||||
try {
|
||||
p.second.run_default();
|
||||
} catch (std::exception &e) {
|
||||
std::cerr << "Error while finalizing option \"" << p.first << "\": " << e.what() << "\n";
|
||||
std::cerr << "Error while initializing option \"" << p.first << "\": " << e.what() << "\n";
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -140,6 +140,7 @@ struct option_parser
|
||||
}
|
||||
|
||||
bool run(std::istream &is);
|
||||
bool initialize_undefined();
|
||||
|
||||
private:
|
||||
std::unordered_map<std::string, worker> m_parsers;
|
||||
|
||||
Reference in New Issue
Block a user