file_util: Migrate Exists() and IsDirectory() over to std::filesystem
Greatly simplifies our file-handling code for these functions.
This commit is contained in:
@@ -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) {
|
||||||
|
@@ -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);
|
||||||
|
Reference in New Issue
Block a user