mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-22 17:24:48 -05:00
AK: Fix String::matches() with non-null-terminated StringViews.
StringView character buffer is not guaranteed to be null-terminated; in particular it will not be null-terminated when making a substring. This means it is not correct to check whether we've reached the end of a StringView by comparing the next character to null; instead, we need to do an explicit length (or pointer) comparison.
This commit is contained in:
parent
c1bbd40b9e
commit
e585ed48b0
Notes:
sideshowbarker
2024-07-19 13:37:56 +09:00
Author: https://github.com/bugaevc Commit: https://github.com/SerenityOS/serenity/commit/e585ed48b0b Pull-request: https://github.com/SerenityOS/serenity/pull/227 Reviewed-by: https://github.com/awesomekling
1 changed files with 7 additions and 6 deletions
|
@ -230,9 +230,10 @@ bool String::match_helper(const StringView& mask) const
|
|||
|
||||
const char* string_ptr = characters();
|
||||
const char* mask_ptr = mask.characters();
|
||||
const char* mask_end = mask_ptr + mask.length();
|
||||
|
||||
// Match string against mask directly unless we hit a *
|
||||
while ((*string_ptr) && (*mask_ptr != '*')) {
|
||||
while ((*string_ptr) && (mask_ptr < mask_end) && (*mask_ptr != '*')) {
|
||||
if ((*mask_ptr != *string_ptr) && (*mask_ptr != '?'))
|
||||
return false;
|
||||
mask_ptr++;
|
||||
|
@ -243,13 +244,13 @@ bool String::match_helper(const StringView& mask) const
|
|||
const char* mp = nullptr;
|
||||
|
||||
while (*string_ptr) {
|
||||
if (*mask_ptr == '*') {
|
||||
if ((mask_ptr < mask_end) && (*mask_ptr == '*')) {
|
||||
// If we have only a * left, there is no way to not match.
|
||||
if (!*++mask_ptr)
|
||||
if (++mask_ptr == mask_end)
|
||||
return true;
|
||||
mp = mask_ptr;
|
||||
cp = string_ptr + 1;
|
||||
} else if ((*mask_ptr == *string_ptr) || (*mask_ptr == '?')) {
|
||||
} else if ((mask_ptr < mask_end) && ((*mask_ptr == *string_ptr) || (*mask_ptr == '?'))) {
|
||||
mask_ptr++;
|
||||
string_ptr++;
|
||||
} else {
|
||||
|
@ -259,11 +260,11 @@ bool String::match_helper(const StringView& mask) const
|
|||
}
|
||||
|
||||
// Handle any trailing mask
|
||||
while (*mask_ptr == '*')
|
||||
while ((mask_ptr < mask_end) && (*mask_ptr == '*'))
|
||||
mask_ptr++;
|
||||
|
||||
// If we 'ate' all of the mask then we match.
|
||||
return !*mask_ptr;
|
||||
return mask_ptr == mask_end;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue