Chromium Code Reviews| Index: third_party/WebKit/Source/wtf/text/StringView.cpp |
| diff --git a/third_party/WebKit/Source/wtf/text/StringView.cpp b/third_party/WebKit/Source/wtf/text/StringView.cpp |
| index 115ac20684b447eec920379a9a37b18cf09384fb..e87ce51218a18ac154ac9bea79420cf17ac85eee 100644 |
| --- a/third_party/WebKit/Source/wtf/text/StringView.cpp |
| +++ b/third_party/WebKit/Source/wtf/text/StringView.cpp |
| @@ -63,6 +63,28 @@ bool equalStringView(const StringView& a, const StringView& b) |
| return equal(a.characters16(), b.characters16(), a.length()); |
| } |
| + |
| +bool equalIgnoringCaseAndNullity(const StringView& a, const StringView& b) |
| +{ |
|
haraken
2016/08/04 09:05:28
Can we add:
DCHECK(!a.isNull());
DCHECK(!b.is
esprehn
2016/08/04 18:30:07
No since the semantics are that you still allow nu
|
| + if (a.length() != b.length()) |
| + return false; |
| + if (a.is8Bit()) { |
| + if (b.is8Bit()) |
| + return equalIgnoringCase(a.characters8(), b.characters8(), a.length()); |
| + return equalIgnoringCase(a.characters8(), b.characters16(), a.length()); |
| + } |
| + if (b.is8Bit()) |
| + return equalIgnoringCase(a.characters16(), b.characters8(), a.length()); |
| + return equalIgnoringCase(a.characters16(), b.characters16(), a.length()); |
| +} |
| + |
| +bool equalIgnoringCase(const StringView& a, const StringView& b) |
| +{ |
| + if (a.isNull() || b.isNull()) |
| + return a.isNull() == b.isNull(); |
| + return equalIgnoringCaseAndNullity(a, b); |
| +} |
| + |
| bool equalIgnoringASCIICase(const StringView& a, const StringView& b) |
| { |
| if (a.isNull() || b.isNull()) |