mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-21 10:23:52 +00:00
unshield fixes
This commit is contained in:
parent
ceb3317807
commit
90a892d304
1 changed files with 41 additions and 7 deletions
|
@ -300,7 +300,7 @@ void UnshieldThread::SetOutputPath(const std::string& path)
|
||||||
mOutputPath = path;
|
mOutputPath = path;
|
||||||
}
|
}
|
||||||
|
|
||||||
void installToPath(const bfs::path& from, const bfs::path& to)
|
void installToPath(const bfs::path& from, const bfs::path& to, bool copy = false)
|
||||||
{
|
{
|
||||||
make_sure_directory_exists(to);
|
make_sure_directory_exists(to);
|
||||||
|
|
||||||
|
@ -309,17 +309,33 @@ void installToPath(const bfs::path& from, const bfs::path& to)
|
||||||
if(bfs::is_directory(dir->path()))
|
if(bfs::is_directory(dir->path()))
|
||||||
installToPath(dir->path(), to / dir->path().filename());
|
installToPath(dir->path(), to / dir->path().filename());
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
if(!copy)
|
||||||
bfs::rename(dir->path(), to / dir->path().filename());
|
bfs::rename(dir->path(), to / dir->path().filename());
|
||||||
|
else
|
||||||
|
bfs::copy_file(dir->path(), to / dir->path().filename());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bfs::path findFile(const bfs::path& in, std::string filename)
|
bfs::path findFile(const bfs::path& in, std::string filename, bool recursive = true)
|
||||||
|
{
|
||||||
|
if(recursive)
|
||||||
{
|
{
|
||||||
for ( bfs::recursive_directory_iterator end, dir(in); dir != end; ++dir )
|
for ( bfs::recursive_directory_iterator end, dir(in); dir != end; ++dir )
|
||||||
{
|
{
|
||||||
if(Misc::StringUtils::lowerCase(dir->path().filename().string()) == filename)
|
if(Misc::StringUtils::lowerCase(dir->path().filename().string()) == filename)
|
||||||
return dir->path();
|
return dir->path();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for ( bfs::recursive_directory_iterator end, dir(in); dir != end; ++dir )
|
||||||
|
{
|
||||||
|
if(Misc::StringUtils::lowerCase(dir->path().filename().string()) == filename)
|
||||||
|
return dir->path();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
@ -351,9 +367,16 @@ bool UnshieldThread::extract()
|
||||||
|
|
||||||
bfs::path dFilesDir = findFile(mwExtractPath, "morrowind.esm").parent_path();
|
bfs::path dFilesDir = findFile(mwExtractPath, "morrowind.esm").parent_path();
|
||||||
|
|
||||||
|
|
||||||
installToPath(dFilesDir, outputDataFilesDir);
|
installToPath(dFilesDir, outputDataFilesDir);
|
||||||
|
|
||||||
|
// Videos are often kept uncompressed on the cd
|
||||||
|
bfs::path videosPath = findFile(mMorrowindPath.parent_path(), "video", false);
|
||||||
|
if(videosPath.string() != "")
|
||||||
|
{
|
||||||
|
emit signalGUI(QString("Installing Videos..."));
|
||||||
|
installToPath(videosPath, outputDataFilesDir / "Video", true);
|
||||||
|
}
|
||||||
|
|
||||||
bfs::rename(findFile(mwExtractPath, "morrowind.ini"), outputDataFilesDir / "Morrowind.ini");
|
bfs::rename(findFile(mwExtractPath, "morrowind.ini"), outputDataFilesDir / "Morrowind.ini");
|
||||||
|
|
||||||
mTribunalDone = contains(outputDataFilesDir, "tribunal.esm");
|
mTribunalDone = contains(outputDataFilesDir, "tribunal.esm");
|
||||||
|
@ -372,6 +395,11 @@ bool UnshieldThread::extract()
|
||||||
|
|
||||||
installToPath(dFilesDir, outputDataFilesDir);
|
installToPath(dFilesDir, outputDataFilesDir);
|
||||||
|
|
||||||
|
// Mt GOTY CD has Sounds in a seperate folder from the rest of the data files
|
||||||
|
bfs::path soundsPath = findFile(tbExtractPath, "sounds", false);
|
||||||
|
if(soundsPath.string() != "")
|
||||||
|
installToPath(soundsPath, outputDataFilesDir / "Sounds");
|
||||||
|
|
||||||
mBloodmoonDone = contains(outputDataFilesDir, "bloodmoon.esm");
|
mBloodmoonDone = contains(outputDataFilesDir, "bloodmoon.esm");
|
||||||
|
|
||||||
fix_ini(outputDataFilesDir, bfs::path(mTribunalPath).parent_path(), mTribunalDone, mBloodmoonDone);
|
fix_ini(outputDataFilesDir, bfs::path(mTribunalPath).parent_path(), mTribunalDone, mBloodmoonDone);
|
||||||
|
@ -388,6 +416,12 @@ bool UnshieldThread::extract()
|
||||||
|
|
||||||
installToPath(dFilesDir, outputDataFilesDir);
|
installToPath(dFilesDir, outputDataFilesDir);
|
||||||
|
|
||||||
|
// My GOTY CD contains a folder within cab files called Tribunal patch,
|
||||||
|
// which contains Tribunal.esm
|
||||||
|
bfs::path tbPatchPath = findFile(bmExtractPath, "tribunal.esm");
|
||||||
|
if(tbPatchPath.string() != "")
|
||||||
|
bfs::rename(tbPatchPath, outputDataFilesDir / "Tribunal.esm");
|
||||||
|
|
||||||
fix_ini(outputDataFilesDir, bfs::path(mBloodmoonPath).parent_path(), false, mBloodmoonDone);
|
fix_ini(outputDataFilesDir, bfs::path(mBloodmoonPath).parent_path(), false, mBloodmoonDone);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue