mirror of
https://github.com/gabime/spdlog.git
synced 2024-11-15 08:25:43 +08:00
Fix #3079
This commit is contained in:
parent
238c9ffa5d
commit
94a8e87c71
@ -534,6 +534,15 @@ SPDLOG_INLINE bool create_dir(const filename_t &path) {
|
||||
}
|
||||
|
||||
auto subdir = path.substr(0, token_pos);
|
||||
#ifdef _WIN32
|
||||
// if subdir is just a drive letter, add a slash e.g. "c:"=>"c:\",
|
||||
// otherwise path_exists(subdir) returns false (issue #3079)
|
||||
const bool is_drive = subdir.length() == 2 && subdir[1] == ':';
|
||||
if (is_drive) {
|
||||
subdir += '\\';
|
||||
token_pos++;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (!subdir.empty() && !path_exists(subdir) && !mkdir_(subdir)) {
|
||||
return false; // return error if failed creating dir
|
||||
|
@ -81,3 +81,65 @@ TEST_CASE("dir_name", "[create_dir]") {
|
||||
REQUIRE(dir_name(SPDLOG_FILENAME_T("../file.txt")) == SPDLOG_FILENAME_T(".."));
|
||||
REQUIRE(dir_name(SPDLOG_FILENAME_T("./file.txt")) == SPDLOG_FILENAME_T("."));
|
||||
}
|
||||
|
||||
#ifdef _WIN32
|
||||
|
||||
//
|
||||
// test windows cases when drive letter is given e.g. C:\\some-folder\
|
||||
//
|
||||
#include <windows.h>
|
||||
#include <fileapi.h>
|
||||
|
||||
std::string get_full_path(const std::string &relative_folder_path) {
|
||||
char full_path[MAX_PATH];
|
||||
|
||||
DWORD result = ::GetFullPathNameA(relative_folder_path.c_str(), MAX_PATH, full_path, nullptr);
|
||||
// Return an empty string if failed to get full path
|
||||
return result > 0 && result < MAX_PATH ? std::string(full_path) : std::string();
|
||||
}
|
||||
|
||||
std::wstring get_full_path(const std::wstring &relative_folder_path) {
|
||||
wchar_t full_path[MAX_PATH];
|
||||
DWORD result = ::GetFullPathNameW(relative_folder_path.c_str(), MAX_PATH, full_path, nullptr);
|
||||
return result > 0 && result < MAX_PATH ? std::wstring(full_path) : std::wstring();
|
||||
}
|
||||
|
||||
spdlog::filename_t::value_type find_non_existing_drive() {
|
||||
for (char drive = 'A'; drive <= 'Z'; ++drive) {
|
||||
std::string root_path = std::string(1, drive) + ":\\";
|
||||
UINT drive_type = GetDriveTypeA(root_path.c_str());
|
||||
if (drive_type == DRIVE_NO_ROOT_DIR) {
|
||||
return static_cast <spdlog::filename_t::value_type>(drive);
|
||||
}
|
||||
}
|
||||
return '\0'; // No available drive found
|
||||
}
|
||||
|
||||
TEST_CASE("create_abs_path1", "[create_dir]") {
|
||||
prepare_logdir();
|
||||
auto abs_path = get_full_path(SPDLOG_FILENAME_T("test_logs\\logdir1"));
|
||||
REQUIRE(!abs_path.empty());
|
||||
REQUIRE(create_dir(abs_path) == true);
|
||||
}
|
||||
|
||||
TEST_CASE("create_abs_path2", "[create_dir]") {
|
||||
prepare_logdir();
|
||||
auto abs_path = get_full_path(SPDLOG_FILENAME_T("test_logs/logdir2"));
|
||||
REQUIRE(!abs_path.empty());
|
||||
REQUIRE(create_dir(abs_path) == true);
|
||||
}
|
||||
|
||||
TEST_CASE("non_existing_drive", "[create_dir]") {
|
||||
prepare_logdir();
|
||||
spdlog::filename_t path;
|
||||
|
||||
auto non_existing_drive = find_non_existing_drive();
|
||||
path += non_existing_drive ;
|
||||
path += SPDLOG_FILENAME_T(":\\");
|
||||
REQUIRE(create_dir(path) == false);
|
||||
path += SPDLOG_FILENAME_T("subdir");
|
||||
REQUIRE(create_dir(path) == false);
|
||||
|
||||
}
|
||||
//#endif // SPDLOG_WCHAR_FILENAMES
|
||||
#endif // _WIN32
|
||||
|
Loading…
Reference in New Issue
Block a user