diff options
author | Konstantin Tokarev <annulen@yandex.ru> | 2016-08-25 19:20:41 +0300 |
---|---|---|
committer | Konstantin Tokarev <annulen@yandex.ru> | 2017-02-02 12:30:55 +0000 |
commit | 6882a04fb36642862b11efe514251d32070c3d65 (patch) | |
tree | b7959826000b061fd5ccc7512035c7478742f7b0 /Source/JavaScriptCore/API/OpaqueJSString.cpp | |
parent | ab6df191029eeeb0b0f16f127d553265659f739e (diff) | |
download | qtwebkit-6882a04fb36642862b11efe514251d32070c3d65.tar.gz |
Imported QtWebKit TP3 (git b57bc6801f1876c3220d5a4bfea33d620d477443)
Change-Id: I3b1d8a2808782c9f34d50240000e20cb38d3680f
Reviewed-by: Konstantin Tokarev <annulen@yandex.ru>
Diffstat (limited to 'Source/JavaScriptCore/API/OpaqueJSString.cpp')
-rw-r--r-- | Source/JavaScriptCore/API/OpaqueJSString.cpp | 76 |
1 files changed, 61 insertions, 15 deletions
diff --git a/Source/JavaScriptCore/API/OpaqueJSString.cpp b/Source/JavaScriptCore/API/OpaqueJSString.cpp index a7cef8d9a..07a79ad99 100644 --- a/Source/JavaScriptCore/API/OpaqueJSString.cpp +++ b/Source/JavaScriptCore/API/OpaqueJSString.cpp @@ -10,10 +10,10 @@ * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * - * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY + * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR @@ -26,38 +26,84 @@ #include "config.h" #include "OpaqueJSString.h" -#include <interpreter/CallFrame.h> -#include <runtime/JSGlobalObject.h> -#include <runtime/Identifier.h> +#include "CallFrame.h" +#include "Identifier.h" +#include "IdentifierInlines.h" +#include "JSGlobalObject.h" +#include <wtf/text/StringView.h> using namespace JSC; -PassRefPtr<OpaqueJSString> OpaqueJSString::create(const String& string) +RefPtr<OpaqueJSString> OpaqueJSString::create(const String& string) { - if (!string.isNull()) - return adoptRef(new OpaqueJSString(string)); - return 0; + if (string.isNull()) + return nullptr; + + return adoptRef(new OpaqueJSString(string)); } -String OpaqueJSString::string() const +OpaqueJSString::~OpaqueJSString() { - if (!this) - return String(); + // m_characters is put in a local here to avoid an extra atomic load. + UChar* characters = m_characters; + if (!characters) + return; + + if (!m_string.is8Bit() && m_string.characters16() == characters) + return; + + fastFree(characters); +} +String OpaqueJSString::string() const +{ // Return a copy of the wrapped string, because the caller may make it an Identifier. return m_string.isolatedCopy(); } Identifier OpaqueJSString::identifier(VM* vm) const { - if (!this || m_string.isNull()) + if (m_string.isNull()) return Identifier(); if (m_string.isEmpty()) return Identifier(Identifier::EmptyIdentifier); if (m_string.is8Bit()) - return Identifier(vm, m_string.characters8(), m_string.length()); + return Identifier::fromString(vm, m_string.characters8(), m_string.length()); + + return Identifier::fromString(vm, m_string.characters16(), m_string.length()); +} + +const UChar* OpaqueJSString::characters() +{ + // m_characters is put in a local here to avoid an extra atomic load. + UChar* characters = m_characters; + if (characters) + return characters; + + if (m_string.isNull()) + return nullptr; + + unsigned length = m_string.length(); + UChar* newCharacters = static_cast<UChar*>(fastMalloc(length * sizeof(UChar))); + StringView(m_string).getCharactersWithUpconvert(newCharacters); + + if (!m_characters.compare_exchange_strong(characters, newCharacters)) { + fastFree(newCharacters); + return characters; + } + + return newCharacters; +} + +bool OpaqueJSString::equal(const OpaqueJSString* a, const OpaqueJSString* b) +{ + if (a == b) + return true; + + if (!a || !b) + return false; - return Identifier(vm, m_string.characters16(), m_string.length()); + return a->m_string == b->m_string; } |