fallback for ini importer

This commit is contained in:
Sebastian Wick 2012-04-02 17:07:18 +02:00
parent 16674ad141
commit 6e19076dc5
3 changed files with 44 additions and 8 deletions

View file

@ -14,10 +14,19 @@ MwIniImporter::MwIniImporter() {
{ "fps", "General:Show FPS" }, { "fps", "General:Show FPS" },
{ 0, 0 } { 0, 0 }
}; };
const char *fallback[][2] = {
{ "Weather_Sunrise_Time", "Weather:Sunrise Time" },
{ "Weather_Sunset_Time", "Weather:Sunset Time" },
{ 0, 0 }
};
for(int i=0; map[i][0]; i++) { for(int i=0; map[i][0]; i++) {
mMergeMap.insert(std::make_pair<std::string, std::string>(map[i][0], map[i][1])); mMergeMap.insert(std::make_pair<std::string, std::string>(map[i][0], map[i][1]));
} }
for(int i=0; fallback[i][0]; i++) {
mMergeFallback.insert(std::make_pair<std::string, std::string>(fallback[i][0], fallback[i][1]));
}
} }
void MwIniImporter::setVerbose(bool verbose) { void MwIniImporter::setVerbose(bool verbose) {
@ -116,16 +125,36 @@ void MwIniImporter::merge(multistrmap &cfg, multistrmap &ini) {
multistrmap::iterator iniIt; multistrmap::iterator iniIt;
for(strmap::iterator it=mMergeMap.begin(); it!=mMergeMap.end(); it++) { for(strmap::iterator it=mMergeMap.begin(); it!=mMergeMap.end(); it++) {
if((iniIt = ini.find(it->second)) != ini.end()) { if((iniIt = ini.find(it->second)) != ini.end()) {
for(std::vector<std::string>::iterator vc = iniIt->second.begin(); vc != iniIt->second.end(); vc++) {
cfg.erase(it->first); cfg.erase(it->first);
if(!this->specialMerge(it->first, it->second, cfg, ini)) { insertMultistrmap(cfg, it->first, *vc);
cfg.insert(std::make_pair<std::string, std::vector<std::string> >(it->first, iniIt->second));
} }
} }
} }
} }
bool MwIniImporter::specialMerge(std::string cfgKey, std::string iniKey, multistrmap &cfg, multistrmap &ini) { void MwIniImporter::mergeFallback(multistrmap &cfg, multistrmap &ini) {
return false; cfg.erase("fallback");
multistrmap::iterator cfgIt;
multistrmap::iterator iniIt;
for(strmap::iterator it=mMergeFallback.begin(); it!=mMergeFallback.end(); it++) {
if((iniIt = ini.find(it->second)) != ini.end()) {
for(std::vector<std::string>::iterator vc = iniIt->second.begin(); vc != iniIt->second.end(); vc++) {
std::string value("\"");
value.append(it->first).append("=").append(vc->substr(0,vc->length()-1)).append("\"");
insertMultistrmap(cfg, "fallback", value);
}
}
}
};
void MwIniImporter::insertMultistrmap(multistrmap &cfg, std::string key, std::string value) {
multistrmap::iterator it = cfg.find(key);
if(it == cfg.end()) {
cfg.insert(std::make_pair<std::string, std::vector<std::string> >(key, std::vector<std::string>() ));
}
cfg[key].push_back(value);
} }
void MwIniImporter::importGameFiles(multistrmap &cfg, multistrmap &ini) { void MwIniImporter::importGameFiles(multistrmap &cfg, multistrmap &ini) {

View file

@ -18,14 +18,16 @@ class MwIniImporter {
multistrmap loadIniFile(std::string filename); multistrmap loadIniFile(std::string filename);
multistrmap loadCfgFile(std::string filename); multistrmap loadCfgFile(std::string filename);
void merge(multistrmap &cfg, multistrmap &ini); void merge(multistrmap &cfg, multistrmap &ini);
void mergeFallback(multistrmap &cfg, multistrmap &ini);
void importGameFiles(multistrmap &cfg, multistrmap &ini); void importGameFiles(multistrmap &cfg, multistrmap &ini);
void writeToFile(boost::iostreams::stream<boost::iostreams::file_sink> &out, multistrmap &cfg); void writeToFile(boost::iostreams::stream<boost::iostreams::file_sink> &out, multistrmap &cfg);
private: private:
bool specialMerge(std::string cfgKey, std::string iniKey, multistrmap &cfg, multistrmap &ini); void insertMultistrmap(multistrmap &cfg, std::string key, std::string value);
std::string numberToString(int n); std::string numberToString(int n);
bool mVerbose; bool mVerbose;
strmap mMergeMap; strmap mMergeMap;
strmap mMergeFallback;
}; };

View file

@ -16,6 +16,7 @@ int main(int argc, char *argv[]) {
("ini,i", bpo::value<std::string>(), "morrowind.ini file") ("ini,i", bpo::value<std::string>(), "morrowind.ini file")
("cfg,c", bpo::value<std::string>(), "openmw.cfg file") ("cfg,c", bpo::value<std::string>(), "openmw.cfg file")
("output,o", bpo::value<std::string>()->default_value(""), "openmw.cfg file") ("output,o", bpo::value<std::string>()->default_value(""), "openmw.cfg file")
("fallback,f", "import fallback settings")
("game-files,g", "import esm and esp files") ("game-files,g", "import esm and esp files")
; ;
@ -53,6 +54,10 @@ int main(int argc, char *argv[]) {
importer.merge(cfg, ini); importer.merge(cfg, ini);
if(vm.count("fallback")) {
importer.mergeFallback(cfg, ini);
}
if(vm.count("game-files")) { if(vm.count("game-files")) {
importer.importGameFiles(cfg, ini); importer.importGameFiles(cfg, ini);
} }