/* * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010 Apple Inc. All rights reserved. * Copyright (C) Research In Motion Limited 2011. All rights reserved. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. * */ #ifndef StringOperators_h #define StringOperators_h namespace WTF { template class StringAppend { public: StringAppend(StringType1 string1, StringType2 string2) : m_string1(string1) , m_string2(string2) { } operator String() const { String result = tryMakeString(m_string1, m_string2); if (!result) CRASH(); return result; } operator AtomicString() const { return operator String(); } bool is8Bit() { StringTypeAdapter adapter1(m_string1); StringTypeAdapter adapter2(m_string2); return adapter1.is8Bit() && adapter2.is8Bit(); } void writeTo(LChar* destination) { ASSERT(is8Bit()); StringTypeAdapter adapter1(m_string1); StringTypeAdapter adapter2(m_string2); adapter1.writeTo(destination); adapter2.writeTo(destination + adapter1.length()); } void writeTo(UChar* destination) { StringTypeAdapter adapter1(m_string1); StringTypeAdapter adapter2(m_string2); adapter1.writeTo(destination); adapter2.writeTo(destination + adapter1.length()); } unsigned length() { StringTypeAdapter adapter1(m_string1); StringTypeAdapter adapter2(m_string2); return adapter1.length() + adapter2.length(); } private: StringType1 m_string1; StringType2 m_string2; }; template class StringTypeAdapter> { public: StringTypeAdapter>(StringAppend& buffer) : m_buffer(buffer) { } unsigned length() { return m_buffer.length(); } bool is8Bit() { return m_buffer.is8Bit(); } void writeTo(LChar* destination) { m_buffer.writeTo(destination); } void writeTo(UChar* destination) { m_buffer.writeTo(destination); } String toString() const { return m_buffer; } private: StringAppend& m_buffer; }; inline StringAppend operator+(const char* string1, const String& string2) { return StringAppend(string1, string2); } inline StringAppend operator+(const char* string1, const AtomicString& string2) { return StringAppend(string1, string2); } template inline StringAppend> operator+(const char* string1, const StringAppend& string2) { return StringAppend>(string1, string2); } inline StringAppend operator+(const UChar* string1, const String& string2) { return StringAppend(string1, string2); } inline StringAppend operator+(const UChar* string1, const AtomicString& string2) { return StringAppend(string1, string2); } template inline StringAppend> operator+(const UChar* string1, const StringAppend& string2) { return StringAppend>(string1, string2); } inline StringAppend operator+(const ASCIILiteral& string1, const String& string2) { return StringAppend(string1, string2); } inline StringAppend operator+(const ASCIILiteral& string1, const AtomicString& string2) { return StringAppend(string1, string2); } template inline StringAppend> operator+(const ASCIILiteral& string1, const StringAppend& string2) { return StringAppend>(string1, string2); } template StringAppend operator+(const String& string1, T string2) { return StringAppend(string1, string2); } template StringAppend, W> operator+(const StringAppend& string1, W string2) { return StringAppend, W>(string1, string2); } } // namespace WTF #endif // StringOperators_h