1
0
Fork 1
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:
Tom Mason 2013-08-18 00:16:20 +01:00
parent ceb3317807
commit 90a892d304

View file

@ -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);
} }