Index: third_party/WebKit/Source/platform/inspector_protocol/String16WTF.h |
diff --git a/third_party/WebKit/Source/platform/inspector_protocol/String16WTF.h b/third_party/WebKit/Source/platform/inspector_protocol/String16WTF.h |
index 15292f003df1675717c1235f0ed610ef138e7698..b65383a3cfa0b61f6d779508f57a7c36827b5f96 100644 |
--- a/third_party/WebKit/Source/platform/inspector_protocol/String16WTF.h |
+++ b/third_party/WebKit/Source/platform/inspector_protocol/String16WTF.h |
@@ -17,111 +17,78 @@ |
namespace blink { |
namespace protocol { |
-class PLATFORM_EXPORT String16 { |
+class PLATFORM_EXPORT String16 : public String16Base<String16, UChar> { |
public: |
+ static const size_t kNotFound = WTF::kNotFound; |
+ |
String16() { } |
- String16(const String16& other); |
- String16(const UChar*, unsigned); |
- String16(const char*); |
- String16(const char*, size_t); |
- static String16 createUninitialized(unsigned length, UChar*& data); |
+ String16(const String16& other) : m_impl(other.m_impl) { } |
+ String16(const UChar* characters, unsigned length) : m_impl(characters, length) { } |
+ String16(const char* characters) : String16(characters, strlen(characters)) { } |
+ String16(const char* characters, size_t length) |
+ { |
+ UChar* data; |
+ m_impl = WTF::String::createUninitialized(length, data); |
+ for (size_t i = 0; i < length; ++i) |
+ data[i] = characters[i]; |
+ } |
+ |
+ ~String16() { } |
+ |
+ String16 isolatedCopy() const { return String16(m_impl.isolatedCopy()); } |
+ const UChar* characters16() const { return m_impl.isEmpty() ? nullptr : m_impl.characters16(); } |
+ size_t length() const { return m_impl.length(); } |
+ bool isEmpty() const { return m_impl.isEmpty(); } |
+ UChar operator[](unsigned index) const { return m_impl[index]; } |
+ String16 substring(unsigned pos, unsigned len = UINT_MAX) const { return m_impl.substring(pos, len); } |
+ size_t find(const String16& str, unsigned start = 0) const { return m_impl.find(str.impl(), start); } |
+ size_t reverseFind(const String16& str, unsigned start = UINT_MAX) const { return m_impl.reverseFind(str.impl(), start); } |
// WTF convenience constructors and helper methods. |
String16(const WebString& other) : String16(String(other)) { } |
template<typename StringType1, typename StringType2> |
String16(const WTF::StringAppend<StringType1, StringType2>& impl) : String16(String(impl)) { } |
String16(const WTF::AtomicString& impl) : String16(String(impl)) { } |
- String16(const WTF::String& impl); |
+ String16(const WTF::String& impl) : m_impl(impl) { m_impl.ensure16Bit(); } |
String16(WTF::HashTableDeletedValueType) : m_impl(WTF::HashTableDeletedValue) { } |
bool isHashTableDeletedValue() const { return m_impl.isHashTableDeletedValue(); } |
operator WTF::String() const { return m_impl; } |
operator WTF::StringView() const { return StringView(m_impl); } |
operator WebString() { return m_impl; } |
const WTF::String& impl() const { return m_impl; } |
- String16 isolatedCopy() const { return String16(m_impl.isolatedCopy()); } |
- |
- ~String16() { } |
- |
- static String16 fromInteger(int i) { return String::number(i); } |
- static String16 fromDouble(double number) { return Decimal::fromDouble(number).toString(); } |
- static String16 fromDoubleFixedPrecision(double number, int precision) { return String::numberToStringFixedWidth(number, precision); } |
- |
- size_t length() const { return m_impl.length(); } |
- bool isEmpty() const { return m_impl.isEmpty(); } |
- UChar operator[](unsigned index) const { return m_impl[index]; } |
- |
- size_t charactersSizeInBytes() const { return m_impl.charactersSizeInBytes(); } |
- const UChar* characters16() const { return m_impl.isEmpty() ? nullptr : m_impl.characters16(); } |
- |
- static double charactersToDouble(const LChar* characters, size_t length, bool* ok = 0) { return ::charactersToDouble(characters, length, ok); } |
- static double charactersToDouble(const UChar* characters, size_t length, bool* ok = 0) { return ::charactersToDouble(characters, length, ok); } |
- |
- String16 substring(unsigned pos, unsigned len = UINT_MAX) const { return m_impl.substring(pos, len); } |
- String16 stripWhiteSpace() const { return m_impl.stripWhiteSpace(); } |
- |
- int toInt(bool* ok = 0) const { return m_impl.toInt(ok); } |
- |
- size_t find(UChar c, unsigned start = 0) const { return m_impl.find(c, start); } |
- size_t find(const String16& str, unsigned start = 0) const { return m_impl.find(str.impl(), start); } |
- size_t reverseFind(const String16& str, unsigned start = UINT_MAX) const { return m_impl.reverseFind(str.impl(), start); } |
- |
- bool startWith(const String16& s) const { return m_impl.startsWith(s); } |
- bool startWith(UChar character) const { return m_impl.startsWith(character); } |
- bool endsWith(const String16& s) const { return m_impl.endsWith(s); } |
- bool endsWith(UChar character) const { return m_impl.endsWith(character); } |
private: |
WTF::String m_impl; |
}; |
-class String16Builder { |
-public: |
- String16Builder() { } |
- void append(const String16& str) { m_impl.append(str); }; |
- void append(UChar c) { m_impl.append(c); }; |
- void append(LChar c) { m_impl.append(c); }; |
- void append(char c) { m_impl.append(c); }; |
- void append(const UChar* c, size_t size) { m_impl.append(c, size); }; |
- void append(const char* characters, unsigned length) { m_impl.append(characters, length); } |
- void appendNumber(int number) { m_impl.appendNumber(number); } |
- void appendNumber(double number) { m_impl.appendNumber(number); } |
- String16 toString() { return m_impl.toString(); } |
- void reserveCapacity(unsigned newCapacity) { m_impl.reserveCapacity(newCapacity); } |
- |
-private: |
- WTF::StringBuilder m_impl; |
-}; |
- |
inline bool operator==(const String16& a, const String16& b) { return a.impl() == b.impl(); } |
inline bool operator!=(const String16& a, const String16& b) { return a.impl() != b.impl(); } |
inline bool operator==(const String16& a, const char* b) { return a.impl() == b; } |
- |
-inline String16 operator+(const String16& a, const char* b) |
-{ |
- return String(a.impl() + b); |
-} |
- |
-inline String16 operator+(const char* a, const String16& b) |
-{ |
- return String(a + b.impl()); |
-} |
- |
-inline String16 operator+(const String16& a, const String16& b) |
-{ |
- return String(a.impl() + b.impl()); |
-} |
+inline String16 operator+(const String16& a, const char* b) { return String16(a.impl() + b); } |
+inline String16 operator+(const char* a, const String16& b) { return String16(a + b.impl()); } |
+inline String16 operator+(const String16& a, const String16& b) { return String16(a.impl() + b.impl()); } |
} // namespace protocol |
} // namespace blink |
-using String16 = blink::protocol::String16; |
-using String16Builder = blink::protocol::String16Builder; |
+namespace std { |
+template<> struct hash<blink::protocol::String16> { |
+ std::size_t operator()(const blink::protocol::String16& string) const |
+ { |
+ return StringHash::hash(string.impl()); |
+ } |
+}; |
+} // namespace std |
+ |
+using InspectorProtocolConvenienceStringType = WTF::String; |
+ |
+// WTF helpers below this line. |
namespace WTF { |
struct String16Hash { |
- static unsigned hash(const String16& key) { return StringHash::hash(key.impl()); } |
- static bool equal(const String16& a, const String16& b) |
+ static unsigned hash(const blink::protocol::String16& key) { return StringHash::hash(key.impl()); } |
+ static bool equal(const blink::protocol::String16& a, const blink::protocol::String16& b) |
{ |
return StringHash::equal(a.impl(), b.impl()); |
} |
@@ -129,26 +96,16 @@ struct String16Hash { |
}; |
template<typename T> struct DefaultHash; |
-template<> struct DefaultHash<String16> { |
+template<> struct DefaultHash<blink::protocol::String16> { |
typedef String16Hash Hash; |
}; |
template<> |
-struct HashTraits<String16> : SimpleClassHashTraits<String16> { |
+struct HashTraits<blink::protocol::String16> : SimpleClassHashTraits<blink::protocol::String16> { |
static const bool hasIsEmptyValueFunction = true; |
- static bool isEmptyValue(const String16& a) { return a.impl().isNull(); } |
+ static bool isEmptyValue(const blink::protocol::String16& a) { return a.impl().isNull(); } |
}; |
} // namespace WTF |
-namespace std { |
-template<> struct hash<String16> { |
- std::size_t operator()(const String16& string) const |
- { |
- return StringHash::hash(string.impl()); |
- } |
-}; |
- |
-} // namespace std |
- |
#endif // !defined(String16WTF_h) |