X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=Source%2FUtils%2FFolders.cpp;h=751da930b65a46a75bb4cdafc87476a08ae2dcb9;hb=b9a46d8e2b7e7e22c706e7dd3734f31015db4408;hp=e2956e55db6c72c49d0d60c9f8dea9d2fd0a8833;hpb=ed3662c0852c4312a612b4fc35bd03aba8d13db7;p=lugaru.git diff --git a/Source/Utils/Folders.cpp b/Source/Utils/Folders.cpp index e2956e5..751da93 100644 --- a/Source/Utils/Folders.cpp +++ b/Source/Utils/Folders.cpp @@ -20,6 +20,8 @@ along with Lugaru. If not, see . #include "Folders.hpp" +#include +#include #include #include @@ -43,18 +45,13 @@ std::string Folders::getScreenshotDir() return screenshotDir; } -std::string Folders::getResourcePath(std::string filepath) -{ - return dataDir + '/' + filepath; -} - std::string Folders::getUserDataPath() { std::string userDataPath; #ifdef _WIN32 char path[MAX_PATH]; // %APPDATA% (%USERPROFILE%\Application Data) - if(SUCCEEDED(SHGetFolderPathA(nullptr, CSIDL_APPDATA, nullptr, 0, path))) { + if (SUCCEEDED(SHGetFolderPathA(nullptr, CSIDL_APPDATA, nullptr, 0, path))) { userDataPath = std::string(path) + "/Lugaru/"; } else { return dataDir; @@ -87,7 +84,8 @@ std::string Folders::getConfigFilePath() #if PLATFORM_LINUX /* Generic code for XDG ENVVAR test and fallback */ -std::string Folders::getGenericDirectory(const char* ENVVAR, const std::string fallback) { +std::string Folders::getGenericDirectory(const char* ENVVAR, const std::string& fallback) +{ const char* path = getenv(ENVVAR); std::string ret; if ((path != NULL) && (strlen(path) != 0)) { @@ -107,40 +105,31 @@ std::string Folders::getGenericDirectory(const char* ENVVAR, const std::string f #if PLATFORM_UNIX const char* Folders::getHomeDirectory() { - const char *homedir = getenv("HOME"); - if (homedir != NULL) + const char* homedir = getenv("HOME"); + if (homedir != NULL) { return homedir; - struct passwd *pw = getpwuid(getuid()); - if (pw != NULL) + } + struct passwd* pw = getpwuid(getuid()); + if (pw != NULL) { return pw->pw_dir; + } return NULL; } #endif -bool Folders::makeDirectory(std::string path) { +bool Folders::makeDirectory(const std::string& path) +{ #ifdef _WIN32 int status = CreateDirectory(path.c_str(), NULL); - if (status != 0) { - return true; - } else if(GetLastError() == ERROR_ALREADY_EXISTS) { - return true; - } else { - return false; - } + return ((status != 0) || (GetLastError() == ERROR_ALREADY_EXISTS)); #else errno = 0; int status = mkdir(path.c_str(), S_IRWXU | S_IRWXG | S_IROTH | S_IXOTH); - if (status == 0) { - return true; - } else if(errno == EEXIST) { - return true; - } else { - return false; - } + return ((status == 0) || (errno == EEXIST)); #endif } -FILE* Folders::openMandatoryFile(std::string filename, const char* mode) +FILE* Folders::openMandatoryFile(const std::string& filename, const char* mode) { FILE* tfile = fopen(filename.c_str(), mode); if (tfile == NULL) { @@ -148,3 +137,15 @@ FILE* Folders::openMandatoryFile(std::string filename, const char* mode) } return tfile; } + +bool Folders::file_exists(const std::string& filepath) +{ + FILE* file; + file = fopen(filepath.c_str(), "rb"); + if (file == NULL) { + return false; + } else { + fclose(file); + return true; + } +}