Browse Source

AK: Allow trailing '*'s in a glob pattern to match nothing

Fixes part of #4607.
AnotherTest 4 years ago
parent
commit
cbe0a8b403
2 changed files with 16 additions and 0 deletions
  1. 8 0
      AK/StringUtils.cpp
  2. 8 0
      AK/Tests/TestStringUtils.cpp

+ 8 - 0
AK/StringUtils.cpp

@@ -93,6 +93,14 @@ bool matches(const StringView& str, const StringView& mask, CaseSensitivity case
         ++mask_ptr;
     }
 
+    if (string_ptr == string_end) {
+        // Allow ending '*' to contain nothing.
+        while (mask_ptr != mask_end && *mask_ptr == '*') {
+            record_span(string_ptr - string_start, 0);
+            ++mask_ptr;
+        }
+    }
+
     return string_ptr == string_end && mask_ptr == mask_end;
 }
 

+ 8 - 0
AK/Tests/TestStringUtils.cpp

@@ -86,6 +86,14 @@ TEST_CASE(matches_with_positions)
     EXPECT_EQ(spans, Vector<AK::MaskSpan>({ { 1, 3 } }));
 }
 
+// #4607
+TEST_CASE(matches_trailing)
+{
+    EXPECT(AK::StringUtils::matches("ab", "ab*"));
+    EXPECT(AK::StringUtils::matches("ab", "ab****"));
+    EXPECT(AK::StringUtils::matches("ab", "*ab****"));
+}
+
 TEST_CASE(convert_to_int)
 {
     auto value = AK::StringUtils::convert_to_int(StringView());