mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-19 23:23:52 +00:00
Use data paths from config (bug #4412)
This commit is contained in:
parent
103a07b744
commit
9126e844bf
1 changed files with 28 additions and 9 deletions
|
@ -873,8 +873,20 @@ void MwIniImporter::importGameFiles(multistrmap &cfg, const multistrmap &ini, co
|
||||||
std::time_t defaultTime = 0;
|
std::time_t defaultTime = 0;
|
||||||
ToUTF8::Utf8Encoder encoder(mEncoding);
|
ToUTF8::Utf8Encoder encoder(mEncoding);
|
||||||
|
|
||||||
// assume the Game Files are all in a "Data Files" directory under the directory holding Morrowind.ini
|
std::vector<boost::filesystem::path> dataPaths;
|
||||||
const boost::filesystem::path gameFilesDir(iniFilename.parent_path() /= "Data Files");
|
if (cfg.count("data"))
|
||||||
|
{
|
||||||
|
for (std::string filePathString : cfg["data"])
|
||||||
|
{
|
||||||
|
if (filePathString.front() == '"')
|
||||||
|
{
|
||||||
|
filePathString.erase(filePathString.begin());
|
||||||
|
filePathString.erase(filePathString.end() - 1);
|
||||||
|
}
|
||||||
|
dataPaths.emplace_back(filePathString);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dataPaths.push_back(iniFilename.parent_path() /= "Data Files");
|
||||||
|
|
||||||
multistrmap::const_iterator it = ini.begin();
|
multistrmap::const_iterator it = ini.begin();
|
||||||
for (int i=0; it != ini.end(); i++)
|
for (int i=0; it != ini.end(); i++)
|
||||||
|
@ -893,9 +905,20 @@ void MwIniImporter::importGameFiles(multistrmap &cfg, const multistrmap &ini, co
|
||||||
|
|
||||||
if(filetype.compare("esm") == 0 || filetype.compare("esp") == 0)
|
if(filetype.compare("esm") == 0 || filetype.compare("esp") == 0)
|
||||||
{
|
{
|
||||||
boost::filesystem::path filepath(gameFilesDir);
|
bool found = false;
|
||||||
filepath /= *entry;
|
for (auto & dataPath : dataPaths)
|
||||||
contentFiles.push_back({lastWriteTime(filepath, defaultTime), filepath});
|
{
|
||||||
|
boost::filesystem::path path = dataPath / *entry;
|
||||||
|
std::time_t time = lastWriteTime(path, defaultTime);
|
||||||
|
if (time != defaultTime)
|
||||||
|
{
|
||||||
|
contentFiles.push_back({time, path});
|
||||||
|
found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!found)
|
||||||
|
std::cout << "Warning: " << *entry << " not found, ignoring" << std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -981,9 +1004,5 @@ std::time_t MwIniImporter::lastWriteTime(const boost::filesystem::path& filename
|
||||||
std::cout << "content file: " << resolved << " timestamp = (" << writeTime <<
|
std::cout << "content file: " << resolved << " timestamp = (" << writeTime <<
|
||||||
") " << timeStrBuffer << std::endl;
|
") " << timeStrBuffer << std::endl;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
std::cout << "content file: " << filename << " not found" << std::endl;
|
|
||||||
}
|
|
||||||
return writeTime;
|
return writeTime;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue