From b61e4feea5b6e86fb5923d1ba772711139063110 Mon Sep 17 00:00:00 2001 From: Shauren Date: Thu, 6 Nov 2014 21:22:50 +0100 Subject: Tools/Patcher * Client patcher no longer has to be ran from administrator level command line to successfully create bnet module * Set patched bnet module as readonly to prevent wow from deleting it --- src/tools/connection_patcher/Program.cpp | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'src/tools/connection_patcher/Program.cpp') diff --git a/src/tools/connection_patcher/Program.cpp b/src/tools/connection_patcher/Program.cpp index 9513e2da486..a613485f839 100644 --- a/src/tools/connection_patcher/Program.cpp +++ b/src/tools/connection_patcher/Program.cpp @@ -43,6 +43,8 @@ namespace Connection_Patcher template void PatchModule(boost::filesystem::path file, boost::filesystem::path path) { + namespace fs = boost::filesystem; + std::cout << "Patching module...\n"; Patcher patcher(file); @@ -50,13 +52,15 @@ namespace Connection_Patcher patcher.Patch(PATCH::Password(), PATTERN::Password()); std::string const moduleName(Helper::GetFileChecksum(patcher.binary) + ".auth"); - boost::filesystem::path const modulePath + fs::path const modulePath (path / std::string(&moduleName[0], 2) / std::string(&moduleName[2], 2)); - if (!boost::filesystem::exists(modulePath)) - boost::filesystem::create_directories(modulePath); + if (!fs::exists(modulePath)) + fs::create_directories(modulePath); + fs::permissions(modulePath / moduleName, fs::add_perms | fs::others_write | fs::group_write | fs::owner_write); patcher.Finish(modulePath / moduleName); + fs::permissions(modulePath / moduleName, fs::remove_perms | fs::others_write | fs::group_write | fs::owner_write); std::cout << "Patching module finished.\n"; } -- cgit v1.2.3