summaryrefslogtreecommitdiffstats
path: root/experimental/tqtinterface/qt4/src/tools/tqstring.h
diff options
context:
space:
mode:
Diffstat (limited to 'experimental/tqtinterface/qt4/src/tools/tqstring.h')
-rw-r--r--experimental/tqtinterface/qt4/src/tools/tqstring.h1684
1 files changed, 1684 insertions, 0 deletions
diff --git a/experimental/tqtinterface/qt4/src/tools/tqstring.h b/experimental/tqtinterface/qt4/src/tools/tqstring.h
new file mode 100644
index 000000000..b4db80271
--- /dev/null
+++ b/experimental/tqtinterface/qt4/src/tools/tqstring.h
@@ -0,0 +1,1684 @@
+/****************************************************************************
+**
+** Definition of the TQString class, and related Unicode functions.
+**
+** Created : 920609
+**
+** Copyright (C) 2010 Timothy Pearson and (C) 1992-2008 Trolltech ASA.
+**
+** This file is part of the tools module of the TQt GUI Toolkit.
+**
+** This file may be used under the terms of the GNU General
+** Public License versions 2.0 or 3.0 as published by the Free
+** Software Foundation and appearing in the files LICENSE.GPL2
+** and LICENSE.GPL3 included in the packaging of this file.
+** Alternatively you may (at your option) use any later version
+** of the GNU General Public License if such license has been
+** publicly approved by Trolltech ASA (or its successors, if any)
+** and the KDE Free TQt Foundation.
+**
+** Please review the following information to ensure GNU General
+** Public Licensing requirements will be met:
+** http://trolltech.com/products/qt/licenses/licensing/opensource/.
+** If you are unsure which license is appropriate for your use, please
+** review the following information:
+** http://trolltech.com/products/qt/licenses/licensing/licensingoverview
+** or contact the sales department at sales@trolltech.com.
+**
+** This file may be used under the terms of the Q Public License as
+** defined by Trolltech ASA and appearing in the file LICENSE.TQPL
+** included in the packaging of this file. Licensees holding valid TQt
+** Commercial licenses may use this file in accordance with the TQt
+** Commercial License Agreement provided with the Software.
+**
+** This file is provided "AS IS" with NO WARRANTY OF ANY KIND,
+** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR
+** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted
+** herein.
+**
+**********************************************************************/
+
+#ifndef TQSTRING_H
+#define TQSTRING_H
+
+#include "tqtglobaldefines.h"
+
+#ifndef TQT_H
+#include "tqcstring.h"
+#endif // TQT_H
+
+#ifdef USE_QT4
+
+#include <Qt/qstring.h>
+#include <Qt/qmetatype.h>
+
+#endif // USE_QT4
+
+#ifndef TQT_NO_CAST_ASCII
+#include <limits.h>
+#include <string>
+#endif
+
+#ifndef TQT_NO_STL
+#if defined ( TQ_CC_MSVC_NET ) && _MSC_VER < 1310 // Avoids nasty warning for xlocale, line 450
+# pragma warning ( push )
+# pragma warning ( disable : 4189 )
+# include <string>
+# pragma warning ( pop )
+#else
+# include <string>
+#endif
+#if defined(TQ_WRONG_SB_CTYPE_MACROS) && defined(_SB_CTYPE_MACROS)
+#undef _SB_CTYPE_MACROS
+#endif
+#endif
+
+#ifdef USE_QT4
+
+class TQCharRef;
+
+class TQ_EXPORT TQChar : public QChar
+{
+public:
+ enum SpecialCharacter {
+ Null = Null,
+ Nbsp = Nbsp,
+ ReplacementCharacter = ReplacementCharacter,
+ ObjectReplacementCharacter = ObjectReplacementCharacter,
+ ByteOrderMark = ByteOrderMark,
+ ByteOrderSwapped = ByteOrderSwapped,
+
+// null = Null,
+// tqreplacement = ReplacementCharacter,
+// byteOrderMark = ByteOrderMark,
+// byteOrderSwapped = ByteOrderSwapped,
+// nbsp = Nbsp,
+
+ ParagraphSeparator = ParagraphSeparator,
+ LineSeparator = LineSeparator
+ };
+
+ TQT_STATIC_CONST TQChar null;
+ TQT_STATIC_CONST TQChar tqreplacement;
+ TQT_STATIC_CONST TQChar byteOrderMark;
+ TQT_STATIC_CONST TQChar byteOrderSwapped;
+ TQT_STATIC_CONST TQChar nbsp;
+
+ TQChar() : QChar() {}
+ TQChar( char c ) : QChar( c ) {}
+ TQChar( uchar c ) : QChar( c ) {}
+ TQChar( uchar c, uchar r ) : QChar( c, r ) {}
+ TQChar( const QChar& c ) : QChar( c ) {}
+ TQChar( ushort rc ) : QChar( rc ) {}
+ TQChar( short rc ) : QChar( rc ) {}
+ TQChar( uint rc ) : QChar( rc ) {}
+ TQChar( int rc ) : QChar( rc ) {}
+ TQChar(TQChar::SpecialCharacter sc) : QChar( (QChar::SpecialCharacter)sc ) {}
+
+ inline TQChar lower() const { return toLower(); }
+ inline TQChar upper() const { return toUpper(); }
+
+#ifdef Q_COMPILER_MANGLES_RETURN_TYPE
+ inline const char latin1() const { return toLatin1(); }
+ inline const char ascii() const { return toAscii(); }
+#else
+ inline char latin1() const { return toLatin1(); }
+ inline char ascii() const { return toAscii(); }
+#endif
+
+#ifndef TQT_NO_CAST_ASCII
+ inline operator char() const { return latin1(); }
+#endif
+
+ static inline bool networkOrdered() {
+ return QSysInfo::ByteOrder == QSysInfo::BigEndian;
+ }
+
+ inline TQChar &operator=( char ch ) { this->QChar::operator=(ch); return *this; }
+
+ inline ushort tqunicode() const { return unicode(); }
+ inline bool mirrored() const { return hasMirrored(); }
+
+ using QChar::operator=;
+};
+
+Q_DECLARE_METATYPE(TQChar)
+
+inline bool operator==( char ch, QChar c ) { return (TQChar(ch) == c); }
+inline bool operator==( QChar c, char ch ) { return (TQChar(ch) == c); }
+inline bool operator!=( char ch, QChar c ) { return (TQChar(ch) != c); }
+inline bool operator!=( QChar c, char ch ) { return (TQChar(ch) != c); }
+
+inline bool operator==( int ch, QChar c ) { return (TQChar(ch) == c); }
+inline bool operator==( QChar c, int ch ) { return (TQChar(ch) == c); }
+inline bool operator!=( int ch, QChar c ) { return (TQChar(ch) == c); }
+inline bool operator!=( QChar c, int ch ) { return (TQChar(ch) == c); }
+
+class TQ_EXPORT TQString : public QString
+{
+public:
+ TQString() : QString() {}
+ TQString( QChar tc ) : QString( tc ) {}
+ TQString( const QString &ts ) : QString( ts ) {}
+ TQString( const QByteArray &ba ) : QString( ba ) { int slen = int(strlen(ba)); if (length() > slen) truncate(slen); }
+ TQString( const QChar* tqunicode, uint length ) : QString( tqunicode, length ) {}
+#ifndef TQT_NO_CAST_ASCII
+ TQString( const char *str ) : QString( str ) {}
+#endif
+#ifndef TQT_NO_STL
+ TQString( const std::string &str ) : QString(str.c_str()) {}
+#endif
+
+ int tqfind( QChar c, int index=0, bool cs=TRUE ) const { return indexOf(c, index, (Qt::CaseSensitivity)cs); }
+ int tqfind( char c, int index=0, bool cs=TRUE ) const { return indexOf(c, index, (Qt::CaseSensitivity)cs); }
+ int tqfind( const QString &str, int index=0, bool cs=TRUE ) const { return indexOf(str, index, (Qt::CaseSensitivity)cs); }
+#ifndef TQT_NO_REGEXP
+ int tqfind( const QRegExp &qr, int index=0 ) const { return indexOf(qr, index); }
+#endif
+#ifndef TQT_NO_CAST_ASCII
+ int tqfind( const char* str, int index=0 ) const { return indexOf(str, index); }
+#endif
+ int tqfindRev( QChar c, int index=-1, bool cs=TRUE) const { return lastIndexOf(c, index, (Qt::CaseSensitivity)cs); }
+ int tqfindRev( char c, int index=-1, bool cs=TRUE) const { return lastIndexOf(c, index, (Qt::CaseSensitivity)cs); }
+ int tqfindRev( const QString &str, int index=-1, bool cs=TRUE) const { return lastIndexOf(str, index, (Qt::CaseSensitivity)cs); }
+#ifndef TQT_NO_REGEXP
+ int tqfindRev( const QRegExp &qr, int index=-1 ) const { return lastIndexOf(qr, index); }
+#endif
+#ifndef TQT_NO_CAST_ASCII
+ int tqfindRev( const char* str, int index=-1 ) const { return lastIndexOf(str, index); }
+#endif
+
+ const char* latin1() const { return latin1_helper(); }
+ const char* ascii() const { return ascii_helper(); }
+
+ bool simpleText() const;
+ void checkSimpleText() const;
+
+ TQString copy() const;
+
+ inline TQString lower() const { return toLower(); }
+ inline TQString upper() const { return toUpper(); }
+ inline TQString stripWhiteSpace() const { return trimmed(); }
+ inline TQString simplifyWhiteSpace() const { return simplified(); }
+
+ inline TQString fill( TQChar c, int len = -1 ) { return QString::fill(c, len); }
+
+ // QString::Null compatibility
+ struct Null { };
+ static const Null null;
+ inline TQString(const Null &) : QString() {}
+ inline TQString &operator=(const Null &) { *this = TQString(); return *this; }
+
+ int tqcontains( QChar c, bool cs=TRUE ) const { return count(c, (Qt::CaseSensitivity)cs); }
+ int tqcontains( char c, bool cs=TRUE ) const { return tqcontains(TQChar(c), cs); }
+#ifndef TQT_NO_CAST_ASCII
+ int tqcontains( const char* str, bool cs=TRUE ) const { return count(str, (Qt::CaseSensitivity)cs); }
+#endif
+ int tqcontains( const QString &str, bool cs=TRUE ) const { return count(str, (Qt::CaseSensitivity)cs); }
+#ifndef TQT_NO_REGEXP
+ int tqcontains( const QRegExp &re ) const { return count(re); }
+#endif
+
+#ifndef QT_NO_CAST_TO_ASCII
+ inline operator const char *() const { return ascii_helper(); }
+#endif
+
+ inline bool tqstartsWith( const TQString& str ) const { return startsWith(str); }
+ inline bool tqstartsWith( const TQString& str, bool cs ) const { return startsWith(str, (cs)?Qt::CaseSensitive:Qt::CaseInsensitive); }
+ inline bool tqendsWith( const TQString& str ) const { return endsWith(str); }
+ inline bool tqendsWith( const TQString& str, bool cs ) const { return endsWith(str, (cs)?Qt::CaseSensitive:Qt::CaseInsensitive); }
+
+ TQCString utf8() const;
+ inline TQChar constref(uint i) const { return tqat(i); }
+ inline TQString leftJustify(int width, QChar aFill = QLatin1Char(' '), bool trunc=false) const { return leftJustified(width, aFill, trunc); }
+ inline TQString rightJustify(int width, QChar aFill = QLatin1Char(' '), bool trunc=false) const { return rightJustified(width, aFill, trunc); }
+
+ inline const TQChar* tqunicode() const { if (length() > 0) return static_cast<const TQChar*>(unicode()); else return static_cast<const TQChar*>(QString().unicode()); }
+ TQCString local8Bit() const;
+
+ inline TQString tqreplace(int i, int len, QChar after) { return tqreplace( i, len, &after, 1 ); }
+ inline TQString tqreplace(int i, int len, const QChar *s, int slen) {
+ // Mimic the old (undocumented) behavior
+ int newindex = i;
+ if (newindex > length()) newindex = length();
+ return replace( newindex, len, s, slen );
+ }
+ inline TQString tqreplace(int i, int len, const QString &after) { return tqreplace( i, len, TQString(after).tqunicode(), after.length() ); }
+ inline TQString tqreplace(QChar before, QChar after, Qt::CaseSensitivity cs = Qt::CaseSensitive) { return replace( before, after, cs ); }
+ inline TQString tqreplace(const QChar *before, int blen, const QChar *after, int alen, Qt::CaseSensitivity cs = Qt::CaseSensitive) { return replace( before, blen, after, alen, cs ); }
+ inline TQString tqreplace(const QLatin1String &before, const QLatin1String &after, Qt::CaseSensitivity cs = Qt::CaseSensitive) { return replace( before, after, cs ); }
+ inline TQString tqreplace(const QLatin1String &before, const QString &after, Qt::CaseSensitivity cs = Qt::CaseSensitive) { return replace( before, after, cs ); }
+ inline TQString tqreplace(const QString &before, const QLatin1String &after, Qt::CaseSensitivity cs = Qt::CaseSensitive) { return replace( before, after, cs ); }
+ inline TQString tqreplace(const QString &before, const QString &after, Qt::CaseSensitivity cs = Qt::CaseSensitive) { return replace( before, after, cs ); }
+ inline TQString tqreplace(QChar c, const QString &after, Qt::CaseSensitivity cs = Qt::CaseSensitive) { return replace( c, after, cs ); }
+ inline TQString tqreplace(QChar c, const QLatin1String &after, Qt::CaseSensitivity cs = Qt::CaseSensitive) { return replace( c, after, cs ); }
+#ifndef QT_NO_REGEXP
+ inline TQString tqreplace(const QRegExp &rx, const QString &after) { return replace( rx, after ); }
+#endif
+ inline TQString tqreplace(const QString &before, const QString &after, bool cs) { return tqreplace(before, after, cs?Qt::CaseSensitive:Qt::CaseInsensitive); }
+
+ inline TQString tqsetNum( short a, int base=10 ) { return setNum(a, base); }
+ inline TQString tqsetNum( ushort a, int base=10 ) { return setNum(a, base); }
+ inline TQString tqsetNum( int a, int base=10 ) { return setNum(a, base); }
+ inline TQString tqsetNum( uint a, int base=10 ) { return setNum(a, base); }
+ inline TQString tqsetNum( long a, int base=10 ) { return setNum(a, base); }
+ inline TQString tqsetNum( ulong a, int base=10 ) { return setNum(a, base); }
+ inline TQString tqsetNum( TQ_LLONG a, int base=10 ) { return setNum(a, base); }
+ inline TQString tqsetNum( TQ_ULLONG a, int base=10 ) { return setNum(a, base); }
+ inline TQString tqsetNum( float a, char f='g', int prec=6 ) { return setNum(a, f, prec); }
+ inline TQString tqsetNum( double a, char f='g', int prec=6 ) { return setNum(a, f, prec); }
+
+ inline TQString remove( uint index, uint len ) { if (index<=((uint)length())) return QString::remove(index, len); return *this; }
+ inline TQString remove( const QString &qs ) { return QString::remove(qs); }
+ inline TQString remove( const QString &qs, bool cs ) { return QString::remove(qs, cs?Qt::CaseSensitive:Qt::CaseInsensitive); }
+ inline TQString remove( QChar c ) { return QString::remove(c); }
+ inline TQString remove( char c ) { return remove( QChar(c) ); }
+#ifndef TQT_NO_CAST_ASCII
+ inline TQString remove( const char *ch ) { return QString::remove(ch); }
+#endif
+#ifndef TQT_NO_REGEXP
+ inline TQString remove( const QRegExp &re ) { return QString::remove(re); }
+#endif
+
+ inline TQString section( TQChar sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const { return QString::section(sep, start, end, (QString::SectionFlags)flags); }
+ inline TQString section( char sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const { return QString::section(sep, start, end, (QString::SectionFlags)flags); }
+#ifndef TQT_NO_CAST_ASCII
+ inline TQString section( const char *in_sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const { return QString::section(in_sep, start, end, (QString::SectionFlags)flags); }
+#endif
+ inline TQString section( const QString in_sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const { return QString::section(in_sep, start, end, (QString::SectionFlags)flags); }
+#ifndef TQT_NO_REGEXP
+ inline TQString section( const QRegExp reg, int start, int end = 0xffffffff, int flags = SectionDefault ) const { return QString::section(reg, start, end, (QString::SectionFlags)flags); }
+#endif
+
+ inline static TQString fromUcs2(const ushort *unicode, int size = -1) { return fromUtf16(unicode, size); }
+ inline const unsigned short *ucs2() const { return utf16(); }
+
+ inline TQString left( uint len ) const { return TQString(QString::left(len)); }
+ inline TQString right( uint len ) const { return TQString(QString::right(len)); }
+ inline TQString mid( uint index, uint len=0xffffffff) const { return TQString(QString::mid(index, len)); }
+
+ inline static TQString number( long n, int base=10 ) { return TQString(QString::number(n, base)); }
+ inline static TQString number( ulong n, int base=10) { return TQString(QString::number(n, base)); }
+ inline static TQString number( TQ_LLONG n, int base=10 ) { return TQString(QString::number(n, base)); }
+ inline static TQString number( TQ_ULLONG n, int base=10) { return TQString(QString::number(n, base)); }
+ inline static TQString number( int n, int base=10 ) { return TQString(QString::number(n, base)); }
+ inline static TQString number( uint n, int base=10) { return TQString(QString::number(n, base)); }
+ inline static TQString number( double n, char f='g', int prec=6 ) { return TQString(QString::number(n, f, prec)); }
+
+ TQString &setAscii( const char*, int len=-1 );
+ TQString &setLatin1( const char *ch, int len=-1 );
+
+// inline TQString tqarg( long a, int fieldWidth = 0, int base = 10 ) const { return TQString(this->arg(a, fieldWidth, base)); }
+// inline TQString tqarg( ulong a, int fieldWidth = 0, int base = 10 ) const { return TQString(this->arg(a, fieldWidth, base)); }
+// inline TQString tqarg( TQ_LLONG a, int fieldwidth=0, int base=10 ) const { return TQString(this->arg(a, fieldwidth, base)); }
+// inline TQString tqarg( TQ_ULLONG a, int fieldwidth=0, int base=10 ) const { return TQString(this->arg(a, fieldwidth, base)); }
+// inline TQString tqarg( int a, int fieldWidth = 0, int base = 10 ) const { return TQString(this->arg(a, fieldWidth, base)); }
+// inline TQString tqarg( uint a, int fieldWidth = 0, int base = 10 ) const { return TQString(this->arg(a, fieldWidth, base)); }
+// inline TQString tqarg( short a, int fieldWidth = 0, int base = 10 ) const { return TQString(this->arg(a, fieldWidth, base)); }
+// inline TQString tqarg( ushort a, int fieldWidth = 0, int base = 10 ) const { return TQString(this->arg(a, fieldWidth, base)); }
+// inline TQString tqarg( double a, int fieldWidth = 0, char fmt = 'g', int prec = -1 ) const { return TQString(this->arg(a, fieldWidth, fmt, prec)); }
+// inline TQString tqarg( char a, int fieldWidth = 0 ) const { return TQString(this->arg(a, fieldWidth)); }
+// inline TQString tqarg( TQChar a, int fieldWidth = 0 ) const { return TQString(this->arg(a, fieldWidth)); }
+// inline TQString tqarg( const TQString& a, int fieldWidth = 0 ) const { return TQString(this->arg(a, fieldWidth)); }
+// inline TQString tqarg( const TQString& a1, const TQString& a2 ) const { return TQString(this->arg(a1, a2)); }
+// inline TQString tqarg( const TQString& a1, const TQString& a2, const TQString& a3 ) const { return TQString(this->arg(a1, a2, a3)); }
+// inline TQString tqarg( const TQString& a1, const TQString& a2, const TQString& a3, const TQString& a4 ) const { return TQString(this->arg(a1, a2, a3, a4)); }
+
+ TQString tqarg( long a, int fieldWidth = 0, int base = 10 ) const;
+ TQString tqarg( ulong a, int fieldWidth = 0, int base = 10 ) const;
+ TQString tqarg( TQ_LLONG a, int fieldwidth=0, int base=10 ) const;
+ TQString tqarg( TQ_ULLONG a, int fieldwidth=0, int base=10 ) const;
+ TQString tqarg( int a, int fieldWidth = 0, int base = 10 ) const;
+ TQString tqarg( uint a, int fieldWidth = 0, int base = 10 ) const;
+ TQString tqarg( short a, int fieldWidth = 0, int base = 10 ) const;
+ TQString tqarg( ushort a, int fieldWidth = 0, int base = 10 ) const;
+ TQString tqarg( double a, int fieldWidth = 0, char fmt = 'g', int prec = -1 ) const;
+ TQString tqarg( char a, int fieldWidth = 0 ) const;
+ TQString tqarg( TQChar a, int fieldWidth = 0 ) const;
+ TQString tqarg( const TQString& a, int fieldWidth = 0 ) const;
+ TQString tqarg( const TQString& a1, const TQString& a2 ) const;
+ TQString tqarg( const TQString& a1, const TQString& a2, const TQString& a3 ) const;
+ TQString tqarg( const TQString& a1, const TQString& a2, const TQString& a3, const TQString& a4 ) const;
+
+ TQString setUnicodeCodes( const ushort* tqunicode_as_ushorts, uint len );
+
+ inline void setLength(int nl) { resize(nl); }
+ TQCharRef tqat( uint i );
+ TQCharRef operator[]( int i );
+
+ static TQString fromLatin1(const char *ch, int len=-1);
+ static inline TQString tqfromLatin1(const char *ch, int len=-1) { return fromLatin1(ch, len); }
+
+ static TQString fromUtf8(const char*, int len=-1);
+
+ // FIXME
+ inline void compose() { /*printf("[FIXME] void TQString::compose() unimplemented\n\r");*/ }
+
+ TQChar tqat( uint i ) const { return i < (uint)length() ? unicode()[i] : TQChar::null; }
+ TQChar operator[]( int i ) const { if ((i<0) || (i>=length())) return TQChar::null; else return tqat((uint)i); }
+
+// TQChar constref(uint i) const { return tqat(i); }
+ QChar& ref(uint i);
+
+// inline QChar ref(uint i) { return (*this)[i]; }
+
+ TQString &operator+=( const TQString &str );
+#ifndef TQT_NO_CAST_ASCII
+ TQString &operator+=( const TQByteArray &str );
+ TQString &operator+=( const char *str );
+#endif
+#ifndef TQT_NO_CAST_ASCII
+ TQString &operator+=( const std::string& );
+#endif
+ TQString &operator+=( TQChar c );
+ TQString &operator+=( char c );
+
+ TQString &operator+=( const QStringRef &s);
+ TQString &operator+=( const QLatin1String &s);
+ TQString &operator+=( QChar c );
+
+ using QString::operator=;
+
+ friend class TQObject;
+ friend class TQWidget;
+ friend class TQStyle;
+
+protected:
+ const char *ascii_helper() const;
+ const char *latin1_helper() const;
+
+public:
+ static char* tqunicodeToLatin1( const TQChar*, uint len );
+
+private:
+ mutable QByteArray tqstring_ascii_ba;
+ mutable QByteArray tqstring_latin1_ba;
+ mutable bool tqstring_issimpletext;
+
+private:
+#ifndef TQT_NO_CAST_ASCII
+// TQString &insertHelper( uint index, const char *s, uint len=UINT_MAX );
+ TQString &operatorPlusEqHelper( const char *s, uint len2=UINT_MAX );
+#endif
+
+private:
+ void subat( uint );
+ TQString tqmultiArg( int numArgs, const TQString& a1, const TQString& a2, const TQString& a3 = TQString(), const TQString& a4 = TQString() ) const;
+
+public:
+ // Interoperability
+ static const TQString& convertFromQString( QString& qstr );
+};
+
+Q_DECLARE_METATYPE(TQString)
+
+// Interoperability
+inline static const TQString& convertFromQString( const QString& qstr ) {
+ return (*static_cast<const TQString*>(&qstr));
+}
+
+inline TQString TQString::tqarg( int a, int fieldWidth, int base ) const { return tqarg( (TQ_LLONG)a, fieldWidth, base ); }
+inline TQString TQString::tqarg( uint a, int fieldWidth, int base ) const { return tqarg( (TQ_ULLONG)a, fieldWidth, base ); }
+inline TQString TQString::tqarg( short a, int fieldWidth, int base ) const { return tqarg( (TQ_LLONG)a, fieldWidth, base ); }
+inline TQString TQString::tqarg( ushort a, int fieldWidth, int base ) const { return tqarg( (TQ_ULLONG)a, fieldWidth, base ); }
+inline TQString TQString::tqarg( const TQString& a1, const TQString& a2 ) const { return tqmultiArg( 2, a1, a2 ); }
+inline TQString TQString::tqarg( const TQString& a1, const TQString& a2, const TQString& a3 ) const { return tqmultiArg( 3, a1, a2, a3 ); }
+inline TQString TQString::tqarg( const TQString& a1, const TQString& a2, const TQString& a3, const TQString& a4 ) const { return tqmultiArg( 4, a1, a2, a3, a4 ); }
+
+inline TQString TQString::copy() const { return TQString( *this ); }
+
+inline bool operator==(TQString::Null, TQString::Null) { return true; }
+inline bool operator==(TQString::Null, const TQString &s) { return s.isNull(); }
+inline bool operator==(const TQString &s, TQString::Null) { return s.isNull(); }
+inline bool operator!=(TQString::Null, TQString::Null) { return false; }
+inline bool operator!=(TQString::Null, const TQString &s) { return !s.isNull(); }
+inline bool operator!=(const TQString &s, TQString::Null) { return !s.isNull(); }
+
+#ifndef TQT_NO_CAST_ASCII
+inline TQString &TQString::operator+=( const TQByteArray &s )
+{
+ int pos = s.tqfind( 0 );
+ return operatorPlusEqHelper( s, pos==-1 ? s.size() : pos );
+}
+#endif
+
+#ifndef TQT_NO_CAST_ASCII
+inline TQString &TQString::operator+=( const std::string& s )
+{ return operator+=(s.c_str()); }
+#endif
+
+// [FIXME] The following operator+ functions spew a ridiculous number of (harmless) warnings
+// due to the very similar QString operator+ functions. Can this be fixed???
+
+TQ_EXPORT inline const TQString operator+( const TQString &s1, const TQString &s2 )
+{
+ TQString tmp( s1 );
+ tmp += s2;
+ return tmp;
+}
+
+#ifndef TQT_NO_CAST_ASCII
+TQ_EXPORT inline const TQString operator+( const TQString &s1, const char *s2 )
+{
+ TQString tmp( s1 );
+ tmp += TQString::fromAscii(s2);
+ return tmp;
+}
+
+TQ_EXPORT inline const TQString operator+( const char *s1, const TQString &s2 )
+{
+ TQString tmp = TQString::fromAscii( s1 );
+ tmp += s2;
+ return tmp;
+}
+#endif
+
+TQ_EXPORT inline const TQString operator+( const TQString &s1, TQChar c2 )
+{
+ TQString tmp( s1 );
+ tmp += c2;
+ return tmp;
+}
+
+TQ_EXPORT inline const TQString operator+( const TQString &s1, char c2 )
+{
+ TQString tmp( s1 );
+ tmp += c2;
+ return tmp;
+}
+
+TQ_EXPORT inline const TQString operator+( TQChar c1, const TQString &s2 )
+{
+ TQString tmp;
+ tmp += c1;
+ tmp += s2;
+ return tmp;
+}
+
+TQ_EXPORT inline const TQString operator+( char c1, const TQString &s2 )
+{
+ TQString tmp;
+ tmp += c1;
+ tmp += s2;
+ return tmp;
+}
+
+#ifndef TQT_NO_STL
+TQ_EXPORT inline const TQString operator+(const TQString& s1, const std::string& s2)
+{
+ return s1 + TQString(s2);
+}
+
+TQ_EXPORT inline const TQString operator+(const std::string& s1, const TQString& s2)
+{
+ TQString tmp(s2);
+ return TQString(tmp.prepend(s1.c_str()));
+}
+#endif
+
+class TQConstString : public TQString
+{
+public:
+ inline TQConstString(const QChar *aUnicode, int aSize) : TQString(aUnicode, aSize) {} // cannot use fromRawData() due to changed semantics
+ inline const TQString &string() const { return *this; }
+};
+
+class TQ_EXPORT TQCharRef {
+ friend class TQString;
+ TQString& s;
+ uint p;
+ TQCharRef(TQString* str, uint pos) : s(*str), p(pos) { }
+
+public:
+ // most TQChar operations repeated here
+
+ // all this is not documented: We just say "like TQChar" and let it be.
+#ifndef TQ_TQDOC
+ ushort unicode() const { return s.constref(p).tqunicode(); }
+ ushort tqunicode() const { return s.constref(p).tqunicode(); }
+ char latin1() const { return s.constref(p).latin1(); }
+
+ // An operator= for each TQChar cast constructors
+ TQCharRef operator=(char c ) { s.ref(p)=c; return *this; }
+ TQCharRef operator=(uchar c ) { s.ref(p)=c; return *this; }
+ TQCharRef operator=(TQChar c ) { s.ref(p)=c; return *this; }
+ TQCharRef operator=(const TQCharRef& c ) { s.ref(p)=c.tqunicode(); return *this; }
+ TQCharRef operator=(ushort rc ) { s.ref(p)=rc; return *this; }
+ TQCharRef operator=(short rc ) { s.ref(p)=rc; return *this; }
+ TQCharRef operator=(uint rc ) { s.ref(p)=rc; return *this; }
+ TQCharRef operator=(int rc ) { s.ref(p)=rc; return *this; }
+
+ operator TQChar () const { return s.constref(p); }
+
+ // each function...
+ bool isNull() const { return tqunicode()==0; }
+ bool isPrint() const { return s.constref(p).isPrint(); }
+ bool isPunct() const { return s.constref(p).isPunct(); }
+ bool isSpace() const { return s.constref(p).isSpace(); }
+ bool isMark() const { return s.constref(p).isMark(); }
+ bool isLetter() const { return s.constref(p).isLetter(); }
+ bool isNumber() const { return s.constref(p).isNumber(); }
+ bool isLetterOrNumber() { return s.constref(p).isLetterOrNumber(); }
+ bool isDigit() const { return s.constref(p).isDigit(); }
+
+ int digitValue() const { return s.constref(p).digitValue(); }
+ TQChar lower() const { return s.constref(p).lower(); }
+ TQChar upper() const { return s.constref(p).upper(); }
+
+ TQChar::Category category() const { return s.constref(p).category(); }
+ TQChar::Direction direction() const { return s.constref(p).direction(); }
+ TQChar::Joining joining() const { return s.constref(p).joining(); }
+ bool mirrored() const { return s.constref(p).mirrored(); }
+ TQChar mirroredChar() const { return s.constref(p).mirroredChar(); }
+// const TQString &decomposition() const { return s.constref(p).decomposition(); }
+ TQChar::Decomposition decompositionTag() const { return s.constref(p).decompositionTag(); }
+ unsigned char combiningClass() const { return s.constref(p).combiningClass(); }
+
+ // Not the non-const ones of these.
+ uchar cell() const { return s.constref(p).cell(); }
+ uchar row() const { return s.constref(p).row(); }
+#endif
+};
+
+// inline TQChar& TQString::ref(uint i)
+inline QChar& TQString::ref(uint i)
+{ // Optimized for easy-inlining by simple compilers.
+ if ( count() != 1 || i >= (uint)length() )
+ subat( i );
+// d->setDirty();
+// return tqunicode()[i];
+
+// const QCharRef& ref = QString::operator[](i);
+// return *const_cast<TQChar*>(static_cast<const TQChar*>(&reinterpret_cast<const QChar&>(ref))); // [FIXME] Will this work the same as data->unicode did in Qt3? Will it work at all???
+
+ QChar *tdata = data();
+ return tdata[i]; // [FIXME] Will this work the same as data->unicode did in Qt3? Will it work at all???
+}
+
+inline TQCharRef TQString::tqat( uint i ) { return TQCharRef(this,i); }
+inline TQCharRef TQString::operator[]( int i ) { return tqat((uint)i); }
+
+/*****************************************************************************
+ TQString stream functions
+ *****************************************************************************/
+#ifndef TQT_NO_DATASTREAM
+TQ_EXPORT TQDataStream &operator<<( TQDataStream &, const TQString & );
+TQ_EXPORT TQDataStream &operator>>( TQDataStream &, TQString & );
+#endif
+
+/*****************************************************************************
+ TQString non-member operators
+ *****************************************************************************/
+
+inline TQ_EXPORT bool operator!=( const TQString &s1, const TQString &s2 ) {
+ if (s1.isNull() != s2.isNull()) return true;
+ return (static_cast<const QString&>(s1) != static_cast<const QString&>(s2));
+}
+inline TQ_EXPORT bool operator==( const TQString &s1, const TQString &s2 ) {
+ if (s1.isNull() != s2.isNull()) return false;
+ return (static_cast<const QString&>(s1) == static_cast<const QString&>(s2));
+}
+
+#else // USE_QT4
+
+/*****************************************************************************
+ TQString class
+ *****************************************************************************/
+
+class TQRegExp;
+class TQString;
+class TQCharRef;
+template <class T> class TQDeepCopy;
+
+class TQ_EXPORT TQChar {
+public:
+ TQChar();
+ TQChar( char c );
+ TQChar( uchar c );
+ TQChar( uchar c, uchar r );
+ TQChar( const TQChar& c ); // ### remove in 4.0 to allow compiler optimization
+ TQChar( ushort rc );
+ TQChar( short rc );
+ TQChar( uint rc );
+ TQChar( int rc );
+
+ TQT_STATIC_CONST TQChar null; // 0000
+ TQT_STATIC_CONST TQChar tqreplacement; // FFFD
+ TQT_STATIC_CONST TQChar byteOrderMark; // FEFF
+ TQT_STATIC_CONST TQChar byteOrderSwapped; // FFFE
+ TQT_STATIC_CONST TQChar nbsp; // 00A0
+
+ // Unicode information
+
+ enum Category
+ {
+ NoCategory,
+
+ Mark_NonSpacing, // Mn
+ Mark_SpacingCombining, // Mc
+ Mark_Enclosing, // Me
+
+ Number_DecimalDigit, // Nd
+ Number_Letter, // Nl
+ Number_Other, // No
+
+ Separator_Space, // Zs
+ Separator_Line, // Zl
+ Separator_Paragraph, // Zp
+
+ Other_Control, // Cc
+ Other_Format, // Cf
+ Other_Surrogate, // Cs
+ Other_PrivateUse, // Co
+ Other_NotAssigned, // Cn
+
+ Letter_Uppercase, // Lu
+ Letter_Lowercase, // Ll
+ Letter_Titlecase, // Lt
+ Letter_Modifier, // Lm
+ Letter_Other, // Lo
+
+ Punctuation_Connector, // Pc
+ Punctuation_Dash, // Pd
+ Punctuation_Dask = Punctuation_Dash, // oops
+ Punctuation_Open, // Ps
+ Punctuation_Close, // Pe
+ Punctuation_InitialQuote, // Pi
+ Punctuation_FinalQuote, // Pf
+ Punctuation_Other, // Po
+
+ Symbol_Math, // Sm
+ Symbol_Currency, // Sc
+ Symbol_Modifier, // Sk
+ Symbol_Other // So
+ };
+
+ enum Direction
+ {
+ DirL, DirR, DirEN, DirES, DirET, DirAN, DirCS, DirB, DirS, DirWS, DirON,
+ DirLRE, DirLRO, DirAL, DirRLE, DirRLO, DirPDF, DirNSM, DirBN
+ };
+
+ enum Decomposition
+ {
+ Single, Canonical, Font, NoBreak, Initial, Medial,
+ Final, Isolated, Circle, Super, Sub, Vertical,
+ Wide, Narrow, Small, Square, Compat, Fraction
+ };
+
+ enum Joining
+ {
+ OtherJoining, Dual, Right, Center
+ };
+
+ enum CombiningClass
+ {
+ Combining_BelowLeftAttached = 200,
+ Combining_BelowAttached = 202,
+ Combining_BelowRightAttached = 204,
+ Combining_LeftAttached = 208,
+ Combining_RightAttached = 210,
+ Combining_AboveLeftAttached = 212,
+ Combining_AboveAttached = 214,
+ Combining_AboveRightAttached = 216,
+
+ Combining_BelowLeft = 218,
+ Combining_Below = 220,
+ Combining_BelowRight = 222,
+ Combining_Left = 224,
+ Combining_Right = 226,
+ Combining_AboveLeft = 228,
+ Combining_Above = 230,
+ Combining_AboveRight = 232,
+
+ Combining_DoubleBelow = 233,
+ Combining_DoubleAbove = 234,
+ Combining_IotaSubscript = 240
+ };
+
+ // ****** WHEN ADDING FUNCTIONS, CONSIDER ADDING TO TQCharRef TOO
+
+ int digitValue() const;
+ TQChar lower() const;
+ TQChar upper() const;
+
+ Category category() const;
+ Direction direction() const;
+ Joining joining() const;
+ bool mirrored() const;
+ TQChar mirroredChar() const;
+ const TQString &decomposition() const; // ### return just TQString in 4.0
+ Decomposition decompositionTag() const;
+ unsigned char combiningClass() const;
+
+ char latin1() const { return ucs > 0xff ? 0 : (char) ucs; }
+ ushort tqunicode() const { return ucs; }
+#ifdef TQ_NO_PACKED_REFERENCE
+ ushort &tqunicode() { return *(&ucs); }
+#else
+ ushort &tqunicode() { return ucs; }
+#endif
+#ifndef TQT_NO_CAST_ASCII
+ // like all ifdef'd code this is undocumented
+ operator char() const { return latin1(); }
+#endif
+
+ bool isNull() const { return tqunicode()==0; }
+ bool isPrint() const;
+ bool isPunct() const;
+ bool isSpace() const;
+ bool isMark() const;
+ bool isLetter() const;
+ bool isNumber() const;
+ bool isLetterOrNumber() const;
+ bool isDigit() const;
+ bool isSymbol() const;
+
+ uchar cell() const { return ((uchar) ucs & 0xff); }
+ uchar row() const { return ((uchar) (ucs>>8)&0xff); }
+ void setCell( uchar cell ) { ucs = (ucs & 0xff00) + cell; }
+ void setRow( uchar row ) { ucs = (((ushort) row)<<8) + (ucs&0xff); }
+
+ static bool networkOrdered() {
+ int wordSize;
+ bool bigEndian = FALSE;
+ qSysInfo( &wordSize, &bigEndian );
+ return bigEndian;
+ }
+
+ friend inline bool operator==( char ch, TQChar c );
+ friend inline bool operator==( TQChar c, char ch );
+ friend inline bool operator==( TQChar c1, TQChar c2 );
+ friend inline bool operator!=( TQChar c1, TQChar c2 );
+ friend inline bool operator!=( char ch, TQChar c );
+ friend inline bool operator!=( TQChar c, char ch );
+ friend inline bool operator<=( TQChar c, char ch );
+ friend inline bool operator<=( char ch, TQChar c );
+ friend inline bool operator<=( TQChar c1, TQChar c2 );
+
+private:
+ ushort ucs;
+#if defined(TQT_TQSTRING_UCS_4)
+ ushort grp;
+#endif
+} TQ_PACKED;
+
+inline TQChar::TQChar() : ucs( 0 )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( 0 )
+#endif
+{
+}
+inline TQChar::TQChar( char c ) : ucs( (uchar)c )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( 0 )
+#endif
+{
+}
+inline TQChar::TQChar( uchar c ) : ucs( c )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( 0 )
+#endif
+{
+}
+inline TQChar::TQChar( uchar c, uchar r ) : ucs( (r << 8) | c )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( 0 )
+#endif
+{
+}
+inline TQChar::TQChar( const TQChar& c ) : ucs( c.ucs )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( c.grp )
+#endif
+{
+}
+
+inline TQChar::TQChar( ushort rc ) : ucs( rc )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( 0 )
+#endif
+{
+}
+inline TQChar::TQChar( short rc ) : ucs( (ushort) rc )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( 0 )
+#endif
+{
+}
+inline TQChar::TQChar( uint rc ) : ucs( (ushort ) (rc & 0xffff) )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( (ushort) ((rc >> 16) & 0xffff) )
+#endif
+{
+}
+inline TQChar::TQChar( int rc ) : ucs( (ushort) (rc & 0xffff) )
+#ifdef TQT_TQSTRING_UCS_4
+ , grp( (ushort) ((rc >> 16) & 0xffff) )
+#endif
+{
+}
+
+inline bool operator==( char ch, TQChar c )
+{
+ return ((uchar) ch) == c.ucs;
+}
+
+inline bool operator==( TQChar c, char ch )
+{
+ return ((uchar) ch) == c.ucs;
+}
+
+inline bool operator==( TQChar c1, TQChar c2 )
+{
+ return c1.ucs == c2.ucs;
+}
+
+inline bool operator!=( TQChar c1, TQChar c2 )
+{
+ return c1.ucs != c2.ucs;
+}
+
+inline bool operator!=( char ch, TQChar c )
+{
+ return ((uchar)ch) != c.ucs;
+}
+
+inline bool operator!=( TQChar c, char ch )
+{
+ return ((uchar) ch) != c.ucs;
+}
+
+inline bool operator<=( TQChar c, char ch )
+{
+ return c.ucs <= ((uchar) ch);
+}
+
+inline bool operator<=( char ch, TQChar c )
+{
+ return ((uchar) ch) <= c.ucs;
+}
+
+inline bool operator<=( TQChar c1, TQChar c2 )
+{
+ return c1.ucs <= c2.ucs;
+}
+
+inline bool operator>=( TQChar c, char ch ) { return ch <= c; }
+inline bool operator>=( char ch, TQChar c ) { return c <= ch; }
+inline bool operator>=( TQChar c1, TQChar c2 ) { return c2 <= c1; }
+inline bool operator<( TQChar c, char ch ) { return !(ch<=c); }
+inline bool operator<( char ch, TQChar c ) { return !(c<=ch); }
+inline bool operator<( TQChar c1, TQChar c2 ) { return !(c2<=c1); }
+inline bool operator>( TQChar c, char ch ) { return !(ch>=c); }
+inline bool operator>( char ch, TQChar c ) { return !(c>=ch); }
+inline bool operator>( TQChar c1, TQChar c2 ) { return !(c2>=c1); }
+
+// internal
+struct TQ_EXPORT TQStringData : public TQShared {
+ TQStringData() :
+ TQShared(), tqunicode(0), ascii(0), len(0), issimpletext(TRUE), maxl(0), islatin1(FALSE) { ref(); }
+ TQStringData(TQChar *u, uint l, uint m) :
+ TQShared(), tqunicode(u), ascii(0), len(l), issimpletext(FALSE), maxl(m), islatin1(FALSE) { }
+ ~TQStringData() { if ( tqunicode ) delete[] ((char*)tqunicode);
+ if ( ascii ) delete[] ascii; }
+
+ void deleteSelf();
+ TQChar *tqunicode;
+ char *ascii;
+ void setDirty() {
+ if ( ascii ) {
+ delete [] ascii;
+ ascii = 0;
+ }
+ issimpletext = FALSE;
+ }
+#ifdef TQ_OS_MAC9
+ uint len;
+#else
+ uint len : 30;
+#endif
+ uint issimpletext : 1;
+#ifdef TQ_OS_MAC9
+ uint maxl;
+#else
+ uint maxl : 30;
+#endif
+ uint islatin1 : 1;
+
+private:
+#if defined(TQ_DISABLE_COPY)
+ TQStringData( const TQStringData& );
+ TQStringData& operator=( const TQStringData& );
+#endif
+};
+
+
+class TQ_EXPORT TQString
+{
+public:
+ TQString(); // make null string
+ TQString( TQChar ); // one-char string
+ TQString( const TQString & ); // impl-shared copy
+ TQString( const TQByteArray& ); // deep copy
+ TQString( const TQChar* tqunicode, uint length ); // deep copy
+#ifndef TQT_NO_CAST_ASCII
+ TQString( const char *str ); // deep copy
+#endif
+#ifndef TQT_NO_STL
+ TQString( const std::string& ); // deep copy
+#endif
+ ~TQString();
+
+#ifdef USE_QT4
+ // Interoperability
+ TQString( const QString &qs );
+ operator QString() const;
+ TQString &operator=( const QString &qs );
+#endif // USE_QT4
+
+ TQString &operator=( const TQString & ); // impl-shared copy
+ TQString &operator=( const char * ); // deep copy
+#ifndef TQT_NO_STL
+ TQString &operator=( const std::string& ); // deep copy
+#endif
+ TQString &operator=( const TQCString& ); // deep copy
+ TQString &operator=( TQChar c );
+ TQString &operator=( char c );
+
+ TQT_STATIC_CONST TQString null;
+
+ bool isNull() const;
+ bool isEmpty() const;
+ uint length() const;
+ void truncate( uint pos );
+
+ TQString & fill( TQChar c, int len = -1 );
+
+ TQString copy() const;
+
+ TQString arg( long a, int fieldWidth = 0, int base = 10 ) const;
+ TQString arg( ulong a, int fieldWidth = 0, int base = 10 ) const;
+ TQString arg( TQ_LLONG a, int fieldwidth=0, int base=10 ) const;
+ TQString arg( TQ_ULLONG a, int fieldwidth=0, int base=10 ) const;
+ TQString arg( int a, int fieldWidth = 0, int base = 10 ) const;
+ TQString arg( uint a, int fieldWidth = 0, int base = 10 ) const;
+ TQString arg( short a, int fieldWidth = 0, int base = 10 ) const;
+ TQString arg( ushort a, int fieldWidth = 0, int base = 10 ) const;
+ TQString arg( double a, int fieldWidth = 0, char fmt = 'g',
+ int prec = -1 ) const;
+ TQString arg( char a, int fieldWidth = 0 ) const;
+ TQString arg( TQChar a, int fieldWidth = 0 ) const;
+ TQString arg( const TQString& a, int fieldWidth = 0 ) const;
+ TQString arg( const TQString& a1, const TQString& a2 ) const;
+ TQString arg( const TQString& a1, const TQString& a2,
+ const TQString& a3 ) const;
+ TQString arg( const TQString& a1, const TQString& a2, const TQString& a3,
+ const TQString& a4 ) const;
+
+#ifndef TQT_NO_SPRINTF
+ TQString &sprintf( const char* format, ... )
+#if defined(TQ_CC_GNU) && !defined(__INSURE__)
+ __attribute__ ((format (printf, 2, 3)))
+#endif
+ ;
+#endif
+
+ int tqfind( TQChar c, int index=0, bool cs=TRUE ) const;
+ int tqfind( char c, int index=0, bool cs=TRUE ) const;
+ int tqfind( const TQString &str, int index=0, bool cs=TRUE ) const;
+#ifndef TQT_NO_REGEXP
+ int tqfind( const TQRegExp &, int index=0 ) const;
+#endif
+#ifndef TQT_NO_CAST_ASCII
+ int tqfind( const char* str, int index=0 ) const;
+#endif
+ int tqfindRev( TQChar c, int index=-1, bool cs=TRUE) const;
+ int tqfindRev( char c, int index=-1, bool cs=TRUE) const;
+ int tqfindRev( const TQString &str, int index=-1, bool cs=TRUE) const;
+#ifndef TQT_NO_REGEXP
+ int tqfindRev( const TQRegExp &, int index=-1 ) const;
+#endif
+#ifndef TQT_NO_CAST_ASCII
+ int tqfindRev( const char* str, int index=-1 ) const;
+#endif
+ int tqcontains( TQChar c, bool cs=TRUE ) const;
+ int tqcontains( char c, bool cs=TRUE ) const
+ { return tqcontains(TQChar(c), cs); }
+#ifndef TQT_NO_CAST_ASCII
+ int tqcontains( const char* str, bool cs=TRUE ) const;
+#endif
+ int tqcontains( const TQString &str, bool cs=TRUE ) const;
+#ifndef TQT_NO_REGEXP
+ int tqcontains( const TQRegExp & ) const;
+#endif
+
+ enum SectionFlags {
+ SectionDefault = 0x00,
+ SectionSkipEmpty = 0x01,
+ SectionIncludeLeadingSep = 0x02,
+ SectionIncludeTrailingSep = 0x04,
+ SectionCaseInsensitiveSeps = 0x08
+ };
+ TQString section( TQChar sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const;
+ TQString section( char sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const;
+#ifndef TQT_NO_CAST_ASCII
+ TQString section( const char *in_sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const;
+#endif
+ TQString section( const TQString &in_sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const;
+#ifndef TQT_NO_REGEXP
+ TQString section( const TQRegExp &reg, int start, int end = 0xffffffff, int flags = SectionDefault ) const;
+#endif
+
+ TQString left( uint len ) const;
+ TQString right( uint len ) const;
+ TQString mid( uint index, uint len=0xffffffff) const;
+
+ TQString leftJustify( uint width, TQChar fill=' ', bool trunc=FALSE)const;
+ TQString rightJustify( uint width, TQChar fill=' ',bool trunc=FALSE)const;
+
+ TQString lower() const;
+ TQString upper() const;
+
+ TQString stripWhiteSpace() const;
+ TQString simplifyWhiteSpace() const;
+
+ TQString &insert( uint index, const TQString & );
+#ifndef TQT_NO_CAST_ASCII
+ TQString &insert( uint index, const TQByteArray & );
+ TQString &insert( uint index, const char * );
+#endif
+ TQString &insert( uint index, const TQChar*, uint len );
+ TQString &insert( uint index, TQChar );
+ TQString &insert( uint index, char c ) { return insert(index,TQChar(c)); }
+ TQString &append( char );
+ TQString &append( TQChar );
+ TQString &append( const TQString & );
+#ifndef TQT_NO_CAST_ASCII
+ TQString &append( const TQByteArray & );
+ TQString &append( const char * );
+#endif
+#if !defined(TQT_NO_STL) && !defined(TQT_NO_CAST_ASCII)
+ TQString &append( const std::string& );
+#endif
+ TQString &prepend( char );
+ TQString &prepend( TQChar );
+ TQString &prepend( const TQString & );
+#ifndef TQT_NO_CAST_ASCII
+ TQString &prepend( const TQByteArray & );
+ TQString &prepend( const char * );
+#endif
+#if !defined(TQT_NO_STL) && !defined(TQT_NO_CAST_ASCII)
+ TQString &prepend( const std::string& );
+#endif
+ TQString &remove( uint index, uint len );
+#if defined(TQ_TQDOC)
+ TQString &remove( const TQString & str, bool cs = TRUE );
+#else
+ // ### TQt 4.0: merge these two into one, and remove TQ_TQDOC hack
+ TQString &remove( const TQString & );
+ TQString &remove( const TQString &, bool cs );
+#endif
+ TQString &remove( TQChar c );
+ TQString &remove( char c )
+ { return remove( TQChar(c) ); }
+#ifndef TQT_NO_CAST_ASCII
+ TQString &remove( const char * );
+#endif
+#ifndef TQT_NO_REGEXP
+ TQString &remove( const TQRegExp & );
+#endif
+ TQString &tqreplace( uint index, uint len, const TQString & );
+ TQString &tqreplace( uint index, uint len, const TQChar*, uint clen );
+ TQString &tqreplace( uint index, uint len, TQChar );
+ TQString &tqreplace( uint index, uint len, char c )
+ { return tqreplace( index, len, TQChar(c) ); }
+#if defined(TQ_TQDOC)
+ TQString &tqreplace( TQChar c, const TQString & after, bool cs = TRUE );
+ TQString &tqreplace( char c, const TQString & after, bool cs = TRUE );
+ TQString &tqreplace( const TQString & before, const TQString & after,
+ bool cs = TRUE );
+#else
+ // ### TQt 4.0: merge these two into one, and remove TQ_TQDOC hack
+ TQString &tqreplace( TQChar c, const TQString & );
+ TQString &tqreplace( TQChar c, const TQString &, bool );
+
+ // ### TQt 4.0: merge these two into one, and remove TQ_TQDOC hack
+ TQString &tqreplace( char c, const TQString & after )
+ { return tqreplace( TQChar(c), after, TRUE ); }
+ TQString &tqreplace( char c, const TQString & after, bool cs )
+ { return tqreplace( TQChar(c), after, cs ); }
+
+ // ### TQt 4.0: merge these two into one, and remove TQ_TQDOC hack
+ TQString &tqreplace( const TQString &, const TQString & );
+ TQString &tqreplace( const TQString &, const TQString &, bool );
+#endif
+#ifndef TQT_NO_REGEXP_CAPTURE
+ TQString &tqreplace( const TQRegExp &, const TQString & );
+#endif
+ TQString &tqreplace( TQChar, TQChar );
+
+ short toShort( bool *ok=0, int base=10 ) const;
+ ushort toUShort( bool *ok=0, int base=10 ) const;
+ int toInt( bool *ok=0, int base=10 ) const;
+ uint toUInt( bool *ok=0, int base=10 ) const;
+ long toLong( bool *ok=0, int base=10 ) const;
+ ulong toULong( bool *ok=0, int base=10 ) const;
+ TQ_LLONG toLongLong( bool *ok=0, int base=10 ) const;
+ TQ_ULLONG toULongLong( bool *ok=0, int base=10 ) const;
+ float toFloat( bool *ok=0 ) const;
+ double toDouble( bool *ok=0 ) const;
+
+ TQString &setNum( short, int base=10 );
+ TQString &setNum( ushort, int base=10 );
+ TQString &setNum( int, int base=10 );
+ TQString &setNum( uint, int base=10 );
+ TQString &setNum( long, int base=10 );
+ TQString &setNum( ulong, int base=10 );
+ TQString &setNum( TQ_LLONG, int base=10 );
+ TQString &setNum( TQ_ULLONG, int base=10 );
+ TQString &setNum( float, char f='g', int prec=6 );
+ TQString &setNum( double, char f='g', int prec=6 );
+
+ static TQString number( long, int base=10 );
+ static TQString number( ulong, int base=10);
+ static TQString number( TQ_LLONG, int base=10 );
+ static TQString number( TQ_ULLONG, int base=10);
+ static TQString number( int, int base=10 );
+ static TQString number( uint, int base=10);
+ static TQString number( double, char f='g', int prec=6 );
+
+ void setExpand( uint index, TQChar c );
+
+ TQString &operator+=( const TQString &str );
+#ifndef TQT_NO_CAST_ASCII
+ TQString &operator+=( const TQByteArray &str );
+ TQString &operator+=( const char *str );
+#endif
+#if !defined(TQT_NO_STL) && !defined(TQT_NO_CAST_ASCII)
+ TQString &operator+=( const std::string& );
+#endif
+ TQString &operator+=( TQChar c );
+ TQString &operator+=( char c );
+
+ TQChar at( uint i ) const
+ { return i < d->len ? d->tqunicode[i] : TQChar::null; }
+ TQChar operator[]( int i ) const { if ((i<0) || (i>=length())) return TQChar::null; else return at((uint)i); }
+ TQCharRef at( uint i );
+ TQCharRef operator[]( int i );
+
+ TQChar constref(uint i) const
+ { return at(i); }
+ TQChar& ref(uint i)
+ { // Optimized for easy-inlining by simple compilers.
+ if ( d->count != 1 || i >= d->len )
+ subat( i );
+ d->setDirty();
+ return d->tqunicode[i];
+ }
+
+ const TQChar* tqunicode() const { return d->tqunicode; }
+ const char* ascii() const;
+ static TQString fromAscii(const char*, int len=-1);
+ const char* latin1() const;
+ static TQString tqfromLatin1(const char*, int len=-1);
+ TQCString utf8() const;
+ static TQString fromUtf8(const char*, int len=-1);
+ TQCString local8Bit() const;
+ static TQString fromLocal8Bit(const char*, int len=-1);
+ bool operator!() const;
+#ifndef TQT_NO_ASCII_CAST
+ operator const char *() const { return ascii(); }
+#endif
+#ifndef TQT_NO_STL
+ operator std::string() const { return ascii() ? ascii() : ""; }
+#endif
+
+ static TQString fromUcs2( const unsigned short *ucs2 );
+ const unsigned short *ucs2() const;
+
+ TQString &setUnicode( const TQChar* tqunicode, uint len );
+ TQString &setUnicodeCodes( const ushort* tqunicode_as_ushorts, uint len );
+ TQString &setAscii( const char*, int len=-1 );
+ TQString &setLatin1( const char*, int len=-1 );
+
+ int compare( const TQString& s ) const;
+ static int compare( const TQString& s1, const TQString& s2 )
+ { return s1.compare( s2 ); }
+
+ int localeAwareCompare( const TQString& s ) const;
+ static int localeAwareCompare( const TQString& s1, const TQString& s2 )
+ { return s1.localeAwareCompare( s2 ); }
+
+#ifndef TQT_NO_DATASTREAM
+ friend TQ_EXPORT TQDataStream &operator>>( TQDataStream &, TQString & );
+#endif
+
+ void compose();
+
+#ifndef TQT_NO_COMPAT
+ const char* data() const { return ascii(); }
+#endif
+
+#if defined(TQ_TQDOC)
+ bool startsWith( const TQString& str, bool cs = TRUE ) const;
+ bool endsWith( const TQString& str, bool cs = TRUE ) const;
+#else
+ // ### TQt 4.0: merge these two into one, and remove TQ_TQDOC hack
+ bool startsWith( const TQString& str ) const;
+ bool startsWith( const TQString& str, bool cs ) const;
+
+ // ### TQt 4.0: merge these two into one, and remove TQ_TQDOC hack
+ bool endsWith( const TQString& str ) const;
+ bool endsWith( const TQString& str, bool cs ) const;
+#endif
+
+ void setLength( uint newLength );
+
+ uint capacity() const;
+ void reserve( uint minCapacity );
+ void squeeze();
+
+ bool simpleText() const { if ( !d->issimpletext ) checkSimpleText(); return (bool)d->issimpletext; }
+ bool isRightToLeft() const;
+
+
+private:
+ TQString( int size, bool /* dummy */ ); // allocate size incl. \0
+
+ void deref();
+ void real_detach();
+ void subat( uint );
+ TQString multiArg( int numArgs, const TQString& a1, const TQString& a2,
+ const TQString& a3 = TQString::null,
+ const TQString& a4 = TQString::null ) const;
+
+ void checkSimpleText() const;
+ void grow( uint newLength );
+#ifndef TQT_NO_CAST_ASCII
+ TQString &insertHelper( uint index, const char *s, uint len=UINT_MAX );
+ TQString &operatorPlusEqHelper( const char *s, uint len2=UINT_MAX );
+#endif
+
+ static TQChar* latin1ToUnicode( const char*, uint * len, uint maxlen=(uint)-1 );
+ static TQChar* latin1ToUnicode( const TQByteArray&, uint * len );
+ static char* tqunicodeToLatin1( const TQChar*, uint len );
+
+ TQStringData *d;
+ static TQStringData* shared_null;
+ static TQStringData* makeSharedNull();
+
+ friend class TQConstString;
+ friend class TQTextStream;
+ TQString( TQStringData* dd, bool /* dummy */ ) : d(dd) { }
+
+ // needed for TQDeepCopy
+ void detach();
+ friend class TQDeepCopy<TQString>;
+};
+
+class TQ_EXPORT TQCharRef {
+ friend class TQString;
+ TQString& s;
+ uint p;
+ TQCharRef(TQString* str, uint pos) : s(*str), p(pos) { }
+
+public:
+ // most TQChar operations repeated here
+
+ // all this is not documented: We just say "like TQChar" and let it be.
+#ifndef TQ_TQDOC
+ ushort tqunicode() const { return s.constref(p).tqunicode(); }
+ char latin1() const { return s.constref(p).latin1(); }
+
+ // An operator= for each TQChar cast constructors
+ TQCharRef operator=(char c ) { s.ref(p)=c; return *this; }
+ TQCharRef operator=(uchar c ) { s.ref(p)=c; return *this; }
+ TQCharRef operator=(TQChar c ) { s.ref(p)=c; return *this; }
+ TQCharRef operator=(const TQCharRef& c ) { s.ref(p)=c.tqunicode(); return *this; }
+ TQCharRef operator=(ushort rc ) { s.ref(p)=rc; return *this; }
+ TQCharRef operator=(short rc ) { s.ref(p)=rc; return *this; }
+ TQCharRef operator=(uint rc ) { s.ref(p)=rc; return *this; }
+ TQCharRef operator=(int rc ) { s.ref(p)=rc; return *this; }
+
+ operator TQChar () const { return s.constref(p); }
+
+ // each function...
+ bool isNull() const { return tqunicode()==0; }
+ bool isPrint() const { return s.constref(p).isPrint(); }
+ bool isPunct() const { return s.constref(p).isPunct(); }
+ bool isSpace() const { return s.constref(p).isSpace(); }
+ bool isMark() const { return s.constref(p).isMark(); }
+ bool isLetter() const { return s.constref(p).isLetter(); }
+ bool isNumber() const { return s.constref(p).isNumber(); }
+ bool isLetterOrNumber() { return s.constref(p).isLetterOrNumber(); }
+ bool isDigit() const { return s.constref(p).isDigit(); }
+
+ int digitValue() const { return s.constref(p).digitValue(); }
+ TQChar lower() const { return s.constref(p).lower(); }
+ TQChar upper() const { return s.constref(p).upper(); }
+
+ TQChar::Category category() const { return s.constref(p).category(); }
+ TQChar::Direction direction() const { return s.constref(p).direction(); }
+ TQChar::Joining joining() const { return s.constref(p).joining(); }
+ bool mirrored() const { return s.constref(p).mirrored(); }
+ TQChar mirroredChar() const { return s.constref(p).mirroredChar(); }
+ const TQString &decomposition() const { return s.constref(p).decomposition(); }
+ TQChar::Decomposition decompositionTag() const { return s.constref(p).decompositionTag(); }
+ unsigned char combiningClass() const { return s.constref(p).combiningClass(); }
+
+ // Not the non-const ones of these.
+ uchar cell() const { return s.constref(p).cell(); }
+ uchar row() const { return s.constref(p).row(); }
+#endif
+};
+
+inline TQCharRef TQString::at( uint i ) { return TQCharRef(this,i); }
+inline TQCharRef TQString::operator[]( int i ) { return tqat((uint)i); }
+
+
+class TQ_EXPORT TQConstString : private TQString {
+public:
+ TQConstString( const TQChar* tqunicode, uint length );
+ ~TQConstString();
+ const TQString& string() const { return *this; }
+};
+
+
+/*****************************************************************************
+ TQString stream functions
+ *****************************************************************************/
+#ifndef TQT_NO_DATASTREAM
+TQ_EXPORT TQDataStream &operator<<( TQDataStream &, const TQString & );
+TQ_EXPORT TQDataStream &operator>>( TQDataStream &, TQString & );
+#endif
+
+/*****************************************************************************
+ TQString inline functions
+ *****************************************************************************/
+
+// These two move code into makeSharedNull() and deletesData()
+// to improve cache-coherence (and reduce code bloat), while
+// keeping the common cases fast.
+//
+// No safe way to pre-init shared_null on ALL compilers/linkers.
+inline TQString::TQString() :
+ d(shared_null ? shared_null : makeSharedNull())
+{
+ d->ref();
+}
+//
+inline TQString::~TQString()
+{
+ if ( d->deref() ) {
+ if ( d != shared_null )
+ d->deleteSelf();
+ }
+}
+
+// needed for TQDeepCopy
+inline void TQString::detach()
+{ real_detach(); }
+
+inline TQString TQString::section( TQChar sep, int start, int end, int flags ) const
+{ return section(TQString(sep), start, end, flags); }
+
+inline TQString TQString::section( char sep, int start, int end, int flags ) const
+{ return section(TQChar(sep), start, end, flags); }
+
+#ifndef TQT_NO_CAST_ASCII
+inline TQString TQString::section( const char *in_sep, int start, int end, int flags ) const
+{ return section(TQString(in_sep), start, end, flags); }
+#endif
+
+inline TQString &TQString::operator=( TQChar c )
+{ *this = TQString(c); return *this; }
+
+inline TQString &TQString::operator=( char c )
+{ *this = TQString(TQChar(c)); return *this; }
+
+inline bool TQString::isNull() const
+{ return tqunicode() == 0; }
+
+inline bool TQString::operator!() const
+{ return isNull(); }
+
+inline uint TQString::length() const
+{ return d->len; }
+
+inline uint TQString::capacity() const
+{ return d->maxl; }
+
+inline bool TQString::isEmpty() const
+{ return length() == 0; }
+
+inline TQString TQString::copy() const
+{ return TQString( *this ); }
+
+#ifndef TQT_NO_CAST_ASCII
+inline TQString &TQString::insert( uint index, const char *s )
+{ return insertHelper( index, s ); }
+
+inline TQString &TQString::insert( uint index, const TQByteArray &s )
+{
+ int pos = s.tqfind( 0 );
+ return insertHelper( index, s, pos==-1 ? s.size() : pos );
+}
+#endif
+
+inline TQString &TQString::prepend( const TQString & s )
+{ return insert(0,s); }
+
+inline TQString &TQString::prepend( TQChar c )
+{ return insert(0,c); }
+
+inline TQString &TQString::prepend( char c )
+{ return insert(0,c); }
+
+#ifndef TQT_NO_CAST_ASCII
+inline TQString &TQString::prepend( const TQByteArray & s )
+{ return insert(0,s); }
+#endif
+
+#ifndef TQT_NO_CAST_ASCII
+inline TQString &TQString::operator+=( const TQByteArray &s )
+{
+ int pos = s.tqfind( 0 );
+ return operatorPlusEqHelper( s, pos==-1 ? s.size() : pos );
+}
+#endif
+
+inline TQString &TQString::append( const TQString & s )
+{ return operator+=(s); }
+
+#ifndef TQT_NO_CAST_ASCII
+inline TQString &TQString::append( const TQByteArray &s )
+{ return operator+=(s); }
+
+inline TQString &TQString::append( const char * s )
+{ return operator+=(s); }
+#endif
+
+inline TQString &TQString::append( TQChar c )
+{ return operator+=(c); }
+
+inline TQString &TQString::append( char c )
+{ return operator+=(c); }
+
+#ifndef TQT_NO_STL
+inline TQString &TQString::operator=( const std::string& str )
+{ return operator=(str.c_str()); }
+#ifndef TQT_NO_CAST_ASCII
+inline TQString &TQString::operator+=( const std::string& s )
+{ return operator+=(s.c_str()); }
+inline TQString &TQString::append( const std::string& s )
+{ return operator+=(s); }
+inline TQString &TQString::prepend( const std::string& s )
+{ return insert(0, s); }
+#endif
+#endif
+
+inline TQString &TQString::setNum( short n, int base )
+{ return setNum((TQ_LLONG)n, base); }
+
+inline TQString &TQString::setNum( ushort n, int base )
+{ return setNum((TQ_ULLONG)n, base); }
+
+inline TQString &TQString::setNum( int n, int base )
+{ return setNum((TQ_LLONG)n, base); }
+
+inline TQString &TQString::setNum( uint n, int base )
+{ return setNum((TQ_ULLONG)n, base); }
+
+inline TQString &TQString::setNum( float n, char f, int prec )
+{ return setNum((double)n,f,prec); }
+
+inline TQString TQString::arg( int a, int fieldWidth, int base ) const
+{ return arg( (TQ_LLONG)a, fieldWidth, base ); }
+
+inline TQString TQString::arg( uint a, int fieldWidth, int base ) const
+{ return arg( (TQ_ULLONG)a, fieldWidth, base ); }
+
+inline TQString TQString::arg( short a, int fieldWidth, int base ) const
+{ return arg( (TQ_LLONG)a, fieldWidth, base ); }
+
+inline TQString TQString::arg( ushort a, int fieldWidth, int base ) const
+{ return arg( (TQ_ULLONG)a, fieldWidth, base ); }
+
+inline TQString TQString::arg( const TQString& a1, const TQString& a2 ) const {
+ return multiArg( 2, a1, a2 );
+}
+
+inline TQString TQString::arg( const TQString& a1, const TQString& a2,
+ const TQString& a3 ) const {
+ return multiArg( 3, a1, a2, a3 );
+}
+
+inline TQString TQString::arg( const TQString& a1, const TQString& a2,
+ const TQString& a3, const TQString& a4 ) const {
+ return multiArg( 4, a1, a2, a3, a4 );
+}
+
+inline int TQString::tqfind( char c, int index, bool cs ) const
+{ return tqfind(TQChar(c), index, cs); }
+
+inline int TQString::tqfindRev( char c, int index, bool cs ) const
+{ return tqfindRev( TQChar(c), index, cs ); }
+
+#ifndef TQT_NO_CAST_ASCII
+inline int TQString::tqfind( const char* str, int index ) const
+{ return tqfind(TQString::fromAscii(str), index); }
+
+inline int TQString::tqfindRev( const char* str, int index ) const
+{ return tqfindRev(TQString::fromAscii(str), index); }
+#endif
+
+
+/*****************************************************************************
+ TQString non-member operators
+ *****************************************************************************/
+
+TQ_EXPORT bool operator!=( const TQString &s1, const TQString &s2 );
+TQ_EXPORT bool operator<( const TQString &s1, const TQString &s2 );
+TQ_EXPORT bool operator<=( const TQString &s1, const TQString &s2 );
+TQ_EXPORT bool operator==( const TQString &s1, const TQString &s2 );
+TQ_EXPORT bool operator>( const TQString &s1, const TQString &s2 );
+TQ_EXPORT bool operator>=( const TQString &s1, const TQString &s2 );
+#ifndef TQT_NO_CAST_ASCII
+TQ_EXPORT bool operator!=( const TQString &s1, const char *s2 );
+TQ_EXPORT bool operator<( const TQString &s1, const char *s2 );
+TQ_EXPORT bool operator<=( const TQString &s1, const char *s2 );
+TQ_EXPORT bool operator==( const TQString &s1, const char *s2 );
+TQ_EXPORT bool operator>( const TQString &s1, const char *s2 );
+TQ_EXPORT bool operator>=( const TQString &s1, const char *s2 );
+TQ_EXPORT bool operator!=( const char *s1, const TQString &s2 );
+TQ_EXPORT bool operator<( const char *s1, const TQString &s2 );
+TQ_EXPORT bool operator<=( const char *s1, const TQString &s2 );
+TQ_EXPORT bool operator==( const char *s1, const TQString &s2 );
+//TQ_EXPORT bool operator>( const char *s1, const TQString &s2 ); // MSVC++
+TQ_EXPORT bool operator>=( const char *s1, const TQString &s2 );
+#endif
+
+// Interoperability
+TQ_EXPORT bool operator==( const QString &s1, const TQString &s2 );
+
+TQ_EXPORT inline const TQString operator+( const TQString &s1, const TQString &s2 )
+{
+ TQString tmp( s1 );
+ tmp += s2;
+ return tmp;
+}
+
+#ifndef TQT_NO_CAST_ASCII
+TQ_EXPORT inline const TQString operator+( const TQString &s1, const char *s2 )
+{
+ TQString tmp( s1 );
+ tmp += TQString::fromAscii(s2);
+ return tmp;
+}
+
+TQ_EXPORT inline const TQString operator+( const char *s1, const TQString &s2 )
+{
+ TQString tmp = TQString::fromAscii( s1 );
+ tmp += s2;
+ return tmp;
+}
+#endif
+
+TQ_EXPORT inline const TQString operator+( const TQString &s1, TQChar c2 )
+{
+ TQString tmp( s1 );
+ tmp += c2;
+ return tmp;
+}
+
+TQ_EXPORT inline const TQString operator+( const TQString &s1, char c2 )
+{
+ TQString tmp( s1 );
+ tmp += c2;
+ return tmp;
+}
+
+TQ_EXPORT inline const TQString operator+( TQChar c1, const TQString &s2 )
+{
+ TQString tmp;
+ tmp += c1;
+ tmp += s2;
+ return tmp;
+}
+
+TQ_EXPORT inline const TQString operator+( char c1, const TQString &s2 )
+{
+ TQString tmp;
+ tmp += c1;
+ tmp += s2;
+ return tmp;
+}
+
+#ifndef TQT_NO_STL
+TQ_EXPORT inline const TQString operator+(const TQString& s1, const std::string& s2)
+{
+ return s1 + TQString(s2);
+}
+
+TQ_EXPORT inline const TQString operator+(const std::string& s1, const TQString& s2)
+{
+ TQString tmp(s2);
+ return TQString(tmp.prepend(s1));
+}
+#endif
+
+
+#if defined(TQ_OS_WIN32)
+extern TQ_EXPORT TQString qt_winTQString(void*);
+extern TQ_EXPORT const void* qt_winTchar(const TQString& str, bool addnul);
+extern TQ_EXPORT void* qt_winTchar_new(const TQString& str);
+extern TQ_EXPORT TQCString qt_winTQString2MB( const TQString& s, int len=-1 );
+extern TQ_EXPORT TQString qt_winMB2TQString( const char* mb, int len=-1 );
+#endif
+
+#endif // USE_QT4
+
+#define TQ_DEFINED_TQSTRING
+#include "tqwinexport.h"
+#endif // TQSTRING_H