mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-04-28 21:07:59 +03:00
Apply clang-format to code base
This commit is contained in:
parent
f37d0be806
commit
ddb0522bbf
2199 changed files with 118692 additions and 114392 deletions
|
@ -2,10 +2,10 @@
|
|||
|
||||
#if defined(__linux__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__OpenBSD__)
|
||||
|
||||
#include <cstring>
|
||||
#include <fstream>
|
||||
#include <pwd.h>
|
||||
#include <unistd.h>
|
||||
#include <fstream>
|
||||
#include <cstring>
|
||||
|
||||
#include <components/debug/debuglog.hpp>
|
||||
#include <components/misc/strings/lower.hpp>
|
||||
|
@ -48,133 +48,135 @@ namespace
|
|||
namespace Files
|
||||
{
|
||||
|
||||
LinuxPath::LinuxPath(const std::string& application_name)
|
||||
: mName(application_name)
|
||||
{
|
||||
std::error_code ec;
|
||||
current_path(getLocalPath(), ec);
|
||||
const auto err = ec.value();
|
||||
if (err != 0) {
|
||||
Log(Debug::Warning) << "Error " << err << " " << std::strerror(err) << " when changing current directory";
|
||||
}
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getUserConfigPath() const
|
||||
{
|
||||
return getEnv("XDG_CONFIG_HOME", getUserHome() / ".config") / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getUserDataPath() const
|
||||
{
|
||||
return getEnv("XDG_DATA_HOME", getUserHome() / ".local/share") / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getCachePath() const
|
||||
{
|
||||
return getEnv("XDG_CACHE_HOME", getUserHome() / ".cache") / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getGlobalConfigPath() const
|
||||
{
|
||||
std::filesystem::path globalPath(GLOBAL_CONFIG_PATH);
|
||||
return globalPath / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getLocalPath() const
|
||||
{
|
||||
auto localPath = std::filesystem::current_path();
|
||||
static const std::filesystem::path statusPaths[] = {"/proc/self/exe", "/proc/self/file", "/proc/curproc/exe", "/proc/curproc/file"};
|
||||
|
||||
for(const auto& path : statusPaths)
|
||||
LinuxPath::LinuxPath(const std::string& application_name)
|
||||
: mName(application_name)
|
||||
{
|
||||
std::error_code ec;
|
||||
const auto binPath = read_symlink(path, ec);
|
||||
if (ec.value() != -1)
|
||||
current_path(getLocalPath(), ec);
|
||||
const auto err = ec.value();
|
||||
if (err != 0)
|
||||
{
|
||||
localPath = binPath.parent_path();
|
||||
break;
|
||||
Log(Debug::Warning) << "Error " << err << " " << std::strerror(err) << " when changing current directory";
|
||||
}
|
||||
}
|
||||
|
||||
return localPath;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getGlobalDataPath() const
|
||||
{
|
||||
std::filesystem::path globalDataPath(GLOBAL_DATA_PATH);
|
||||
return globalDataPath / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getInstallPath() const
|
||||
{
|
||||
std::filesystem::path installPath;
|
||||
|
||||
std::filesystem::path homePath = getUserHome();
|
||||
|
||||
if (!homePath.empty())
|
||||
std::filesystem::path LinuxPath::getUserConfigPath() const
|
||||
{
|
||||
std::filesystem::path wineDefaultRegistry(homePath);
|
||||
wineDefaultRegistry /= ".wine/system.reg";
|
||||
return getEnv("XDG_CONFIG_HOME", getUserHome() / ".config") / mName;
|
||||
}
|
||||
|
||||
if (std::filesystem::is_regular_file(wineDefaultRegistry))
|
||||
std::filesystem::path LinuxPath::getUserDataPath() const
|
||||
{
|
||||
return getEnv("XDG_DATA_HOME", getUserHome() / ".local/share") / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getCachePath() const
|
||||
{
|
||||
return getEnv("XDG_CACHE_HOME", getUserHome() / ".cache") / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getGlobalConfigPath() const
|
||||
{
|
||||
std::filesystem::path globalPath(GLOBAL_CONFIG_PATH);
|
||||
return globalPath / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getLocalPath() const
|
||||
{
|
||||
auto localPath = std::filesystem::current_path();
|
||||
static const std::filesystem::path statusPaths[]
|
||||
= { "/proc/self/exe", "/proc/self/file", "/proc/curproc/exe", "/proc/curproc/file" };
|
||||
|
||||
for (const auto& path : statusPaths)
|
||||
{
|
||||
std::ifstream file(wineDefaultRegistry);
|
||||
bool isRegEntry = false;
|
||||
std::string line;
|
||||
std::string mwpath;
|
||||
|
||||
while (std::getline(file, line))
|
||||
std::error_code ec;
|
||||
const auto binPath = read_symlink(path, ec);
|
||||
if (ec.value() != -1)
|
||||
{
|
||||
if (line[0] == '[') // we found an entry
|
||||
{
|
||||
if (isRegEntry)
|
||||
{
|
||||
break;
|
||||
}
|
||||
localPath = binPath.parent_path();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
isRegEntry = (line.find("Softworks\\\\Morrowind]") != std::string::npos);
|
||||
}
|
||||
else if (isRegEntry)
|
||||
return localPath;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getGlobalDataPath() const
|
||||
{
|
||||
std::filesystem::path globalDataPath(GLOBAL_DATA_PATH);
|
||||
return globalDataPath / mName;
|
||||
}
|
||||
|
||||
std::filesystem::path LinuxPath::getInstallPath() const
|
||||
{
|
||||
std::filesystem::path installPath;
|
||||
|
||||
std::filesystem::path homePath = getUserHome();
|
||||
|
||||
if (!homePath.empty())
|
||||
{
|
||||
std::filesystem::path wineDefaultRegistry(homePath);
|
||||
wineDefaultRegistry /= ".wine/system.reg";
|
||||
|
||||
if (std::filesystem::is_regular_file(wineDefaultRegistry))
|
||||
{
|
||||
std::ifstream file(wineDefaultRegistry);
|
||||
bool isRegEntry = false;
|
||||
std::string line;
|
||||
std::string mwpath;
|
||||
|
||||
while (std::getline(file, line))
|
||||
{
|
||||
if (line[0] == '"') // empty line means new registry key
|
||||
if (line[0] == '[') // we found an entry
|
||||
{
|
||||
std::string key = line.substr(1, line.find('"', 1) - 1);
|
||||
if (strcasecmp(key.c_str(), "Installed Path") == 0)
|
||||
if (isRegEntry)
|
||||
{
|
||||
std::string::size_type valuePos = line.find('=') + 2;
|
||||
mwpath = line.substr(valuePos, line.rfind('"') - valuePos);
|
||||
|
||||
std::string::size_type pos = mwpath.find("\\");
|
||||
while (pos != std::string::npos)
|
||||
{
|
||||
mwpath.replace(pos, 2, "/");
|
||||
pos = mwpath.find("\\", pos + 1);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
isRegEntry = (line.find("Softworks\\\\Morrowind]") != std::string::npos);
|
||||
}
|
||||
else if (isRegEntry)
|
||||
{
|
||||
if (line[0] == '"') // empty line means new registry key
|
||||
{
|
||||
std::string key = line.substr(1, line.find('"', 1) - 1);
|
||||
if (strcasecmp(key.c_str(), "Installed Path") == 0)
|
||||
{
|
||||
std::string::size_type valuePos = line.find('=') + 2;
|
||||
mwpath = line.substr(valuePos, line.rfind('"') - valuePos);
|
||||
|
||||
std::string::size_type pos = mwpath.find("\\");
|
||||
while (pos != std::string::npos)
|
||||
{
|
||||
mwpath.replace(pos, 2, "/");
|
||||
pos = mwpath.find("\\", pos + 1);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!mwpath.empty())
|
||||
{
|
||||
// Change drive letter to lowercase, so we could use
|
||||
// ~/.wine/dosdevices symlinks
|
||||
mwpath[0] = Misc::StringUtils::toLower(mwpath[0]);
|
||||
installPath /= homePath;
|
||||
installPath /= ".wine/dosdevices/";
|
||||
installPath /= mwpath;
|
||||
|
||||
if (!std::filesystem::is_directory(installPath))
|
||||
if (!mwpath.empty())
|
||||
{
|
||||
installPath.clear();
|
||||
// Change drive letter to lowercase, so we could use
|
||||
// ~/.wine/dosdevices symlinks
|
||||
mwpath[0] = Misc::StringUtils::toLower(mwpath[0]);
|
||||
installPath /= homePath;
|
||||
installPath /= ".wine/dosdevices/";
|
||||
installPath /= mwpath;
|
||||
|
||||
if (!std::filesystem::is_directory(installPath))
|
||||
{
|
||||
installPath.clear();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return installPath;
|
||||
}
|
||||
return installPath;
|
||||
}
|
||||
|
||||
} /* namespace Files */
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue