diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-05-20 09:56:07 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-05-20 09:56:07 +0000 |
commit | 41386e9cb918eed93b3f13648cbef387e371e451 (patch) | |
tree | a97f9d7bd1d9d091833286085f72da9d83fd0606 /Source/JavaScriptCore/API/OpaqueJSString.cpp | |
parent | e15dd966d523731101f70ccf768bba12435a0208 (diff) | |
download | WebKitGtk-tarball-41386e9cb918eed93b3f13648cbef387e371e451.tar.gz |
webkitgtk-2.4.9webkitgtk-2.4.9
Diffstat (limited to 'Source/JavaScriptCore/API/OpaqueJSString.cpp')
-rw-r--r-- | Source/JavaScriptCore/API/OpaqueJSString.cpp | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/Source/JavaScriptCore/API/OpaqueJSString.cpp b/Source/JavaScriptCore/API/OpaqueJSString.cpp index 07a79ad99..5cc2e0ab8 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 INC. ``AS IS'' AND ANY + * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, 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 INC. OR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, 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 @@ -28,13 +28,11 @@ #include "CallFrame.h" #include "Identifier.h" -#include "IdentifierInlines.h" #include "JSGlobalObject.h" -#include <wtf/text/StringView.h> using namespace JSC; -RefPtr<OpaqueJSString> OpaqueJSString::create(const String& string) +PassRefPtr<OpaqueJSString> OpaqueJSString::create(const String& string) { if (string.isNull()) return nullptr; @@ -49,7 +47,7 @@ OpaqueJSString::~OpaqueJSString() if (!characters) return; - if (!m_string.is8Bit() && m_string.characters16() == characters) + if (!m_string.is8Bit() && m_string.deprecatedCharacters() == characters) return; fastFree(characters); @@ -57,26 +55,32 @@ OpaqueJSString::~OpaqueJSString() String OpaqueJSString::string() const { + if (!this) + return String(); + // 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 (m_string.isNull()) + if (!this || m_string.isNull()) return Identifier(); if (m_string.isEmpty()) return Identifier(Identifier::EmptyIdentifier); if (m_string.is8Bit()) - return Identifier::fromString(vm, m_string.characters8(), m_string.length()); + return Identifier(vm, m_string.characters8(), m_string.length()); - return Identifier::fromString(vm, m_string.characters16(), m_string.length()); + return Identifier(vm, m_string.characters16(), m_string.length()); } const UChar* OpaqueJSString::characters() { + if (!this) + return nullptr; + // m_characters is put in a local here to avoid an extra atomic load. UChar* characters = m_characters; if (characters) @@ -87,7 +91,12 @@ const UChar* OpaqueJSString::characters() unsigned length = m_string.length(); UChar* newCharacters = static_cast<UChar*>(fastMalloc(length * sizeof(UChar))); - StringView(m_string).getCharactersWithUpconvert(newCharacters); + + if (m_string.is8Bit()) { + for (size_t i = 0; i < length; ++i) + newCharacters[i] = m_string.characters8()[i]; + } else + memcpy(newCharacters, m_string.characters16(), length * sizeof(UChar)); if (!m_characters.compare_exchange_strong(characters, newCharacters)) { fastFree(newCharacters); |