2022-02-11 09:07:11 +11:00
|
|
|
/* SPDX-License-Identifier: Apache-2.0 */
|
2014-06-19 18:48:41 +10:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
#include "testing/testing.h"
|
|
|
|
|
2020-08-07 16:43:42 +02:00
|
|
|
#include "IMB_imbuf.h"
|
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
#include "BLI_fileops.h"
|
|
|
|
#include "BLI_path_util.h"
|
2017-03-24 17:29:48 +11:00
|
|
|
#include "BLI_string.h"
|
2016-02-06 21:19:47 +05:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
/* -------------------------------------------------------------------- */
|
|
|
|
/* tests */
|
|
|
|
|
2020-04-07 12:02:21 +10:00
|
|
|
/* BLI_path_normalize */
|
2016-02-06 21:19:47 +05:00
|
|
|
#ifndef _WIN32
|
2017-03-24 17:48:22 +11:00
|
|
|
TEST(path_util, Clean)
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
/* "/./" -> "/" */
|
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "/a/./b/./c/./";
|
2020-11-06 17:49:09 +01:00
|
|
|
BLI_path_normalize(nullptr, path);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("/a/b/c/", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "/./././";
|
2020-11-06 17:49:09 +01:00
|
|
|
BLI_path_normalize(nullptr, path);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("/", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "/a/./././b/";
|
2020-11-06 17:49:09 +01:00
|
|
|
BLI_path_normalize(nullptr, path);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("/a/b/", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
/* "//" -> "/" */
|
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "a////";
|
2020-11-06 17:49:09 +01:00
|
|
|
BLI_path_normalize(nullptr, path);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("a/", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2020-11-06 14:25:30 +01:00
|
|
|
if (false) /* FIXME */
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "./a////";
|
2020-11-06 17:49:09 +01:00
|
|
|
BLI_path_normalize(nullptr, path);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("./a/", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
/* "foo/bar/../" -> "foo/" */
|
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "/a/b/c/../../../";
|
2020-11-06 17:49:09 +01:00
|
|
|
BLI_path_normalize(nullptr, path);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("/", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "/a/../a/b/../b/c/../c/";
|
2020-11-06 17:49:09 +01:00
|
|
|
BLI_path_normalize(nullptr, path);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("/a/b/c/", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "//../";
|
2020-04-07 12:02:21 +10:00
|
|
|
BLI_path_normalize("/a/b/c/", path);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("/a/b/", path);
|
|
|
|
}
|
|
|
|
}
|
2016-02-06 21:19:47 +05:00
|
|
|
#endif
|
2014-06-18 22:49:17 +10:00
|
|
|
|
2017-03-22 19:31:34 +11:00
|
|
|
#define AT_INDEX(str_input, index_input, str_expect) \
|
|
|
|
{ \
|
|
|
|
char path[] = str_input; \
|
2022-10-31 13:21:24 +11:00
|
|
|
/* Test input assumes forward slash, support back-slash on WIN32. */ \
|
|
|
|
if (SEP == '\\') { \
|
|
|
|
BLI_str_replace_char(path, '/', '\\'); \
|
|
|
|
} \
|
2017-03-22 19:31:34 +11:00
|
|
|
const char *expect = str_expect; \
|
|
|
|
int index_output, len_output; \
|
|
|
|
const bool ret = BLI_path_name_at_index(path, index_input, &index_output, &len_output); \
|
|
|
|
if (expect == NULL) { \
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_FALSE(ret); \
|
2017-03-22 19:31:34 +11:00
|
|
|
} \
|
|
|
|
else { \
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_TRUE(ret); \
|
2017-03-22 19:31:34 +11:00
|
|
|
EXPECT_EQ(strlen(expect), len_output); \
|
|
|
|
path[index_output + len_output] = '\0'; \
|
2017-03-24 17:48:22 +11:00
|
|
|
EXPECT_STREQ(&path[index_output], expect); \
|
2019-04-17 06:17:24 +02:00
|
|
|
} \
|
2017-03-22 19:31:34 +11:00
|
|
|
} \
|
|
|
|
((void)0)
|
|
|
|
|
|
|
|
/* BLI_path_name_at_index */
|
|
|
|
TEST(path_util, NameAtIndex_Single)
|
|
|
|
{
|
|
|
|
AT_INDEX("/a", 0, "a");
|
|
|
|
AT_INDEX("/a/", 0, "a");
|
|
|
|
AT_INDEX("a/", 0, "a");
|
|
|
|
AT_INDEX("//a//", 0, "a");
|
|
|
|
AT_INDEX("a/b", 0, "a");
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2020-11-06 17:49:09 +01:00
|
|
|
AT_INDEX("/a", 1, nullptr);
|
|
|
|
AT_INDEX("/a/", 1, nullptr);
|
|
|
|
AT_INDEX("a/", 1, nullptr);
|
|
|
|
AT_INDEX("//a//", 1, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
TEST(path_util, NameAtIndex_SingleNeg)
|
|
|
|
{
|
|
|
|
AT_INDEX("/a", -1, "a");
|
|
|
|
AT_INDEX("/a/", -1, "a");
|
|
|
|
AT_INDEX("a/", -1, "a");
|
|
|
|
AT_INDEX("//a//", -1, "a");
|
|
|
|
AT_INDEX("a/b", -1, "b");
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2020-11-06 17:49:09 +01:00
|
|
|
AT_INDEX("/a", -2, nullptr);
|
|
|
|
AT_INDEX("/a/", -2, nullptr);
|
|
|
|
AT_INDEX("a/", -2, nullptr);
|
|
|
|
AT_INDEX("//a//", -2, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, NameAtIndex_Double)
|
|
|
|
{
|
|
|
|
AT_INDEX("/ab", 0, "ab");
|
|
|
|
AT_INDEX("/ab/", 0, "ab");
|
|
|
|
AT_INDEX("ab/", 0, "ab");
|
|
|
|
AT_INDEX("//ab//", 0, "ab");
|
|
|
|
AT_INDEX("ab/c", 0, "ab");
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2020-11-06 17:49:09 +01:00
|
|
|
AT_INDEX("/ab", 1, nullptr);
|
|
|
|
AT_INDEX("/ab/", 1, nullptr);
|
|
|
|
AT_INDEX("ab/", 1, nullptr);
|
|
|
|
AT_INDEX("//ab//", 1, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, NameAtIndex_DoublNeg)
|
|
|
|
{
|
|
|
|
AT_INDEX("/ab", -1, "ab");
|
|
|
|
AT_INDEX("/ab/", -1, "ab");
|
|
|
|
AT_INDEX("ab/", -1, "ab");
|
|
|
|
AT_INDEX("//ab//", -1, "ab");
|
|
|
|
AT_INDEX("ab/c", -1, "c");
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2020-11-06 17:49:09 +01:00
|
|
|
AT_INDEX("/ab", -2, nullptr);
|
|
|
|
AT_INDEX("/ab/", -2, nullptr);
|
|
|
|
AT_INDEX("ab/", -2, nullptr);
|
|
|
|
AT_INDEX("//ab//", -2, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, NameAtIndex_Misc)
|
|
|
|
{
|
|
|
|
AT_INDEX("/how/now/brown/cow", 0, "how");
|
|
|
|
AT_INDEX("/how/now/brown/cow", 1, "now");
|
|
|
|
AT_INDEX("/how/now/brown/cow", 2, "brown");
|
|
|
|
AT_INDEX("/how/now/brown/cow", 3, "cow");
|
2020-11-06 17:49:09 +01:00
|
|
|
AT_INDEX("/how/now/brown/cow", 4, nullptr);
|
|
|
|
AT_INDEX("/how/now/brown/cow/", 4, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, NameAtIndex_MiscNeg)
|
|
|
|
{
|
|
|
|
AT_INDEX("/how/now/brown/cow", 0, "how");
|
|
|
|
AT_INDEX("/how/now/brown/cow", 1, "now");
|
|
|
|
AT_INDEX("/how/now/brown/cow", 2, "brown");
|
|
|
|
AT_INDEX("/how/now/brown/cow", 3, "cow");
|
2020-11-06 17:49:09 +01:00
|
|
|
AT_INDEX("/how/now/brown/cow", 4, nullptr);
|
|
|
|
AT_INDEX("/how/now/brown/cow/", 4, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, NameAtIndex_MiscComplex)
|
|
|
|
{
|
|
|
|
AT_INDEX("how//now/brown/cow", 0, "how");
|
2022-10-31 13:21:24 +11:00
|
|
|
AT_INDEX("//how///now//brown/cow", 1, "now");
|
|
|
|
AT_INDEX("/how/now///brown//cow", 2, "brown");
|
|
|
|
AT_INDEX("/how/now/brown/cow///", 3, "cow");
|
|
|
|
AT_INDEX("/how/now/brown//cow", 4, nullptr);
|
|
|
|
AT_INDEX("how/now/brown//cow/", 4, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, NameAtIndex_MiscComplexNeg)
|
|
|
|
{
|
|
|
|
AT_INDEX("how//now/brown/cow", -4, "how");
|
2022-10-31 13:21:24 +11:00
|
|
|
AT_INDEX("//how///now//brown/cow", -3, "now");
|
|
|
|
AT_INDEX("/how/now///brown//cow", -2, "brown");
|
|
|
|
AT_INDEX("/how/now/brown/cow///", -1, "cow");
|
|
|
|
AT_INDEX("/how/now/brown//cow", -5, nullptr);
|
|
|
|
AT_INDEX("how/now/brown//cow/", -5, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, NameAtIndex_NoneComplex)
|
|
|
|
{
|
2020-11-06 17:49:09 +01:00
|
|
|
AT_INDEX("", 0, nullptr);
|
|
|
|
AT_INDEX("/", 0, nullptr);
|
|
|
|
AT_INDEX("//", 0, nullptr);
|
|
|
|
AT_INDEX("///", 0, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, NameAtIndex_NoneComplexNeg)
|
|
|
|
{
|
2020-11-06 17:49:09 +01:00
|
|
|
AT_INDEX("", -1, nullptr);
|
|
|
|
AT_INDEX("/", -1, nullptr);
|
|
|
|
AT_INDEX("//", -1, nullptr);
|
|
|
|
AT_INDEX("///", -1, nullptr);
|
2017-03-22 19:31:34 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
#undef AT_INDEX
|
|
|
|
|
2022-10-31 13:04:30 +11:00
|
|
|
/* For systems with `/` path separator (non WIN32). */
|
|
|
|
#define JOIN_FORWARD_SLASH(str_expect, out_size, ...) \
|
2017-03-24 17:29:48 +11:00
|
|
|
{ \
|
|
|
|
const char *expect = str_expect; \
|
|
|
|
char result[(out_size) + 1024]; \
|
2022-10-31 13:04:30 +11:00
|
|
|
/* Check we don't write past the last byte. */ \
|
2017-03-24 17:29:48 +11:00
|
|
|
result[out_size] = '\0'; \
|
2022-10-17 11:16:41 +11:00
|
|
|
BLI_path_join(result, out_size, __VA_ARGS__); \
|
2022-10-31 13:04:30 +11:00
|
|
|
EXPECT_STREQ(result, expect); \
|
|
|
|
EXPECT_EQ(result[out_size], '\0'); \
|
|
|
|
} \
|
|
|
|
((void)0)
|
|
|
|
|
|
|
|
/* For systems with `\` path separator (WIN32).
|
|
|
|
* Perform additional manipulation to behave as if input arguments used `\` separators.
|
|
|
|
* Needed since #BLI_path_join uses native slashes. */
|
|
|
|
#define JOIN_BACK_SLASH(str_expect, out_size, ...) \
|
|
|
|
{ \
|
|
|
|
const char *expect = str_expect; \
|
|
|
|
char result[(out_size) + 1024]; \
|
|
|
|
const char *input_forward_slash[] = {__VA_ARGS__}; \
|
|
|
|
char *input_back_slash[ARRAY_SIZE(input_forward_slash)] = {nullptr}; \
|
|
|
|
for (int i = 0; i < ARRAY_SIZE(input_forward_slash); i++) { \
|
|
|
|
input_back_slash[i] = strdup(input_forward_slash[i]); \
|
|
|
|
BLI_str_replace_char(input_back_slash[i], '/', '\\'); \
|
|
|
|
} \
|
|
|
|
/* Check we don't write past the last byte. */ \
|
|
|
|
result[out_size] = '\0'; \
|
|
|
|
BLI_path_join_array(result, \
|
|
|
|
out_size, \
|
|
|
|
const_cast<const char **>(input_back_slash), \
|
|
|
|
ARRAY_SIZE(input_back_slash)); \
|
2017-03-24 17:29:48 +11:00
|
|
|
BLI_str_replace_char(result, '\\', '/'); \
|
|
|
|
EXPECT_STREQ(result, expect); \
|
|
|
|
EXPECT_EQ(result[out_size], '\0'); \
|
2022-10-31 13:04:30 +11:00
|
|
|
for (int i = 0; i < ARRAY_SIZE(input_forward_slash); i++) { \
|
|
|
|
free(input_back_slash[i]); \
|
|
|
|
} \
|
2017-03-24 17:29:48 +11:00
|
|
|
} \
|
|
|
|
((void)0)
|
|
|
|
|
2022-10-31 13:04:30 +11:00
|
|
|
#ifdef WIN32
|
|
|
|
# define JOIN JOIN_BACK_SLASH
|
|
|
|
#else
|
|
|
|
# define JOIN JOIN_FORWARD_SLASH
|
|
|
|
#endif
|
|
|
|
|
2017-03-24 17:29:48 +11:00
|
|
|
/* BLI_path_join */
|
|
|
|
TEST(path_util, JoinNop)
|
|
|
|
{
|
|
|
|
JOIN("", 100, "");
|
|
|
|
JOIN("", 100, "", "");
|
|
|
|
JOIN("", 100, "", "", "");
|
|
|
|
JOIN("/", 100, "/", "", "");
|
|
|
|
JOIN("/", 100, "/", "/");
|
|
|
|
JOIN("/", 100, "/", "", "/");
|
|
|
|
JOIN("/", 100, "/", "", "/", "");
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, JoinSingle)
|
|
|
|
{
|
|
|
|
JOIN("test", 100, "test");
|
|
|
|
JOIN("", 100, "");
|
|
|
|
JOIN("a", 100, "a");
|
|
|
|
JOIN("/a", 100, "/a");
|
|
|
|
JOIN("a/", 100, "a/");
|
|
|
|
JOIN("/a/", 100, "/a/");
|
|
|
|
JOIN("/a/", 100, "/a//");
|
|
|
|
JOIN("//a/", 100, "//a//");
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, JoinTriple)
|
|
|
|
{
|
|
|
|
JOIN("/a/b/c", 100, "/a", "b", "c");
|
|
|
|
JOIN("/a/b/c", 100, "/a/", "/b/", "/c");
|
|
|
|
JOIN("/a/b/c", 100, "/a/b/", "/c");
|
|
|
|
JOIN("/a/b/c", 100, "/a/b/c");
|
|
|
|
JOIN("/a/b/c", 100, "/", "a/b/c");
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2017-03-24 17:29:48 +11:00
|
|
|
JOIN("/a/b/c/", 100, "/a/", "/b/", "/c/");
|
|
|
|
JOIN("/a/b/c/", 100, "/a/b/c/");
|
|
|
|
JOIN("/a/b/c/", 100, "/a/b/", "/c/");
|
|
|
|
JOIN("/a/b/c/", 100, "/a/b/c", "/");
|
|
|
|
JOIN("/a/b/c/", 100, "/", "a/b/c", "/");
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, JoinTruncateShort)
|
|
|
|
{
|
|
|
|
JOIN("", 1, "/");
|
|
|
|
JOIN("/", 2, "/");
|
|
|
|
JOIN("a", 2, "", "aa");
|
|
|
|
JOIN("a", 2, "", "a/");
|
|
|
|
JOIN("a/b", 4, "a", "bc");
|
|
|
|
JOIN("ab/", 4, "ab", "c");
|
|
|
|
JOIN("/a/", 4, "/a", "b");
|
|
|
|
JOIN("/a/", 4, "/a/", "b/");
|
|
|
|
JOIN("/a/", 4, "/a", "/b/");
|
|
|
|
JOIN("/a/", 4, "/", "a/b/");
|
|
|
|
JOIN("//a", 4, "//", "a/b/");
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2017-03-24 17:29:48 +11:00
|
|
|
JOIN("/a/b", 5, "/a", "b", "c");
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, JoinTruncateLong)
|
|
|
|
{
|
|
|
|
JOIN("", 1, "//", "//longer", "path");
|
|
|
|
JOIN("/", 2, "//", "//longer", "path");
|
|
|
|
JOIN("//", 3, "//", "//longer", "path");
|
|
|
|
JOIN("//l", 4, "//", "//longer", "path");
|
|
|
|
/* snip */
|
|
|
|
JOIN("//longe", 8, "//", "//longer", "path");
|
|
|
|
JOIN("//longer", 9, "//", "//longer", "path");
|
|
|
|
JOIN("//longer/", 10, "//", "//longer", "path");
|
|
|
|
JOIN("//longer/p", 11, "//", "//longer", "path");
|
|
|
|
JOIN("//longer/pa", 12, "//", "//longer", "path");
|
|
|
|
JOIN("//longer/pat", 13, "//", "//longer", "path");
|
|
|
|
JOIN("//longer/path", 14, "//", "//longer", "path"); /* not truncated. */
|
|
|
|
JOIN("//longer/path", 14, "//", "//longer", "path/");
|
|
|
|
JOIN("//longer/path/", 15, "//", "//longer", "path/"); /* not truncated. */
|
|
|
|
JOIN("//longer/path/", 15, "//", "//longer", "path/", "trunc");
|
|
|
|
JOIN("//longer/path/t", 16, "//", "//longer", "path/", "trunc");
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(path_util, JoinComplex)
|
|
|
|
{
|
2022-10-31 13:04:30 +11:00
|
|
|
JOIN("/a/b/c/d/e/f/g/", 100, "/", "a/b", "//////c/d", "", "e", "f", "g//");
|
|
|
|
JOIN("/aa/bb/cc/dd/ee/ff/gg/", 100, "/", "aa/bb", "//////cc/dd", "", "ee", "ff", "gg//");
|
|
|
|
JOIN("1/2/3/", 100, "1", "////////", "", "2", "3///");
|
2017-03-24 17:29:48 +11:00
|
|
|
}
|
|
|
|
|
2022-09-12 10:39:24 +10:00
|
|
|
TEST(path_util, JoinRelativePrefix)
|
|
|
|
{
|
|
|
|
JOIN("//a/b/c", 100, "//a", "b", "c");
|
|
|
|
JOIN("//a/b/c", 100, "//", "//a//", "//b//", "//c");
|
|
|
|
JOIN("//a/b/c", 100, "//", "//", "a", "//", "b", "//", "c");
|
|
|
|
}
|
|
|
|
|
2017-03-24 17:29:48 +11:00
|
|
|
#undef JOIN
|
2022-10-31 13:04:30 +11:00
|
|
|
#undef JOIN_BACK_SLASH
|
|
|
|
#undef JOIN_FORWARD_SLASH
|
2017-03-22 19:31:34 +11:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
/* BLI_path_frame */
|
2017-03-24 17:48:22 +11:00
|
|
|
TEST(path_util, Frame)
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
bool ret;
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "";
|
|
|
|
ret = BLI_path_frame(path, 123, 1);
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_TRUE(ret);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("123", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "";
|
|
|
|
ret = BLI_path_frame(path, 123, 12);
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_TRUE(ret);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("000000000123", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "test_";
|
|
|
|
ret = BLI_path_frame(path, 123, 1);
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_TRUE(ret);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("test_123", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "test_";
|
|
|
|
ret = BLI_path_frame(path, 1, 12);
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_TRUE(ret);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("test_000000000001", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "test_############";
|
|
|
|
ret = BLI_path_frame(path, 1, 0);
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_TRUE(ret);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("test_000000000001", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "test_#_#_middle";
|
|
|
|
ret = BLI_path_frame(path, 123, 0);
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_TRUE(ret);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("test_#_123_middle", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
/* intentionally fail */
|
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "";
|
|
|
|
ret = BLI_path_frame(path, 123, 0);
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_FALSE(ret);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("", path);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "test_middle";
|
|
|
|
ret = BLI_path_frame(path, 123, 0);
|
2020-03-16 10:53:22 +01:00
|
|
|
EXPECT_FALSE(ret);
|
2014-06-18 22:49:17 +10:00
|
|
|
EXPECT_STREQ("test_middle", path);
|
|
|
|
}
|
2020-07-03 15:27:02 +02:00
|
|
|
|
|
|
|
/* negative frame numbers */
|
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "test_####";
|
|
|
|
ret = BLI_path_frame(path, -1, 4);
|
|
|
|
EXPECT_TRUE(ret);
|
|
|
|
EXPECT_STREQ("test_-0001", path);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
char path[FILE_MAX] = "test_####";
|
|
|
|
ret = BLI_path_frame(path, -100, 4);
|
|
|
|
EXPECT_TRUE(ret);
|
|
|
|
EXPECT_STREQ("test_-0100", path);
|
|
|
|
}
|
2014-06-18 22:49:17 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/* BLI_split_dirfile */
|
2017-03-24 17:48:22 +11:00
|
|
|
TEST(path_util, SplitDirfile)
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
{
|
|
|
|
const char *path = "";
|
|
|
|
char dir[FILE_MAX], file[FILE_MAX];
|
|
|
|
BLI_split_dirfile(path, dir, file, sizeof(dir), sizeof(file));
|
|
|
|
EXPECT_STREQ("", dir);
|
|
|
|
EXPECT_STREQ("", file);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
const char *path = "/";
|
|
|
|
char dir[FILE_MAX], file[FILE_MAX];
|
|
|
|
BLI_split_dirfile(path, dir, file, sizeof(dir), sizeof(file));
|
|
|
|
EXPECT_STREQ("/", dir);
|
|
|
|
EXPECT_STREQ("", file);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
const char *path = "fileonly";
|
|
|
|
char dir[FILE_MAX], file[FILE_MAX];
|
|
|
|
BLI_split_dirfile(path, dir, file, sizeof(dir), sizeof(file));
|
|
|
|
EXPECT_STREQ("", dir);
|
|
|
|
EXPECT_STREQ("fileonly", file);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
const char *path = "dironly/";
|
|
|
|
char dir[FILE_MAX], file[FILE_MAX];
|
|
|
|
BLI_split_dirfile(path, dir, file, sizeof(dir), sizeof(file));
|
|
|
|
EXPECT_STREQ("dironly/", dir);
|
|
|
|
EXPECT_STREQ("", file);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
const char *path = "/a/b";
|
|
|
|
char dir[FILE_MAX], file[FILE_MAX];
|
|
|
|
BLI_split_dirfile(path, dir, file, sizeof(dir), sizeof(file));
|
|
|
|
EXPECT_STREQ("/a/", dir);
|
|
|
|
EXPECT_STREQ("b", file);
|
|
|
|
}
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
{
|
|
|
|
const char *path = "/dirtoobig/filetoobig";
|
|
|
|
char dir[5], file[5];
|
|
|
|
BLI_split_dirfile(path, dir, file, sizeof(dir), sizeof(file));
|
|
|
|
EXPECT_STREQ("/dir", dir);
|
|
|
|
EXPECT_STREQ("file", file);
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2014-06-18 22:49:17 +10:00
|
|
|
BLI_split_dirfile(path, dir, file, 1, 1);
|
|
|
|
EXPECT_STREQ("", dir);
|
|
|
|
EXPECT_STREQ("", file);
|
|
|
|
}
|
|
|
|
}
|
Fix BLI_path_frame_strip
The `BLI_path_frame_strip` function was completely broken, unless the
number of digits in the sequence number was the same as the length of
the extension. In other words, it would work fine for `file.0001.abc` (4
digit `0001` and 4 char `.abc`), but other combinations would truncate
to the shortest (`file.001.abc` would become `file.###.ab` and
`file.00001.a` would become `file.##.a`). The dependency between the
sequence number and the file extension is now removed.
The behaviour has changed a little bit in the case where there are no
numbers in the filename. Previously, `path="filename.abc"` would result
in `path="filename.abc"` and `ext=""`, but now it results in
`path="filename"` and `ext=".abc"`. This way `ext` always contains the
extension, and the behaviour is consistent regardless of whether there
were any numbers found.
Furthermore, I've removed the `bool set_frame_char` parameter, because
it was unclear, probably also buggy, and most importantly, never used.
I've also added a unit test for the `BLI_path_frame_strip` function.
2019-03-20 12:59:11 +01:00
|
|
|
|
|
|
|
#define PATH_FRAME_STRIP(input_path, expect_path, expect_ext) \
|
|
|
|
{ \
|
|
|
|
char path[FILE_MAX]; \
|
|
|
|
char ext[FILE_MAX]; \
|
|
|
|
BLI_strncpy(path, (input_path), FILE_MAX); \
|
|
|
|
BLI_path_frame_strip(path, ext); \
|
|
|
|
EXPECT_STREQ(path, expect_path); \
|
|
|
|
EXPECT_STREQ(ext, expect_ext); \
|
2019-12-10 12:00:49 +11:00
|
|
|
} \
|
|
|
|
((void)0)
|
Fix BLI_path_frame_strip
The `BLI_path_frame_strip` function was completely broken, unless the
number of digits in the sequence number was the same as the length of
the extension. In other words, it would work fine for `file.0001.abc` (4
digit `0001` and 4 char `.abc`), but other combinations would truncate
to the shortest (`file.001.abc` would become `file.###.ab` and
`file.00001.a` would become `file.##.a`). The dependency between the
sequence number and the file extension is now removed.
The behaviour has changed a little bit in the case where there are no
numbers in the filename. Previously, `path="filename.abc"` would result
in `path="filename.abc"` and `ext=""`, but now it results in
`path="filename"` and `ext=".abc"`. This way `ext` always contains the
extension, and the behaviour is consistent regardless of whether there
were any numbers found.
Furthermore, I've removed the `bool set_frame_char` parameter, because
it was unclear, probably also buggy, and most importantly, never used.
I've also added a unit test for the `BLI_path_frame_strip` function.
2019-03-20 12:59:11 +01:00
|
|
|
|
|
|
|
/* BLI_path_frame_strip */
|
|
|
|
TEST(path_util, PathFrameStrip)
|
|
|
|
{
|
|
|
|
PATH_FRAME_STRIP("", "", "");
|
|
|
|
PATH_FRAME_STRIP("nonum.abc", "nonum", ".abc");
|
|
|
|
PATH_FRAME_STRIP("fileonly.001.abc", "fileonly.###", ".abc");
|
|
|
|
PATH_FRAME_STRIP("/abspath/to/somefile.001.abc", "/abspath/to/somefile.###", ".abc");
|
|
|
|
PATH_FRAME_STRIP("/ext/longer/somefile.001.alembic", "/ext/longer/somefile.###", ".alembic");
|
|
|
|
PATH_FRAME_STRIP("/ext/shorter/somefile.123001.abc", "/ext/shorter/somefile.######", ".abc");
|
|
|
|
}
|
|
|
|
#undef PATH_FRAME_STRIP
|
2019-04-29 12:49:56 +10:00
|
|
|
|
|
|
|
#define PATH_EXTENSION_CHECK(input_path, input_ext, expect_ext) \
|
|
|
|
{ \
|
|
|
|
const bool ret = BLI_path_extension_check(input_path, input_ext); \
|
2022-09-26 13:58:49 +10:00
|
|
|
if (STREQ(input_ext, expect_ext)) { \
|
2019-04-29 12:49:56 +10:00
|
|
|
EXPECT_TRUE(ret); \
|
|
|
|
} \
|
|
|
|
else { \
|
|
|
|
EXPECT_FALSE(ret); \
|
|
|
|
} \
|
|
|
|
} \
|
|
|
|
((void)0)
|
|
|
|
|
|
|
|
/* BLI_path_extension_check */
|
|
|
|
TEST(path_util, PathExtensionCheck)
|
|
|
|
{
|
|
|
|
PATH_EXTENSION_CHECK("a/b/c.exe", ".exe", ".exe");
|
|
|
|
PATH_EXTENSION_CHECK("correct/path/to/file.h", ".h", ".h");
|
|
|
|
PATH_EXTENSION_CHECK("correct/path/to/file.BLEND", ".BLEND", ".BLEND");
|
|
|
|
PATH_EXTENSION_CHECK("../tricky/path/to/file.h", ".h", ".h");
|
|
|
|
PATH_EXTENSION_CHECK("../dirty//../path\\to/file.h", ".h", ".h");
|
|
|
|
PATH_EXTENSION_CHECK("a/b/c.veryveryverylonglonglongextension",
|
|
|
|
".veryveryverylonglonglongextension",
|
|
|
|
".veryveryverylonglonglongextension");
|
|
|
|
PATH_EXTENSION_CHECK("filename.PNG", "pnG", "pnG");
|
|
|
|
PATH_EXTENSION_CHECK("a/b/c.h.exe", ".exe", ".exe");
|
|
|
|
PATH_EXTENSION_CHECK("a/b/c.h.exe", "exe", "exe");
|
|
|
|
PATH_EXTENSION_CHECK("a/b/c.exe", "c.exe", "c.exe");
|
|
|
|
PATH_EXTENSION_CHECK("a/b/noext", "noext", "noext");
|
|
|
|
|
|
|
|
PATH_EXTENSION_CHECK("a/b/c.exe", ".png", ".exe");
|
|
|
|
PATH_EXTENSION_CHECK("a/b/c.exe", "c.png", ".exe");
|
|
|
|
PATH_EXTENSION_CHECK("a/b/s.l", "l.s", "s.l");
|
|
|
|
PATH_EXTENSION_CHECK(".hiddenfolder", "", ".hiddenfolder");
|
|
|
|
PATH_EXTENSION_CHECK("../dirty//../path\\to/actual.h.file.ext", ".h", ".ext");
|
|
|
|
PATH_EXTENSION_CHECK("..\\dirty//../path//to/.hiddenfile.JPEG", ".hiddenfile", ".JPEG");
|
|
|
|
}
|
|
|
|
#undef PATH_EXTENSION_CHECK
|
|
|
|
|
|
|
|
#define PATH_FRAME_CHECK_CHARS(input_path, expect_hasChars) \
|
|
|
|
{ \
|
|
|
|
const bool ret = BLI_path_frame_check_chars(input_path); \
|
|
|
|
if (expect_hasChars) { \
|
|
|
|
EXPECT_TRUE(ret); \
|
|
|
|
} \
|
|
|
|
else { \
|
|
|
|
EXPECT_FALSE(ret); \
|
|
|
|
} \
|
|
|
|
} \
|
|
|
|
((void)0)
|
|
|
|
|
|
|
|
/* BLI_path_frame_check_chars */
|
|
|
|
TEST(path_util, PathFrameCheckChars)
|
|
|
|
{
|
|
|
|
PATH_FRAME_CHECK_CHARS("a#", true);
|
|
|
|
PATH_FRAME_CHECK_CHARS("aaaaa#", true);
|
|
|
|
PATH_FRAME_CHECK_CHARS("#aaaaa", true);
|
|
|
|
PATH_FRAME_CHECK_CHARS("a##.###", true);
|
|
|
|
PATH_FRAME_CHECK_CHARS("####.abc#", true);
|
|
|
|
PATH_FRAME_CHECK_CHARS("path/to/chars/a#", true);
|
|
|
|
PATH_FRAME_CHECK_CHARS("path/to/chars/123#123.exe", true);
|
|
|
|
|
|
|
|
PATH_FRAME_CHECK_CHARS("&", false);
|
|
|
|
PATH_FRAME_CHECK_CHARS("\35", false);
|
|
|
|
PATH_FRAME_CHECK_CHARS("path#/to#/chars#/$.h", false);
|
|
|
|
PATH_FRAME_CHECK_CHARS("path#/to#/chars#/nochars.h", false);
|
|
|
|
PATH_FRAME_CHECK_CHARS("..\\dirty\\path#/..//to#\\chars#/nochars.h", false);
|
|
|
|
PATH_FRAME_CHECK_CHARS("..\\dirty\\path#/..//to#/chars#\\nochars.h", false);
|
|
|
|
}
|
|
|
|
#undef PATH_FRAME_CHECK_CHARS
|
|
|
|
|
|
|
|
#define PATH_FRAME_RANGE(input_path, sta, end, digits, expect_outpath) \
|
|
|
|
{ \
|
|
|
|
char path[FILE_MAX]; \
|
|
|
|
bool ret; \
|
|
|
|
BLI_strncpy(path, input_path, FILE_MAX); \
|
|
|
|
ret = BLI_path_frame_range(path, sta, end, digits); \
|
|
|
|
if (expect_outpath == NULL) { \
|
|
|
|
EXPECT_FALSE(ret); \
|
|
|
|
} \
|
|
|
|
else { \
|
|
|
|
EXPECT_TRUE(ret); \
|
|
|
|
EXPECT_STREQ(path, expect_outpath); \
|
|
|
|
} \
|
|
|
|
} \
|
|
|
|
((void)0)
|
|
|
|
|
|
|
|
/* BLI_path_frame_range */
|
|
|
|
TEST(path_util, PathFrameRange)
|
|
|
|
{
|
|
|
|
int dummy = -1;
|
|
|
|
PATH_FRAME_RANGE("#", 1, 2, dummy, "1-2");
|
|
|
|
PATH_FRAME_RANGE("##", 1, 2, dummy, "01-02");
|
|
|
|
PATH_FRAME_RANGE("##", 1000, 2000, dummy, "1000-2000");
|
|
|
|
PATH_FRAME_RANGE("###", 100, 200, dummy, "100-200");
|
|
|
|
PATH_FRAME_RANGE("###", 8, 9, dummy, "008-009");
|
|
|
|
|
|
|
|
PATH_FRAME_RANGE("", 100, 200, 1, "100-200");
|
|
|
|
PATH_FRAME_RANGE("", 123, 321, 4, "0123-0321");
|
|
|
|
PATH_FRAME_RANGE("", 1, 0, 20, "00000000000000000001-00000000000000000000");
|
|
|
|
}
|
|
|
|
#undef PATH_FRAME_RANGE
|
|
|
|
|
|
|
|
#define PATH_FRAME_GET(input_path, expect_frame, expect_numdigits, expect_pathisvalid) \
|
|
|
|
{ \
|
|
|
|
char path[FILE_MAX]; \
|
|
|
|
int out_frame = -1, out_numdigits = -1; \
|
|
|
|
BLI_strncpy(path, input_path, FILE_MAX); \
|
|
|
|
const bool ret = BLI_path_frame_get(path, &out_frame, &out_numdigits); \
|
|
|
|
if (expect_pathisvalid) { \
|
|
|
|
EXPECT_TRUE(ret); \
|
|
|
|
} \
|
|
|
|
else { \
|
|
|
|
EXPECT_FALSE(ret); \
|
|
|
|
} \
|
|
|
|
EXPECT_EQ(out_frame, expect_frame); \
|
|
|
|
EXPECT_EQ(out_numdigits, expect_numdigits); \
|
|
|
|
} \
|
|
|
|
((void)0)
|
|
|
|
|
|
|
|
/* BLI_path_frame_get */
|
|
|
|
TEST(path_util, PathFrameGet)
|
|
|
|
{
|
|
|
|
PATH_FRAME_GET("001.avi", 1, 3, true);
|
|
|
|
PATH_FRAME_GET("0000299.ext", 299, 7, true);
|
|
|
|
PATH_FRAME_GET("path/to/frame_2810.dummy_quite_long_extension", 2810, 4, true);
|
|
|
|
PATH_FRAME_GET("notframe_7_frame00018.bla", 18, 5, true);
|
|
|
|
|
|
|
|
PATH_FRAME_GET("", -1, -1, false);
|
|
|
|
}
|
|
|
|
#undef PATH_FRAME_GET
|
2019-08-13 15:35:48 +02:00
|
|
|
|
|
|
|
/* BLI_path_extension */
|
|
|
|
TEST(path_util, PathExtension)
|
|
|
|
{
|
2020-11-06 17:49:09 +01:00
|
|
|
EXPECT_EQ(nullptr, BLI_path_extension("some.def/file"));
|
|
|
|
EXPECT_EQ(nullptr, BLI_path_extension("Text"));
|
|
|
|
EXPECT_EQ(nullptr, BLI_path_extension("Text…001"));
|
2019-08-13 15:35:48 +02:00
|
|
|
|
2019-08-15 01:34:58 +10:00
|
|
|
EXPECT_STREQ(".", BLI_path_extension("some/file."));
|
|
|
|
EXPECT_STREQ(".gz", BLI_path_extension("some/file.tar.gz"));
|
2019-08-13 15:35:48 +02:00
|
|
|
EXPECT_STREQ(".abc", BLI_path_extension("some.def/file.abc"));
|
|
|
|
EXPECT_STREQ(".abc", BLI_path_extension("C:\\some.def\\file.abc"));
|
|
|
|
EXPECT_STREQ(".001", BLI_path_extension("Text.001"));
|
|
|
|
}
|
2020-10-26 16:31:11 +01:00
|
|
|
|
|
|
|
/* BLI_path_rel. */
|
2020-10-26 18:29:54 +01:00
|
|
|
#ifndef _WIN32
|
2020-10-26 16:31:11 +01:00
|
|
|
|
2020-10-26 18:29:54 +01:00
|
|
|
# define PATH_REL(abs_path, ref_path, rel_path) \
|
|
|
|
{ \
|
|
|
|
char path[FILE_MAX]; \
|
|
|
|
BLI_strncpy(path, abs_path, sizeof(path)); \
|
|
|
|
BLI_path_rel(path, ref_path); \
|
|
|
|
EXPECT_STREQ(rel_path, path); \
|
|
|
|
} \
|
|
|
|
void(0)
|
2020-10-26 16:31:11 +01:00
|
|
|
|
|
|
|
TEST(path_util, PathRelPath)
|
|
|
|
{
|
|
|
|
PATH_REL("/foo/bar/blender.blend", "/foo/bar/", "//blender.blend");
|
|
|
|
PATH_REL("/foo/bar/blender.blend", "/foo/bar", "//bar/blender.blend");
|
|
|
|
|
|
|
|
/* Check for potential buffer overflows. */
|
|
|
|
{
|
|
|
|
char abs_path_in[FILE_MAX];
|
|
|
|
abs_path_in[0] = '/';
|
|
|
|
for (int i = 1; i < FILE_MAX - 1; i++) {
|
|
|
|
abs_path_in[i] = 'A';
|
|
|
|
}
|
|
|
|
abs_path_in[FILE_MAX - 1] = '\0';
|
|
|
|
char abs_path_out[FILE_MAX];
|
|
|
|
abs_path_out[0] = '/';
|
|
|
|
abs_path_out[1] = '/';
|
|
|
|
for (int i = 2; i < FILE_MAX - 1; i++) {
|
|
|
|
abs_path_out[i] = 'A';
|
|
|
|
}
|
|
|
|
abs_path_out[FILE_MAX - 1] = '\0';
|
|
|
|
PATH_REL(abs_path_in, "/", abs_path_out);
|
|
|
|
|
|
|
|
const char *ref_path_in = "/foo/bar/";
|
|
|
|
const size_t ref_path_in_len = strlen(ref_path_in);
|
|
|
|
strcpy(abs_path_in, ref_path_in);
|
|
|
|
for (int i = ref_path_in_len; i < FILE_MAX - 1; i++) {
|
|
|
|
abs_path_in[i] = 'A';
|
|
|
|
}
|
|
|
|
abs_path_in[FILE_MAX - 1] = '\0';
|
|
|
|
abs_path_out[0] = '/';
|
|
|
|
abs_path_out[1] = '/';
|
2022-09-25 18:33:28 +10:00
|
|
|
for (int i = 2; i < FILE_MAX - (int(ref_path_in_len) - 1); i++) {
|
2020-10-26 16:31:11 +01:00
|
|
|
abs_path_out[i] = 'A';
|
|
|
|
}
|
|
|
|
abs_path_out[FILE_MAX - (ref_path_in_len - 1)] = '\0';
|
|
|
|
PATH_REL(abs_path_in, ref_path_in, abs_path_out);
|
|
|
|
}
|
|
|
|
}
|
2020-10-26 18:29:54 +01:00
|
|
|
|
|
|
|
# undef PATH_REL
|
|
|
|
|
|
|
|
#endif
|
2021-09-27 15:22:53 +02:00
|
|
|
|
|
|
|
/* BLI_path_contains */
|
|
|
|
TEST(path_util, PathContains)
|
|
|
|
{
|
|
|
|
EXPECT_TRUE(BLI_path_contains("/some/path", "/some/path")) << "A path contains itself";
|
|
|
|
EXPECT_TRUE(BLI_path_contains("/some/path", "/some/path/inside"))
|
|
|
|
<< "A path contains its subdirectory";
|
|
|
|
EXPECT_TRUE(BLI_path_contains("/some/path", "/some/path/../path/inside"))
|
2022-05-11 17:01:06 +10:00
|
|
|
<< "Paths should be normalized";
|
2021-09-27 15:22:53 +02:00
|
|
|
EXPECT_TRUE(BLI_path_contains("C:\\some\\path", "C:\\some\\path\\inside"))
|
|
|
|
<< "Windows paths should be supported as well";
|
|
|
|
|
|
|
|
EXPECT_FALSE(BLI_path_contains("C:\\some\\path", "C:\\some\\other\\path"))
|
|
|
|
<< "Windows paths should be supported as well";
|
|
|
|
EXPECT_FALSE(BLI_path_contains("/some/path", "/"))
|
|
|
|
<< "Root directory not be contained in a subdirectory";
|
|
|
|
EXPECT_FALSE(BLI_path_contains("/some/path", "/some/path/../outside"))
|
2022-05-11 17:01:06 +10:00
|
|
|
<< "Paths should be normalized";
|
2021-09-27 15:22:53 +02:00
|
|
|
EXPECT_FALSE(BLI_path_contains("/some/path", "/some/path_library"))
|
|
|
|
<< "Just sharing a suffix is not enough, path semantics should be followed";
|
|
|
|
EXPECT_FALSE(BLI_path_contains("/some/path", "./contents"))
|
|
|
|
<< "Relative paths are not supported";
|
|
|
|
}
|
2021-09-28 11:05:45 +02:00
|
|
|
|
|
|
|
#ifdef WIN32
|
|
|
|
TEST(path_util, PathContains_Windows_case_insensitive)
|
|
|
|
{
|
|
|
|
EXPECT_TRUE(BLI_path_contains("C:\\some\\path", "c:\\SOME\\path\\inside"))
|
|
|
|
<< "On Windows path comparison should ignore case";
|
|
|
|
}
|
|
|
|
#endif
|