Răsfoiți Sursa

Fix handling of leading `..` in simplify_path

Prior to this `..\..\texture.png` was incorrectly simplified to `texture.png`
demolke 8 luni în urmă
părinte
comite
964e2b3a9e
2 a modificat fișierele cu 5 adăugiri și 1 ștergeri
  1. 1 1
      core/string/ustring.cpp
  2. 4 0
      tests/core/string/test_string.h

+ 1 - 1
core/string/ustring.cpp

@@ -4608,7 +4608,7 @@ String String::simplify_path() const {
 			dirs.remove_at(i);
 			i--;
 		} else if (d == "..") {
-			if (i != 0) {
+			if (i != 0 && dirs[i - 1] != "..") {
 				dirs.remove_at(i);
 				dirs.remove_at(i - 1);
 				i -= 2;

+ 4 - 0
tests/core/string/test_string.h

@@ -1687,6 +1687,10 @@ TEST_CASE("[String] Path functions") {
 	for (int i = 0; i < 3; i++) {
 		CHECK(String(file_name[i]).is_valid_filename() == valid[i]);
 	}
+
+	CHECK(String("res://texture.png") == String("res://folder/../folder/../texture.png").simplify_path());
+	CHECK(String("res://texture.png") == String("res://folder/sub/../../texture.png").simplify_path());
+	CHECK(String("res://../../texture.png") == String("res://../../texture.png").simplify_path());
 }
 
 TEST_CASE("[String] hash") {