1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-19 22:23:51 +00:00
openmw-tes3mp/components/files/windowspath.cpp

126 lines
3.1 KiB
C++
Raw Normal View History

#include "windowspath.hpp"
#if defined(_WIN32) || defined(__WINDOWS__)
#include <cstring>
#include <windows.h>
#include <shlobj.h>
#include <Shlwapi.h>
#pragma comment(lib, "Shlwapi.lib")
2014-01-14 13:20:41 +00:00
#include <boost/locale.hpp>
namespace bconv = boost::locale::conv;
/**
* FIXME: Someone with Windows system should check this and correct if necessary
2014-01-14 13:20:41 +00:00
* FIXME: MAX_PATH is irrelevant for extended-length paths, i.e. \\?\...
*/
/**
* \namespace Files
*/
namespace Files
{
WindowsPath::WindowsPath(const std::string& application_name)
: mName(application_name)
{
2014-05-22 12:35:57 +00:00
/* Since on Windows boost::path.string() returns string of narrow
characters in local encoding, it is required to path::imbue()
with UTF-8 encoding (generated for empty name from boost::locale)
to handle Unicode in platform-agnostic way using std::string.
See boost::filesystem and boost::locale reference for details.
*/
boost::filesystem::path::imbue(boost::locale::generator().generate(""));
}
2013-12-25 23:28:19 +00:00
boost::filesystem::path WindowsPath::getUserConfigPath() const
{
boost::filesystem::path userPath(".");
2014-01-14 13:20:41 +00:00
WCHAR path[MAX_PATH + 1];
memset(path, 0, sizeof(path));
2014-01-14 13:20:41 +00:00
if(SUCCEEDED(SHGetFolderPathW(NULL, CSIDL_PERSONAL | CSIDL_FLAG_CREATE, NULL, 0, path)))
{
2014-01-14 13:20:41 +00:00
userPath = boost::filesystem::path(bconv::utf_to_utf<char>(path));
}
return userPath / "My Games" / mName;
}
2013-12-26 00:24:43 +00:00
boost::filesystem::path WindowsPath::getUserDataPath() const
{
// Have some chaos, windows people!
return getUserConfigPath();
}
2013-12-25 23:28:19 +00:00
boost::filesystem::path WindowsPath::getGlobalConfigPath() const
{
boost::filesystem::path globalPath(".");
2014-01-14 13:20:41 +00:00
WCHAR path[MAX_PATH + 1];
memset(path, 0, sizeof(path));
2014-01-14 13:20:41 +00:00
if(SUCCEEDED(SHGetFolderPathW(NULL, CSIDL_PROGRAM_FILES | CSIDL_FLAG_CREATE, NULL, 0, path)))
{
2014-01-14 13:20:41 +00:00
globalPath = boost::filesystem::path(bconv::utf_to_utf<char>(path));
}
return globalPath / mName;
}
boost::filesystem::path WindowsPath::getLocalPath() const
{
return boost::filesystem::path("./");
}
boost::filesystem::path WindowsPath::getGlobalDataPath() const
{
2013-12-28 17:16:01 +00:00
return getGlobalConfigPath();
}
2012-09-02 17:40:26 +00:00
boost::filesystem::path WindowsPath::getCachePath() const
{
2013-12-28 17:16:01 +00:00
return getUserConfigPath() / "cache";
2012-09-02 17:40:26 +00:00
}
boost::filesystem::path WindowsPath::getInstallPath() const
{
boost::filesystem::path installPath("");
HKEY hKey;
BOOL f64 = FALSE;
LPCTSTR regkey;
if ((IsWow64Process(GetCurrentProcess(), &f64) && f64) || sizeof(void*) == 8)
{
regkey = "SOFTWARE\\Wow6432Node\\Bethesda Softworks\\Morrowind";
}
else
{
regkey = "SOFTWARE\\Bethesda Softworks\\Morrowind";
}
if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, TEXT(regkey), 0, KEY_ALL_ACCESS, &hKey) == ERROR_SUCCESS)
{
//Key existed, let's try to read the install dir
2012-01-17 08:02:45 +00:00
std::vector<char> buf(512);
int len = 512;
2012-01-17 08:02:45 +00:00
if (RegQueryValueEx(hKey, TEXT("Installed Path"), NULL, NULL, (LPBYTE)&buf[0], (LPDWORD)&len) == ERROR_SUCCESS)
{
2012-01-17 08:02:45 +00:00
installPath = &buf[0];
}
}
return installPath;
}
} /* namespace Files */
#endif /* defined(_WIN32) || defined(__WINDOWS__) */