Fixed a bug with normalizing paths that contain dot folders

- Added additional tests
This commit is contained in:
Sam Surtees 2018-01-08 03:21:55 +10:00
parent ef9b341d6f
commit 9039232548
2 changed files with 11 additions and 1 deletions

View File

@ -35,7 +35,8 @@ static void* normalize_substring(const char* str, const char* endPtr, char* writ
ptr = writePtr - 3;
while (ptr >= writeBegin) {
if (ptr[0] == '/' && ptr[1] != '.' && ptr[2] != '.') {
/* break on '/' except when it's '/../' */
if (ptr[0] == '/' && !(ptr[1] == '.' && ptr[2] == '.' && ptr[3] == '/')) {
writePtr -= writePtr - ptr;
/* special fix for cases, when '..' is the last chars in path i.e. d:\game\.., this should be converted into d:\,

View File

@ -683,4 +683,13 @@
function suite.normalize_legitimateDots()
test.isequal("d:/test/test..test", path.normalize("d:/test/test..test"))
test.isequal("d:/test..test/test", path.normalize("d:/test..test/test"))
test.isequal("d:/test/.test", path.normalize("d:/test/.test"))
test.isequal("d:/.test", path.normalize("d:/test/../.test"))
test.isequal("d:/test", path.normalize("d:/test/.test/.."))
test.isequal("d:/test/..test", path.normalize("d:/test/..test"))
test.isequal("d:/..test", path.normalize("d:/test/../..test"))
test.isequal("d:/test", path.normalize("d:/test/..test/.."))
test.isequal("d:/test/.test", path.normalize("d:/test/..test/../.test"))
test.isequal("d:/test/..test/.test", path.normalize("d:/test/..test/test/../.test"))
test.isequal("d:/test", path.normalize("d:/test/..test/../.test/.."))
end