From 8fb80790055c365600b0f8f881a213506acff5e8 Mon Sep 17 00:00:00 2001 From: Erik Smistad Date: Fri, 8 Dec 2023 10:30:23 +0100 Subject: [PATCH] Fixed some issues with createDirectories() --- source/FAST/Tests/UtilityTests.cpp | 24 ++++++++++++++++++++++++ source/FAST/Utility.cpp | 10 +++------- 2 files changed, 27 insertions(+), 7 deletions(-) diff --git a/source/FAST/Tests/UtilityTests.cpp b/source/FAST/Tests/UtilityTests.cpp index 483b4f3e9..0eba707b5 100644 --- a/source/FAST/Tests/UtilityTests.cpp +++ b/source/FAST/Tests/UtilityTests.cpp @@ -34,6 +34,10 @@ TEST_CASE("Split", "[split][utility]") { CHECK(parts[0] == "\"Wee sad"); CHECK(parts[1] == "asd asd "); CHECK(parts[2] == "asdasd\""); + + parts = split("test", "/"); + REQUIRE(parts.size() == 1); + CHECK(parts[0] == "test"); } TEST_CASE("Replace", "[replace][utility]") { @@ -65,4 +69,24 @@ TEST_CASE("getFileName", "[getFileName][utility][fast]") { CHECK(getFileName(str) == "asd_asd.txt"); str = "asd asd.txt"; CHECK(getFileName(str) == "asd asd.txt"); +} + +TEST_CASE("createDirectories", "[createDirectories][utility][fast]") { + std::string name = "create_directories_test"; + CHECK_NOTHROW(createDirectories(name)); + CHECK(isDir(name)); + + std::string name2 = "create_directories_test2/test2/"; + CHECK_NOTHROW(createDirectories(name2)); + CHECK(isDir(name2)); + + std::string name3 = "create_directories_test3/test3/test3/"; + CHECK_NOTHROW(createDirectories(name3)); + CHECK(isDir(name3)); + +#ifdef WIN32 + std::string name4 = "create_directories_test4\\test4\\"; + CHECK_NOTHROW(createDirectories(name4)); + CHECK(isDir(name4)); +#endif } \ No newline at end of file diff --git a/source/FAST/Utility.cpp b/source/FAST/Utility.cpp index 8c8a5f66c..5440c4588 100644 --- a/source/FAST/Utility.cpp +++ b/source/FAST/Utility.cpp @@ -905,14 +905,10 @@ void createDirectories(std::string path) { } directories = filteredDirectories; -#ifdef _WIN32 - std::string currentPath = directories[0]; -#else - std::string currentPath = "/" + directories[0]; -#endif + std::string currentPath = ""; // Create each directory needed - for(int i = 1; i < directories.size(); ++i) { - currentPath += "/" + directories[i]; + for(int i = 0; i < directories.size(); ++i) { + currentPath += directories[i] + "/"; try { createDirectory(currentPath); } catch(ExistException &e) {