diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-04-10 09:28:39 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-04-10 09:28:39 +0000 |
commit | 32761a6cee1d0dee366b885b7b9c777e67885688 (patch) | |
tree | d6bec92bebfb216f4126356e55518842c2f476a1 /Source/JavaScriptCore/runtime/JSStringBuilder.h | |
parent | a4e969f4965059196ca948db781e52f7cfebf19e (diff) | |
download | WebKitGtk-tarball-32761a6cee1d0dee366b885b7b9c777e67885688.tar.gz |
webkitgtk-2.4.11webkitgtk-2.4.11
Diffstat (limited to 'Source/JavaScriptCore/runtime/JSStringBuilder.h')
-rw-r--r-- | Source/JavaScriptCore/runtime/JSStringBuilder.h | 139 |
1 files changed, 97 insertions, 42 deletions
diff --git a/Source/JavaScriptCore/runtime/JSStringBuilder.h b/Source/JavaScriptCore/runtime/JSStringBuilder.h index 32b39f0a4..7b1c1a505 100644 --- a/Source/JavaScriptCore/runtime/JSStringBuilder.h +++ b/Source/JavaScriptCore/runtime/JSStringBuilder.h @@ -32,7 +32,6 @@ namespace JSC { -// FIXME: Should move the last few callers over from this to WTF::StringBuilder. class JSStringBuilder { public: JSStringBuilder() @@ -41,64 +40,73 @@ public: { } - void append(LChar character) + void append(const UChar u) { if (m_is8Bit) { - m_okay &= buffer8.tryAppend(&character, 1); - return; - } - UChar upconvertedCharacter = character; - m_okay &= buffer16.tryAppend(&upconvertedCharacter, 1); - } - - void append(UChar character) - { - if (m_is8Bit) { - if (character < 0x100) { - LChar narrowedCharacter = character; - m_okay &= buffer8.tryAppend(&narrowedCharacter, 1); + if (u < 0xff) { + LChar c = u; + m_okay &= buffer8.tryAppend(&c, 1); return; } upConvert(); } - m_okay &= buffer16.tryAppend(&character, 1); + m_okay &= buffer16.tryAppend(&u, 1); } void append(const char* str) { - append(reinterpret_cast<const LChar*>(str), strlen(str)); + append(str, strlen(str)); } - JSValue build(ExecState* exec) + void append(const char* str, size_t len) { - if (!m_okay) - return throwOutOfMemoryError(exec); if (m_is8Bit) { - buffer8.shrinkToFit(); - if (!buffer8.data()) - return throwOutOfMemoryError(exec); - return jsString(exec, String::adopt(buffer8)); + m_okay &= buffer8.tryAppend(reinterpret_cast<const LChar*>(str), len); + return; + } + m_okay &= buffer8.tryReserveCapacity(buffer16.size() + len); + for (size_t i = 0; i < len; i++) { + UChar u = static_cast<unsigned char>(str[i]); + m_okay &= buffer16.tryAppend(&u, 1); } - buffer16.shrinkToFit(); - if (!buffer16.data()) - return throwOutOfMemoryError(exec); - return jsString(exec, String::adopt(buffer16)); } -private: - void append(const LChar* characters, size_t length) + void append(const LChar* str, size_t len) { if (m_is8Bit) { - m_okay &= buffer8.tryAppend(characters, length); + m_okay &= buffer8.tryAppend(str, len); return; } - // FIXME: There must be a more efficient way of doing this. - m_okay &= buffer16.tryReserveCapacity(buffer16.size() + length); - for (size_t i = 0; i < length; i++) { - UChar upconvertedCharacter = characters[i]; - m_okay &= buffer16.tryAppend(&upconvertedCharacter, 1); + m_okay &= buffer8.tryReserveCapacity(buffer16.size() + len); + for (size_t i = 0; i < len; i++) { + UChar u = str[i]; + m_okay &= buffer16.tryAppend(&u, 1); } } + + void append(const UChar* str, size_t len) + { + if (m_is8Bit) + upConvert(); // FIXME: We could check character by character its size. + m_okay &= buffer16.tryAppend(str, len); + } + + void append(const String& str) + { + unsigned length = str.length(); + + if (!length) + return; + + if (m_is8Bit) { + if (str.is8Bit()) { + m_okay &= buffer8.tryAppend(str.characters8(), length); + return; + } + upConvert(); + } + m_okay &= buffer16.tryAppend(str.deprecatedCharacters(), length); + } void upConvert() { @@ -112,22 +120,69 @@ private: m_is8Bit = false; } + JSValue build(ExecState* exec) + { + if (!m_okay) + return throwOutOfMemoryError(exec); + if (m_is8Bit) { + buffer8.shrinkToFit(); + if (!buffer8.data()) + return throwOutOfMemoryError(exec); + return jsString(exec, String::adopt(buffer8)); + } + buffer16.shrinkToFit(); + if (!buffer16.data()) + return throwOutOfMemoryError(exec); + return jsString(exec, String::adopt(buffer16)); + } + +protected: Vector<LChar, 64, UnsafeVectorOverflow> buffer8; Vector<UChar, 64, UnsafeVectorOverflow> buffer16; bool m_okay; bool m_is8Bit; }; -template<typename StringType> -inline JSValue jsMakeNontrivialString(ExecState* exec, StringType&& string) +template<typename StringType1, typename StringType2> +inline JSValue jsMakeNontrivialString(ExecState* exec, StringType1 string1, StringType2 string2) +{ + PassRefPtr<StringImpl> result = WTF::tryMakeString(string1, string2); + if (!result) + return throwOutOfMemoryError(exec); + return jsNontrivialString(exec, result); +} + +template<typename StringType1, typename StringType2, typename StringType3> +inline JSValue jsMakeNontrivialString(ExecState* exec, StringType1 string1, StringType2 string2, StringType3 string3) { - return jsNontrivialString(exec, std::forward<StringType>(string)); + PassRefPtr<StringImpl> result = WTF::tryMakeString(string1, string2, string3); + if (!result) + return throwOutOfMemoryError(exec); + return jsNontrivialString(exec, result); +} + +template<typename StringType1, typename StringType2, typename StringType3, typename StringType4> +inline JSValue jsMakeNontrivialString(ExecState* exec, StringType1 string1, StringType2 string2, StringType3 string3, StringType4 string4) +{ + PassRefPtr<StringImpl> result = WTF::tryMakeString(string1, string2, string3, string4); + if (!result) + return throwOutOfMemoryError(exec); + return jsNontrivialString(exec, result); +} + +template<typename StringType1, typename StringType2, typename StringType3, typename StringType4, typename StringType5> +inline JSValue jsMakeNontrivialString(ExecState* exec, StringType1 string1, StringType2 string2, StringType3 string3, StringType4 string4, StringType5 string5) +{ + PassRefPtr<StringImpl> result = WTF::tryMakeString(string1, string2, string3, string4, string5); + if (!result) + return throwOutOfMemoryError(exec); + return jsNontrivialString(exec, result); } -template<typename StringType, typename... StringTypes> -inline JSValue jsMakeNontrivialString(ExecState* exec, const StringType& string, const StringTypes&... strings) +template<typename StringType1, typename StringType2, typename StringType3, typename StringType4, typename StringType5, typename StringType6> +inline JSValue jsMakeNontrivialString(ExecState* exec, StringType1 string1, StringType2 string2, StringType3 string3, StringType4 string4, StringType5 string5, StringType6 string6) { - String result = WTF::tryMakeString(string, strings...); + PassRefPtr<StringImpl> result = WTF::tryMakeString(string1, string2, string3, string4, string5, string6); if (!result) return throwOutOfMemoryError(exec); return jsNontrivialString(exec, result); |