From 733f6b770fcd7c2e5577bfb1fc738dc6ae5c3920 Mon Sep 17 00:00:00 2001 From: win7-7 Date: Sat, 25 May 2019 18:02:40 +0300 Subject: use memcmp for nsIAtom Equals to improve performance xpcom/ds issue #1113 Use memcmp and not slower string Equals in nsHtml5Portability::localEqualsBuffer --- xpcom/ds/nsIAtom.idl | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'xpcom/ds/nsIAtom.idl') diff --git a/xpcom/ds/nsIAtom.idl b/xpcom/ds/nsIAtom.idl index 6e8602c42..ce4cff485 100644 --- a/xpcom/ds/nsIAtom.idl +++ b/xpcom/ds/nsIAtom.idl @@ -37,9 +37,15 @@ interface nsIAtom : nsISupports size_t SizeOfIncludingThis(in MallocSizeOf aMallocSizeOf); %{C++ - // note this is NOT virtual so this won't muck with the vtable! + // note these are NOT virtual so they won't muck with the vtable! + inline bool Equals(char16ptr_t aString, uint32_t aLength) const + { + return mLength == aLength && + memcmp(mString, aString, mLength * sizeof(char16_t)) == 0; + } + inline bool Equals(const nsAString& aString) const { - return aString.Equals(nsDependentString(mString, mLength)); + return Equals(aString.BeginReading(), aString.Length()); } inline bool IsStaticAtom() const { -- cgit v1.2.3