file_util: Migrate Exists() and IsDirectory() over to std::filesystem

Greatly simplifies our file-handling code for these functions.
This commit is contained in:
Lioncash
2020-12-08 18:36:49 -05:00
committed by GPUCode
parent 281f2926bb
commit 0675bd946c
2 changed files with 13 additions and 57 deletions

View File

@@ -3,6 +3,7 @@
// Refer to the license.txt file included. // Refer to the license.txt file included.
#include <array> #include <array>
#include <filesystem>
#include <limits> #include <limits>
#include <memory> #include <memory>
#include <sstream> #include <sstream>
@@ -77,62 +78,16 @@
// The code still needs a ton of cleanup. // The code still needs a ton of cleanup.
// REMEMBER: strdup considered harmful! // REMEMBER: strdup considered harmful!
namespace Common::FS { namespace Common::FS {
namespace fs = std::filesystem;
// Remove any ending forward slashes from directory paths bool Exists(const fs::path& path) {
// Modifies argument. std::error_code ec;
static void StripTailDirSlashes(std::string& fname) { return fs::exists(path, ec);
if (fname.length() <= 1) {
return;
} }
std::size_t i = fname.length(); bool IsDirectory(const fs::path& path) {
while (i > 0 && fname[i - 1] == DIR_SEP_CHR) { std::error_code ec;
--i; return fs::is_directory(path, ec);
}
fname.resize(i);
}
bool Exists(const std::string& filename) {
struct stat file_info;
std::string copy(filename);
StripTailDirSlashes(copy);
#ifdef _WIN32
// Windows needs a slash to identify a driver root
if (copy.size() != 0 && copy.back() == ':')
copy += DIR_SEP_CHR;
int result = _wstat64(Common::UTF8ToUTF16W(copy).c_str(), &file_info);
#else
int result = stat(copy.c_str(), &file_info);
#endif
return (result == 0);
}
bool IsDirectory(const std::string& filename) {
struct stat file_info;
std::string copy(filename);
StripTailDirSlashes(copy);
#ifdef _WIN32
// Windows needs a slash to identify a driver root
if (copy.size() != 0 && copy.back() == ':')
copy += DIR_SEP_CHR;
int result = _wstat64(Common::UTF8ToUTF16W(copy).c_str(), &file_info);
#else
int result = stat(copy.c_str(), &file_info);
#endif
if (result < 0) {
LOG_DEBUG(Common_Filesystem, "stat failed on {}: {}", filename, GetLastErrorMsg());
return false;
}
return S_ISDIR(file_info.st_mode);
} }
bool Delete(const std::string& filename) { bool Delete(const std::string& filename) {

View File

@@ -6,6 +6,7 @@
#include <array> #include <array>
#include <cstdio> #include <cstdio>
#include <filesystem>
#include <fstream> #include <fstream>
#include <functional> #include <functional>
#include <limits> #include <limits>
@@ -90,11 +91,11 @@ private:
friend class boost::serialization::access; friend class boost::serialization::access;
}; };
// Returns true if file filename exists // Returns true if the exists
[[nodiscard]] bool Exists(const std::string& filename); [[nodiscard]] bool Exists(const std::filesystem::path& path);
// Returns true if filename is a directory // Returns true if path is a directory
[[nodiscard]] bool IsDirectory(const std::string& filename); [[nodiscard]] bool IsDirectory(const std::filesystem::path& path);
// Returns the size of filename (64bit) // Returns the size of filename (64bit)
[[nodiscard]] u64 GetSize(const std::string& filename); [[nodiscard]] u64 GetSize(const std::string& filename);