summaryrefslogtreecommitdiffstats
path: root/tqtinterface/qt4/src/tools/tqstring.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tqtinterface/qt4/src/tools/tqstring.cpp')
-rw-r--r--tqtinterface/qt4/src/tools/tqstring.cpp8493
1 files changed, 0 insertions, 8493 deletions
diff --git a/tqtinterface/qt4/src/tools/tqstring.cpp b/tqtinterface/qt4/src/tools/tqstring.cpp
deleted file mode 100644
index c57b539..0000000
--- a/tqtinterface/qt4/src/tools/tqstring.cpp
+++ /dev/null
@@ -1,8493 +0,0 @@
-/****************************************************************************
-**
-** Implementation of the TQString class and related Unicode functions
-**
-** Created : 920722
-**
-** 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 [email protected].
-**
-** 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.
-**
-**********************************************************************/
-
-// Don't define it while compiling this module, or USERS of TQt will
-// not be able to link.
-#ifdef TQT_NO_CAST_ASCII
-#undef TQT_NO_CAST_ASCII
-#endif
-
-#include "tqstring.h"
-#include "tqregexp.h"
-#include "tqdatastream.h"
-#ifndef TQT_NO_TEXTCODEC
-#include "tqtextcodec.h"
-#endif
-#include "tqlocale.h"
-#include "tqlocale_p.h"
-
-#include "tqunicodetables_p.h"
-#include <limits.h>
-#include <stdarg.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#ifndef TQ_OS_TEMP
-#include <locale.h>
-#endif
-#if defined(TQ_WS_WIN)
-#include "tqt_windows.h"
-#endif
-#if !defined( TQT_NO_COMPONENT ) && !defined( TQT_LITE_COMPONENT )
-#include "tqcleanuphandler.h"
-#endif
-
-#ifndef LLONG_MAX
-#define LLONG_MAX TQ_INT64_C(9223372036854775807)
-#endif
-#ifndef LLONG_MIN
-#define LLONG_MIN (-LLONG_MAX - TQ_INT64_C(1))
-#endif
-#ifndef ULLONG_MAX
-#define ULLONG_MAX TQ_UINT64_C(18446744073709551615)
-#endif
-
-#ifdef USE_QT4
-
-// #include <Qt/qhash.h>
-
-// static QHash<void *, QByteArray> *asciiCache = 0;
-
-TQT_STATIC_CONST_IMPL TQChar TQChar::null;
-TQT_STATIC_CONST_IMPL TQChar TQChar::replacement((ushort)0xfffd);
-TQT_STATIC_CONST_IMPL TQChar TQChar::byteOrderMark((ushort)0xfeff);
-TQT_STATIC_CONST_IMPL TQChar TQChar::byteOrderSwapped((ushort)0xfffe);
-TQT_STATIC_CONST_IMPL TQChar TQChar::nbsp((ushort)0x00a0);
-
-/*!
- \internal
-*/
-const char *TQString::ascii_helper() const
-{
- // tqstring_ascii_ba must be a persistent member variable within the class instance, but NOT static. A static variable is global for ALL class instances (very bad!)
- // Also, it MUST be declared mutable, otherwise a raft of "discards qualifiers" errors will pop up.
-
-// tqstring_ascii_ba = toAscii();
- // Get a real, TRUE copy of the data, not some stupid shared copy that will randomly invalidate my pointer at an unknown future date/time
- QByteArray tempba = toAscii();
- tqstring_ascii_ba.resize(tempba.size());
- memcpy(tqstring_ascii_ba.data(), tempba.data(), tempba.size());
- return tqstring_ascii_ba.data();
-}
-
-/*!
- \internal
-*/
-const char *TQString::latin1_helper() const
-{
- // tqstring_latin1_ba must be a persistent member variable within the class instance, but NOT static. A static variable is global for ALL class instances (very bad!)
- // Also, it MUST be declared mutable, otherwise a raft of "discards qualifiers" errors will pop up.
-
- //tqstring_latin1_ba = toLatin1();
- // Get a real, TRUE copy of the data, not some stupid shared copy that will randomly invalidate my pointer at an unknown future date/time
- QByteArray tempba = toLatin1();
- tqstring_latin1_ba.resize(tempba.size());
- memcpy(tqstring_latin1_ba.data(), tempba.data(), tempba.size());
- return tqstring_latin1_ba.data();
-}
-
-/*!
- This utility function converts \a l 16-bit characters from \a uc
- to ASCII, returning a '\0'-terminated string.
-
- The caller is responsible for deleting the resultant string with
- delete[].
-*/
-char* TQString::tqunicodeToLatin1(const TQChar *uc, uint l)
-{
- if (!uc) {
- return 0;
- }
- char *a = new char[l+1];
- char *result = a;
- while (l--) {
- *a++ = (uc->tqunicode() > 0xff) ? '?' : (char)uc->tqunicode();
- uc++;
- }
- *a = '\0';
- return result;
-}
-
-#if defined(Q_CC_MSVC) && _MSC_VER <= 1300
-const TQString::Null TQString::null;
-#else
-const TQString::Null TQString::null = { };
-#endif
-
-/*****************************************************************************
- TQString stream functions
- *****************************************************************************/
-#ifndef TQT_NO_DATASTREAM
-/*!
- \relates TQString
-
- Writes the string \a str to the stream \a s.
-
- See also \link datastreamformat.html Format of the TQDataStream operators \endlink
-*/
-
-TQDataStream &operator<<( TQDataStream &s, const TQString &str )
-{
- if ( s.version() == 1 ) {
- TQCString l( str.latin1() );
- s << l;
- }
- else {
- int byteOrder = s.byteOrder();
- const TQChar* ub = str.tqunicode();
- if ( ub || s.version() < 3 ) {
- static const uint auto_size = 1024;
- char t[auto_size];
- char *b;
- if ( str.length()*sizeof(TQChar) > auto_size ) {
- b = new char[str.length()*sizeof(TQChar)];
- } else {
- b = t;
- }
- int l = str.length();
- char *c=b;
- while ( l-- ) {
- if ( byteOrder == TQDataStream::BigEndian ) {
- *c++ = (char)ub->row();
- *c++ = (char)ub->cell();
- } else {
- *c++ = (char)ub->cell();
- *c++ = (char)ub->row();
- }
- ub++;
- }
- s.writeBytes( b, sizeof(TQChar)*str.length() );
- if ( str.length()*sizeof(TQChar) > auto_size )
- delete [] b;
- } else {
- // write null marker
- s << (TQ_UINT32)0xffffffff;
- }
- }
- return s;
-}
-
-/*!
- \relates TQString
-
- Reads a string from the stream \a s into string \a str.
-
- See also \link datastreamformat.html Format of the TQDataStream operators \endlink
-*/
-
-TQDataStream &operator>>( TQDataStream &s, TQString &str )
-{
-#ifdef TQT_TQSTRING_UCS_4
-#if defined(TQ_CC_GNU)
-#warning "operator>> not working properly"
-#endif
-#endif
- if ( s.version() == 1 ) {
- TQCString l;
- s >> l;
- str = TQString( l );
- }
- else {
- TQ_UINT32 bytes = 0;
- s >> bytes; // read size of string
- if ( bytes == 0xffffffff ) { // null string
- str = TQString::null;
- } else if ( bytes > 0 ) { // not empty
- int byteOrder = s.byteOrder();
- str.setLength( bytes/2 );
-// TQChar* ch = str.d->tqunicode;
- TQChar* ch = static_cast<TQChar*>(str.data());
- static const uint auto_size = 1024;
- char t[auto_size];
- char *b;
- if ( bytes > auto_size ) {
- b = new char[bytes];
- } else {
- b = t;
- }
- s.readRawBytes( b, bytes );
- int bt = bytes/2;
- char *oldb = b;
- while ( bt-- ) {
- if ( byteOrder == TQDataStream::BigEndian )
- *ch++ = (ushort) (((ushort)b[0])<<8) | (uchar)b[1];
- else
- *ch++ = (ushort) (((ushort)b[1])<<8) | (uchar)b[0];
- b += 2;
- }
- if ( bytes > auto_size )
- delete [] oldb;
- } else {
- str = "";
- }
- }
- return s;
-}
-#endif // TQT_NO_DATASTREAM
-
-#ifndef TQT_NO_CAST_ASCII
-TQString &TQString::operatorPlusEqHelper( const char *s, uint len2 )
-{
-// if ( s ) {
-// #ifndef TQT_NO_TEXTCODEC
-// if ( TQTextCodec::codecForCStrings() )
-// return operator+=( fromAscii( s, len2 ) );
-// #endif
-//
-// uint len1 = length();
-// if ( len2 == UINT_MAX )
-// len2 = int(strlen( s ));
-// if ( len2 ) {
-// grow( len1 + len2 );
-// TQChar* uc = d->tqunicode + len1;
-// while ( len2-- )
-// *uc++ = *s++;
-// } else if ( isNull() ) { // ## just for 1.x compat:
-// *this = tqfromLatin1( "" );
-// }
-// }
-// return *this;
-
- this->append(s);
- return *this;
-}
-#endif
-
-/*!
- \class TQCharRef tqstring.h
- \reentrant
- \brief The TQCharRef class is a helper class for TQString.
-
- \ingroup text
-
- When you get an object of type TQCharRef, if you can assign to it,
- the assignment will apply to the character in the string from
- which you got the reference. That is its whole purpose in life.
- The TQCharRef becomes invalid once modifications are made to the
- string: if you want to keep the character, copy it into a TQChar.
-
- Most of the TQChar member functions also exist in TQCharRef.
- However, they are not explicitly documented here.
-
- \sa TQString::operator[]() TQString::at() TQChar
-*/
-
-/*! \fn TQString& TQString::append( const char *str )
- \overload
-
- Appends \a str to the string and returns a reference to the result.
-
- Equivalent to operator+=().
-*/
-
-/*!
- Appends \a str to the string and returns a reference to the string.
-*/
-TQString& TQString::operator+=( const TQString &str )
-{
-// uint len1 = length();
-// uint len2 = str.length();
-// if ( len2 ) {
-// if ( isEmpty() ) {
-// operator=( str );
-// } else {
-// grow( len1+len2 );
-// memcpy( d->tqunicode+len1, str.tqunicode(), sizeof(TQChar)*len2 );
-// }
-// } else if ( isNull() && !str.isNull() ) { // ## just for 1.x compat:
-// *this = tqfromLatin1( "" );
-// }
-// return *this;
-
- this->append(str);
- return *this;
-}
-
-/*!
- \overload
-
- Appends \a str to the string and returns a reference to the string.
-*/
-#ifndef TQT_NO_CAST_ASCII
-TQString& TQString::operator+=( const char *str )
-{
- // ### TQt 4: make this function inline
- return operatorPlusEqHelper( str );
-}
-#endif
-
-/*! \overload
-
- Appends \a c to the string and returns a reference to the string.
-*/
-
-TQString &TQString::operator+=( TQChar c )
-{
-// grow( length()+1 );
-// d->tqunicode[length()-1] = c;
-// return *this;
-
- this->append(c);
- return *this;
-}
-
-/*!
- \overload
-
- Appends \a c to the string and returns a reference to the string.
-*/
-
-TQString &TQString::operator+=( char c )
-{
-// #ifndef TQT_NO_TEXTCODEC
-// if ( TQTextCodec::codecForCStrings() )
-// return operator+=( fromAscii( &c, 1 ) );
-// #endif
-// grow( length()+1 );
-// d->tqunicode[length()-1] = c;
-// return *this;
-
- this->append(c);
- return *this;
-}
-
-TQString &TQString::operator+=(const QStringRef &s) {
- //return convertFromQString();
- return (*static_cast<TQString*>(&append(s)));
-}
-
-TQString &TQString::operator+=(const QLatin1String &s) {
- return (*static_cast<TQString*>(&append(s)));
-}
-
-TQString &TQString::operator+=(QChar c) {
- return (*static_cast<TQString*>(&append(c)));
-}
-
-/*!
- \fn TQCharRef TQString::at( uint i )
-
- \overload
-
- The function returns a reference to the character at index \a i.
- The resulting reference can then be assigned to, or used
- immediately, but it will become invalid once further modifications
- are made to the original string.
-
- If \a i is beyond the length of the string then the string is
- expanded with TQChar::null.
-*/
-
-/*
- Internal chunk of code to handle the
- uncommon cases of at() above.
-*/
-void TQString::subat( uint i )
-{
- uint olen = length();
- if ( i >= olen ) {
- setLength( i+1 ); // i is index; i+1 is needed length
- for ( uint j=olen; j<=i; j++ )
- tqat(j) = TQChar::null;
- } else {
- // Just be sure to detach
-// real_detach();
- }
-}
-
-/*!
- \fn const TQChar* TQString::tqunicode() const
-
- Returns the Unicode representation of the string. The result
- remains valid until the string is modified.
-*/
-
-/*!
- Returns the string encoded in a locale-specific format. On X11,
- this is the TQTextCodec::codecForLocale(). On Windows, it is a
- system-defined encoding. On Mac OS X, this always uses UTF-8 as
- the encoding.
-
- See TQTextCodec for more diverse coding/decoding of Unicode
- strings.
-
- \sa fromLocal8Bit(), ascii(), latin1(), utf8()
-*/
-
-TQCString TQString::local8Bit() const
-{
-#ifdef TQT_NO_TEXTCODEC
- return latin1();
-#else
-#ifdef TQ_WS_X11
- TQTextCodec* codec = TQTextCodec::codecForLocale();
- return codec
- ? codec->fromUnicode(*this)
- : TQCString(latin1());
-#endif
-#if defined( TQ_WS_MACX )
- return utf8();
-#endif
-#if defined( TQ_WS_MAC9 )
- return TQCString(latin1()); //I'm evil..
-#endif
-#ifdef TQ_WS_WIN
- return isNull() ? TQCString("") : qt_winTQString2MB( *this );
-#endif
-#ifdef TQ_WS_TQWS
- return utf8(); // ### if there is any 8 bit format supported?
-#endif
-#endif
-}
-
-// TQCString TQString::local8Bit() const
-// {
-// return toLocal8Bit();
-// }
-
-/*!
- Returns the Unicode string decoded from the first \a len
- bytes of \a utf8, ignoring the rest of \a utf8. If \a len is
- -1 then the length of \a utf8 is used. If \a len is bigger than
- the length of \a utf8 then it will use the length of \a utf8.
-
- \code
- TQString str = TQString::fromUtf8( "123456789", 5 );
- // str == "12345"
- \endcode
-
- See TQTextCodec for more diverse coding/decoding of Unicode strings.
-*/
-TQString TQString::fromUtf8( const char* utf8, int len )
-{
- if ( !utf8 )
- return TQString();
- TQString result = QString::fromUtf8(utf8, len);
- int slen = int(strlen(utf8));
- if (result.length() > slen) {
- result.truncate(slen);
- }
- return result;
-}
-
-/*!
- Returns the Unicode string decoded from the first \a len
- bytes of \a chars, ignoring the rest of \a chars. If \a len
- is -1 then the length of \a chars is used. If \a len is bigger
- than the length of \a chars then it will use the length of \a
- chars.
-
- \sa fromAscii()
-*/
-TQString TQString::fromLatin1( const char* chars, int len )
-{
- if ( !chars )
- return TQString();
- TQString result = QString::fromLatin1(chars, len);
- int slen = int(strlen(chars));
- if (result.length() > slen) {
- result.truncate(slen);
- }
- return result;
-}
-
-/*!
- Returns the string encoded in UTF-8 format.
-
- See TQTextCodec for more diverse coding/decoding of Unicode strings.
-
- \sa fromUtf8(), ascii(), latin1(), local8Bit()
-*/
-TQCString TQString::utf8() const
-{
- int l = length();
- int rlen = l*3+1;
- TQCString rstr(rlen);
- uchar* cursor = (uchar*)rstr.data();
- const TQChar *ch = static_cast<const TQChar*>(data());
- for (int i=0; i < l; i++) {
- uint u = ch->tqunicode();
- if ( u < 0x80 ) {
- *cursor++ = (uchar)u;
- } else {
- if ( u < 0x0800 ) {
- *cursor++ = 0xc0 | ((uchar) (u >> 6));
- } else {
- if (u >= 0xd800 && u < 0xdc00 && i < l-1) {
- unsigned short low = ch[1].tqunicode();
- if (low >= 0xdc00 && low < 0xe000) {
- ++ch;
- ++i;
- u = (u - 0xd800)*0x400 + (low - 0xdc00) + 0x10000;
- }
- }
- if (u > 0xffff) {
- // if people are working in utf8, but strings are encoded in eg. latin1, the resulting
- // name might be invalid utf8. This and the corresponding code in fromUtf8 takes care
- // we can handle this without loosing information. This can happen with latin filenames
- // and a utf8 locale under Unix.
- if (u > 0x10fe00 && u < 0x10ff00) {
- *cursor++ = (u - 0x10fe00);
- ++ch;
- continue;
- } else {
- *cursor++ = 0xf0 | ((uchar) (u >> 18));
- *cursor++ = 0x80 | ( ((uchar) (u >> 12)) & 0x3f);
- }
- } else {
- *cursor++ = 0xe0 | ((uchar) (u >> 12));
- }
- *cursor++ = 0x80 | ( ((uchar) (u >> 6)) & 0x3f);
- }
- *cursor++ = 0x80 | ((uchar) (u&0x3f));
- }
- ++ch;
- }
- rstr.truncate( cursor - (uchar*)rstr.data() );
- return rstr;
-}
-
-static bool tqIsUpper(char c)
-{
- return c >= 'A' && c <= 'Z';
-}
-
-static bool tqIsDigit(char c)
-{
- return c >= '0' && c <= '9';
-}
-
-static char tqToLower(char c)
-{
- if (c >= 'A' && c <= 'Z')
- return c - 'A' + 'a';
- else
- return c;
-}
-
-struct ArgEscapeData
-{
- uint min_escape; // lowest escape sequence number
- uint occurrences; // number of occurences of the lowest escape
- // sequence number
- uint locale_occurrences; // number of occurences of the lowest escape
- // sequence number which contain 'L'
- uint escape_len; // total length of escape sequences which will
- // be replaced
-};
-
-static ArgEscapeData findArgEscapes(const TQString &s)
-{
- const TQChar *uc_begin = s.tqunicode();
- const TQChar *uc_end = uc_begin + s.length();
-
- ArgEscapeData d;
-
- d.min_escape = 10;
- d.occurrences = 0;
- d.escape_len = 0;
- d.locale_occurrences = 0;
-
- const TQChar *c = uc_begin;
- while (c != uc_end) {
- while (c != uc_end && c->tqunicode() != '%')
- ++c;
-
- if (c == uc_end || ++c == uc_end)
- break;
-
- bool locale_arg = FALSE;
- if (c->tqunicode() == 'L') {
- locale_arg = TRUE;
- if (++c == uc_end)
- break;
- }
-
- if (c->tqunicode() < '0' || c->tqunicode() > '9')
- continue;
-
- uint escape = c->tqunicode() - '0';
- ++c;
-
- if (escape > d.min_escape)
- continue;
-
- if (escape < d.min_escape) {
- d.min_escape = escape;
- d.occurrences = 0;
- d.escape_len = 0;
- d.locale_occurrences = 0;
- }
-
-#if TQT_VERSION < 0x040000
- // ### remove preprocessor in TQt 4.0
- /* Since in TQt < 4.0 only the first instance is replaced,
- escape_len should hold the length of only the first escape
- sequence */
- if (d.occurrences == 0)
-#endif
- {
- ++d.occurrences;
- if (locale_arg) {
- ++d.locale_occurrences;
- d.escape_len += 3;
- }
- else
- d.escape_len += 2;
- }
- }
-
- return d;
-}
-
-static TQString replaceArgEscapes(const TQString &s, const ArgEscapeData &d, int field_width,
- const TQString &arg, const TQString &larg)
-{
- const TQChar *uc_begin = s.tqunicode();
- const TQChar *uc_end = uc_begin + s.length();
-
- uint abs_field_width = TQABS(field_width);
- uint result_len = s.length()
- - d.escape_len
- + (d.occurrences - d.locale_occurrences)
- *TQMAX(abs_field_width, arg.length())
- + d.locale_occurrences
- *TQMAX(abs_field_width, larg.length());
-
- TQString result;
- result.setLength(result_len);
- TQChar *result_buff = (TQChar*) result.tqunicode();
-
- TQChar *rc = result_buff;
- const TQChar *c = uc_begin;
- uint repl_cnt = 0;
- while (c != uc_end) {
- /* We don't have to check if we run off the end of the string with c,
- because as long as d.occurrences > 0 we KNOW there are valid escape
- sequences. */
-
- const TQChar *text_start = c;
-
- while (c->tqunicode() != '%')
- ++c;
-
- const TQChar *escape_start = c++;
-
- bool locale_arg = FALSE;
- if (c->tqunicode() == 'L') {
- locale_arg = TRUE;
- ++c;
- }
-
- if (c->tqunicode() != '0' + d.min_escape) {
- memcpy(rc, text_start, (c - text_start)*sizeof(TQChar));
- rc += c - text_start;
- }
- else {
- ++c;
-
- memcpy(rc, text_start, (escape_start - text_start)*sizeof(TQChar));
- rc += escape_start - text_start;
-
- uint pad_chars;
- if (locale_arg)
- pad_chars = TQMAX(abs_field_width, larg.length()) - larg.length();
- else
- pad_chars = TQMAX(abs_field_width, arg.length()) - arg.length();
-
- if (field_width > 0) { // left padded
- for (uint i = 0; i < pad_chars; ++i)
-// (rc++)->tqunicode() = ' ';
- *(rc++) = ' ';
- }
-
- if (locale_arg) {
- memcpy(rc, larg.tqunicode(), larg.length()*sizeof(TQChar));
- rc += larg.length();
- }
- else {
- memcpy(rc, arg.tqunicode(), arg.length()*sizeof(TQChar));
- rc += arg.length();
- }
-
- if (field_width < 0) { // right padded
- for (uint i = 0; i < pad_chars; ++i)
-// (rc++)->tqunicode() = ' ';
- *(rc++) = ' ';
- }
-
- if (++repl_cnt == d.occurrences) {
- memcpy(rc, c, (uc_end - c)*sizeof(TQChar));
- rc += uc_end - c;
- TQ_ASSERT(rc - result_buff == (int)result_len);
- c = uc_end;
- }
- }
- }
-
- return result;
-}
-
-/*!
- This function will return a string that replaces the lowest
- numbered occurrence of \c %1, \c %2, ..., \c %9 with \a a.
-
- The \a fieldWidth value specifies the minimum amount of space that
- \a a is padded to. A positive value will produce right-aligned
- text, whereas a negative value will produce left-aligned text.
-
- The following example shows how we could create a 'status' string
- when processing a list of files:
- \code
- TQString status = TQString( "Processing file %1 of %2: %3" )
- .tqarg( i ) // current file's number
- .tqarg( total ) // number of files to process
- .tqarg( fileName ); // current file's name
- \endcode
-
- It is generally fine to use filenames and numbers as we have done
- in the example above. But note that using tqarg() to construct
- natural language sentences does not usually translate well into
- other languages because sentence structure and word order often
- differ between languages.
-
- If there is no place marker (\c %1, \c %2, etc.), a warning
- message (qWarning()) is output and the result is undefined.
-
- \warning If any placeholder occurs more than once, the result is undefined.
-
-*/
-TQString TQString::tqarg( const TQString& a, int fieldWidth ) const
-{
- ArgEscapeData d = findArgEscapes(*this);
-
- if (d.occurrences == 0) {
- qWarning( "TQString::tqarg(): Argument missing: %s, %s", latin1(),
- a.latin1() );
- return *this;
- }
-
- return replaceArgEscapes(*this, d, fieldWidth, a, a);
-}
-
-/*!
- \fn TQString TQString::tqarg( const TQString& a1, const TQString& a2 ) const
-
- \overload
-
- This is the same as str.tqarg(\a a1).tqarg(\a a2), except that
- the strings are replaced in one pass. This can make a difference
- if \a a1 contains e.g. \c{%1}:
-
- \code
- TQString str( "%1 %2" );
- str.tqarg( "Hello", "world" ); // returns "Hello world"
- str.tqarg( "Hello" ).tqarg( "world" ); // returns "Hello world"
-
- str.tqarg( "(%1)", "Hello" ); // returns "(%1) Hello"
- str.tqarg( "(%1)" ).tqarg( "Hello" ); // returns "(Hello) %2"
- \endcode
-*/
-
-/*!
- \fn TQString TQString::tqarg( const TQString& a1, const TQString& a2,
- const TQString& a3 ) const
- \overload
-
- This is the same as calling str.tqarg(\a a1).tqarg(\a a2).tqarg(\a a3),
- except that the strings are replaced in one pass.
-*/
-
-/*!
- \fn TQString TQString::tqarg( const TQString& a1, const TQString& a2,
- const TQString& a3, const TQString& a4 ) const
- \overload
-
- This is the same as calling
- str.tqarg(\a a1).tqarg(\a a2).tqarg(\a a3).tqarg(\a a4),
- except that the strings are replaced in one pass.
-*/
-
-/*!
- \overload
-
- The \a fieldWidth value specifies the minimum amount of space that
- \a a is padded to. A positive value will produce a right-aligned
- number, whereas a negative value will produce a left-aligned
- number.
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36.
-
- The '%' can be followed by an 'L', in which case the sequence is
- replaced with a localized representation of \a a. The conversion
- uses the default locale. The default locale is determined from the
- system's locale settings at application startup. It can be changed
- using TQLocale::setDefault(). The 'L' flag is ignored if \a base is
- not 10.
-
- \code
- TQString str;
- str = TQString( "Decimal 63 is %1 in hexadecimal" )
- .tqarg( 63, 0, 16 );
- // str == "Decimal 63 is 3f in hexadecimal"
-
- TQLocale::setDefault(TQLocale::English, TQLocale::UnitedStates);
- str = TQString( "%1 %L2 %L3" )
- .tqarg( 12345 )
- .tqarg( 12345 )
- .tqarg( 12345, 0, 16 );
- // str == "12345 12,345 3039"
- \endcode
-*/
-TQString TQString::tqarg( long a, int fieldWidth, int base ) const
-{
- return tqarg((TQ_LLONG)a, fieldWidth, base);
-}
-
-/*!
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-TQString TQString::tqarg( ulong a, int fieldWidth, int base ) const
-{
- return tqarg((TQ_ULLONG)a, fieldWidth, base);
-}
-
-/*!
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-TQString TQString::tqarg( TQ_LLONG a, int fieldWidth, int base ) const
-{
- ArgEscapeData d = findArgEscapes(*this);
-
- if (d.occurrences == 0) {
- qWarning( "TQString::tqarg(): Argument missing: %s, %lld", latin1(),
- a );
- return *this;
- }
-
- TQString arg;
- if (d.occurrences > d.locale_occurrences)
- arg = number(a, base);
-
- TQString locale_arg;
- if (d.locale_occurrences > 0) {
- TQLocale locale;
- locale_arg = locale.d->longLongToString(a, -1, base, -1, TQLocalePrivate::ThousandsGroup);
- }
-
- return replaceArgEscapes(*this, d, fieldWidth, arg, locale_arg);
-}
-
-/*!
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-TQString TQString::tqarg( TQ_ULLONG a, int fieldWidth, int base ) const
-{
- ArgEscapeData d = findArgEscapes(*this);
-
- if (d.occurrences == 0) {
- qWarning( "TQString::tqarg(): Argument missing: %s, %llu", latin1(),
- a );
- return *this;
- }
-
- TQString arg;
- if (d.occurrences > d.locale_occurrences)
- arg = number(a, base);
-
- TQString locale_arg;
- if (d.locale_occurrences > 0) {
- TQLocale locale;
- locale_arg = locale.d->unsLongLongToString(a, -1, base, -1, TQLocalePrivate::ThousandsGroup);
- }
-
- return replaceArgEscapes(*this, d, fieldWidth, arg, locale_arg);
-}
-
-/*!
- \fn TQString TQString::tqarg( int a, int fieldWidth, int base ) const
-
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-
-/*!
- \fn TQString TQString::tqarg( uint a, int fieldWidth, int base ) const
-
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-
-/*!
- \fn TQString TQString::tqarg( short a, int fieldWidth, int base ) const
-
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-
-/*!
- \fn TQString TQString::tqarg( ushort a, int fieldWidth, int base ) const
-
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-
-
-/*!
- \overload
-
- \a a is assumed to be in the Latin-1 character set.
-*/
-TQString TQString::tqarg( char a, int fieldWidth ) const
-{
- TQString c;
- c += a;
- return tqarg( c, fieldWidth );
-}
-
-/*!
- \overload
-*/
-TQString TQString::tqarg( TQChar a, int fieldWidth ) const
-{
- TQString c;
- c += a;
- return tqarg( c, fieldWidth );
-}
-
-/*!
- \overload
-
- \target arg-formats
-
- Argument \a a is formatted according to the \a fmt format specified,
- which is 'g' by default and can be any of the following:
-
- \table
- \header \i Format \i Meaning
- \row \i \c e \i format as [-]9.9e[+|-]999
- \row \i \c E \i format as [-]9.9E[+|-]999
- \row \i \c f \i format as [-]9.9
- \row \i \c g \i use \c e or \c f format, whichever is the most concise
- \row \i \c G \i use \c E or \c f format, whichever is the most concise
- \endtable
-
- With 'e', 'E', and 'f', \a prec is the number of digits after the
- decimal point. With 'g' and 'G', \a prec is the maximum number of
- significant digits (trailing zeroes are omitted).
-
- \code
- double d = 12.34;
- TQString ds = TQString( "'E' format, precision 3, gives %1" )
- .tqarg( d, 0, 'E', 3 );
- // ds == "'E' format, precision 3, gives 1.234E+01"
- \endcode
-
- The '%L' syntax can be used to produce localized strings.
-*/
-TQString TQString::tqarg( double a, int fieldWidth, char fmt, int prec ) const
-{
- ArgEscapeData d = findArgEscapes(*this);
-
- if (d.occurrences == 0) {
- qWarning( "TQString::tqarg(): Argument missing: %s, %g", latin1(),
- a );
- return *this;
- }
-
- TQString arg;
- if (d.occurrences > d.locale_occurrences)
- arg = number(a, fmt, prec);
-
- TQString locale_arg;
- if (d.locale_occurrences > 0) {
- TQLocale locale;
-
- TQLocalePrivate::DoubleForm form = TQLocalePrivate::DFDecimal;
- uint flags = 0;
-
- if (tqIsUpper(fmt))
- flags = TQLocalePrivate::CapitalEorX;
- fmt = tqToLower(fmt);
-
- switch (fmt) {
- case 'f':
- form = TQLocalePrivate::DFDecimal;
- break;
- case 'e':
- form = TQLocalePrivate::DFExponent;
- break;
- case 'g':
- form = TQLocalePrivate::DFSignificantDigits;
- break;
- default:
-#if defined(TQT_CHECK_RANGE)
- qWarning( "TQString::setNum: Invalid format char '%c'", fmt );
-#endif
- break;
- }
-
- flags |= TQLocalePrivate::ThousandsGroup;
-
- locale_arg = locale.d->doubleToString(a, prec, form, -1, flags);
- }
-
- return replaceArgEscapes(*this, d, fieldWidth, arg, locale_arg);
-}
-
-TQString TQString::tqmultiArg( int numArgs, const TQString& a1, const TQString& a2, const TQString& a3, const TQString& a4 ) const
-{
- TQString result;
- union {
- int digitUsed[10];
- int argForDigit[10];
- };
- register const TQChar *uc = this->tqunicode();
- const TQString *args[4];
- const int len = (int) length();
- const int end = len - 1;
- int lastDigit = -1;
- int i;
-
- memset( digitUsed, 0, sizeof(digitUsed) );
- args[0] = &a1;
- args[1] = &a2;
- args[2] = &a3;
- args[3] = &a4;
-
- for ( i = 0; i < end; i++ ) {
- if ( uc[i] == '%' ) {
- int digit = uc[i + 1].tqunicode() - '0';
- if ( digit >= 0 && digit <= 9 )
- digitUsed[digit]++;
- }
- }
-
- for ( i = 0; i < numArgs; i++ ) {
- do {
- ++lastDigit;
- } while ( lastDigit < 10 && digitUsed[lastDigit] == 0 );
-
- if ( lastDigit == 10 ) {
- qWarning( "TQString::arg(): Argument missing: %s, %s",
- latin1(), args[i]->latin1() );
- numArgs = i;
- lastDigit = 9;
- break;
- }
- argForDigit[lastDigit] = i;
- }
-
- i = 0;
- while ( i < len ) {
- if ( uc[i] == '%' && i != end ) {
- int digit = uc[i + 1].tqunicode() - '0';
- if ( digit >= 0 && digit <= lastDigit ) {
- result += *args[argForDigit[digit]];
- i += 2;
- continue;
- }
- }
- result += uc[i++];
- }
- return result;
-}
-
-TQString &TQString::setAscii( const char *str, int len )
-{
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() ) {
- *this = TQString::fromAscii( str, len );
- return *this;
- }
-#endif // TQT_NO_TEXTCODEC
- return setLatin1( str, len );
-}
-
-TQString &TQString::setLatin1( const char *ch, int len ) {
- *this = fromLatin1(ch, len); return *this;
-}
-
-bool TQString::simpleText() const {
- if ( !tqstring_issimpletext ) checkSimpleText();
- return tqstring_issimpletext;
-}
-
-/*! \internal
- */
-void TQString::checkSimpleText() const
-{
- TQChar *p = const_cast<TQChar*>(tqunicode());
- TQChar *end = p + length();
- while ( p < end ) {
- ushort uc = p->tqunicode();
- // sort out regions of complex text formatting
- if ( uc > 0x058f && ( uc < 0x1100 || uc > 0xfb0f ) ) {
- tqstring_issimpletext = FALSE;
- return;
- }
- p++;
- }
- tqstring_issimpletext = TRUE;
-}
-
-/*!
- Resizes the string to \a len characters and copies \a
- tqunicode_as_ushorts into the string (on some X11 client platforms
- this will involve a byte-swapping pass).
-
- If \a tqunicode_as_ushorts is 0, nothing is copied, but the string
- is still resized to \a len. If \a len is zero, the string becomes
- a \link isNull() null\endlink string.
-
- \sa setLatin1(), isNull()
-*/
-TQString TQString::setUnicodeCodes( const ushort* tqunicode_as_ushorts, uint len )
-{
- return TQString(setUnicode((const TQChar*)tqunicode_as_ushorts, len));
-}
-
-/*!
- Returns the string converted to a \c double value.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- \code
- TQString string( "1234.56" );
- double a = string.toDouble(); // a == 1234.56
- \endcode
-
- The string-to-number functions:
- \list
- \i toShort()
- \i toUShort()
- \i toInt()
- \i toUInt()
- \i toLong()
- \i toULong()
- \i toLongLong()
- \i toULongLong()
- \i toFloat()
- \i toDouble()
- \endlist
- can handle numbers
- represented in various locales. These representations may use different
- characters for the decimal point, thousands group sepearator
- and even individual digits. TQString's functions try to interpret
- the string according to the current locale. The current locale is
- determined from the system at application startup and can be changed
- by calling TQLocale::setDefault(). If the string cannot be interpreted
- according to the current locale, this function falls back
- on the "C" locale.
-
- \code
- bool ok;
- double d;
-
- TQLocale::setDefault(TQLocale::C);
- d = TQString( "1234,56" ).toDouble(&ok); // ok == false
- d = TQString( "1234.56" ).toDouble(&ok); // ok == true, d == 1234.56
-
- TQLocale::setDefault(TQLocale::German);
- d = TQString( "1234,56" ).toDouble(&ok); // ok == true, d == 1234.56
- d = TQString( "1234.56" ).toDouble(&ok); // ok == true, d == 1234.56
- \endcode
-
- Due to the ambiguity between the decimal point and thousands group
- separator in various locales, these functions do not handle
- thousands group separators. If you need to convert such numbers,
- use the corresponding function in TQLocale.
-
- \code
- bool ok;
- TQLocale::setDefault(TQLocale::C);
- double d = TQString( "1,234,567.89" ).toDouble(&ok); // ok == false
- \endcode
-
- \warning If the string contains trailing whitespace this function
- will fail, and set \a *ok to false if \a ok is not 0. Leading
- whitespace is ignored.
-
- \sa number() TQLocale::setDefault() TQLocale::toDouble() stripWhiteSpace()
-*/
-
-double TQString::toDouble( bool *ok ) const
-{
- // If there is trailing whitespace, set ok to false but return the correct
- // result anyway to preserve behavour of pervious versions of TQt
- if (length() > 0 && tqunicode()[length() - 1].isSpace()) {
- TQString tmp = stripWhiteSpace();
- if (ok != 0)
- *ok = FALSE;
- return tmp.toDouble();
- }
-
- // Try the default locale
- bool my_ok;
- TQLocale def_locale;
- double result = def_locale.d->stringToDouble(*this, &my_ok, TQLocalePrivate::FailOnGroupSeparators);
- if (my_ok) {
- if (ok != 0)
- *ok = TRUE;
- return result;
- }
-
- // If the default was not "C", try the "C" locale
- if (def_locale.language() == TQLocale::C) {
- if (ok != 0)
- *ok = FALSE;
- return 0.0;
- }
-
- TQLocale c_locale(TQLocale::C);
- return c_locale.d->stringToDouble(*this, ok, TQLocalePrivate::FailOnGroupSeparators);
-}
-
-/*!
- Returns the string converted to a \c float value.
-
- Returns 0.0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \warning If the string contains trailing whitespace this function
- will fail, settings \a *ok to false if \a ok is not 0.
- Leading whitespace is ignored.
-
- \sa number()
-*/
-
-#define TQT_MAX_FLOAT 3.4028234663852886e+38
-
-float TQString::toFloat( bool *ok ) const
-{
- bool myOk;
- double d = toDouble(&myOk);
- if (!myOk || d > TQT_MAX_FLOAT || d < -TQT_MAX_FLOAT) {
- if (ok != 0)
- *ok = FALSE;
- return 0.0;
- }
- if (ok != 0)
- *ok = TRUE;
- return (float) d;
-}
-
-/*!
- Sets the string to the printed value of \a n in base \a base and
- returns a reference to the string. The returned string is in "C" locale.
-
- The base is 10 by default and must be between 2 and 36.
-
- \code
- TQString string;
- string = string.setNum( 1234 ); // string == "1234"
- \endcode
-*/
-
-#else // USE_QT4
-
-static int ucstrcmp( const TQString &as, const TQString &bs )
-{
- const TQChar *a = as.tqunicode();
- const TQChar *b = bs.tqunicode();
- if ( a == b )
- return 0;
- if ( a == 0 )
- return 1;
- if ( b == 0 )
- return -1;
- int l=TQMIN(as.length(),bs.length());
- while ( l-- && *a == *b )
- a++,b++;
- if ( l==-1 )
- return ( as.length()-bs.length() );
- return a->tqunicode() - b->tqunicode();
-}
-
-static int ucstrncmp( const TQChar *a, const TQChar *b, int l )
-{
- while ( l-- && *a == *b )
- a++,b++;
- if ( l==-1 )
- return 0;
- return a->tqunicode() - b->tqunicode();
-}
-
-static int ucstrnicmp( const TQChar *a, const TQChar *b, int l )
-{
- while ( l-- && ::lower( *a ) == ::lower( *b ) )
- a++,b++;
- if ( l==-1 )
- return 0;
- return ::lower( *a ).tqunicode() - ::lower( *b ).tqunicode();
-}
-
-static uint computeNewMax( uint len )
-{
- if (len >= 0x80000000)
- return len;
-
- uint newMax = 4;
- while ( newMax < len )
- newMax *= 2;
- // try to save some memory
- if ( newMax >= 1024 * 1024 && len <= newMax - (newMax >> 2) )
- newMax -= newMax >> 2;
- return newMax;
-}
-
-static bool qIsUpper(char c)
-{
- return c >= 'A' && c <= 'Z';
-}
-
-static bool qIsDigit(char c)
-{
- return c >= '0' && c <= '9';
-}
-
-static char qToLower(char c)
-{
- if (c >= 'A' && c <= 'Z')
- return c - 'A' + 'a';
- else
- return c;
-}
-
-/*!
- \class TQCharRef tqstring.h
- \reentrant
- \brief The TQCharRef class is a helper class for TQString.
-
- \ingroup text
-
- When you get an object of type TQCharRef, if you can assign to it,
- the assignment will apply to the character in the string from
- which you got the reference. That is its whole purpose in life.
- The TQCharRef becomes invalid once modifications are made to the
- string: if you want to keep the character, copy it into a TQChar.
-
- Most of the TQChar member functions also exist in TQCharRef.
- However, they are not explicitly documented here.
-
- \sa TQString::operator[]() TQString::at() TQChar
-*/
-
-/*!
- \class TQChar tqstring.h
- \reentrant
- \brief The TQChar class provides a lightweight Unicode character.
-
- \ingroup text
-
- Unicode characters are (so far) 16-bit entities without any markup
- or structure. This class represents such an entity. It is
- lightweight, so it can be used everywhere. Most compilers treat it
- like a "short int". (In a few years it may be necessary to make
- TQChar 32-bit when more than 65536 Unicode code points have been
- defined and come into use.)
-
- TQChar provides a full complement of testing/classification
- functions, converting to and from other formats, converting from
- composed to decomposed Unicode, and trying to compare and
- case-convert if you ask it to.
-
- The classification functions include functions like those in
- ctype.h, but operating on the full range of Unicode characters.
- They all return TRUE if the character is a certain type of
- character; otherwise they return FALSE. These classification
- functions are isNull() (returns TRUE if the character is U+0000),
- isPrint() (TRUE if the character is any sort of printable
- character, including whitespace), isPunct() (any sort of
- punctation), isMark() (Unicode Mark), isLetter (a letter),
- isNumber() (any sort of numeric character), isLetterOrNumber(),
- and isDigit() (decimal digits). All of these are wrappers around
- category() which return the Unicode-defined category of each
- character.
-
- TQChar further provides direction(), which indicates the "natural"
- writing direction of this character. The joining() function
- indicates how the character joins with its neighbors (needed
- mostly for Arabic) and finally mirrored(), which indicates whether
- the character needs to be mirrored when it is printed in its
- "unnatural" writing direction.
-
- Composed Unicode characters (like &aring;) can be converted to
- decomposed Unicode ("a" followed by "ring above") by using
- decomposition().
-
- In Unicode, comparison is not necessarily possible and case
- conversion is very difficult at best. Unicode, covering the
- "entire" world, also includes most of the world's case and sorting
- problems. TQt tries, but not very hard: operator==() and friends
- will do comparison based purely on the numeric Unicode value (code
- point) of the characters, and upper() and lower() will do case
- changes when the character has a well-defined upper/lower-case
- equivalent. There is no provision for locale-dependent case
- folding rules or comparison; these functions are meant to be fast
- so they can be used unambiguously in data structures. (See
- TQString::localeAwareCompare() though.)
-
- The conversion functions include tqunicode() (to a scalar), latin1()
- (to scalar, but converts all non-Latin-1 characters to 0), row()
- (gives the Unicode row), cell() (gives the Unicode cell),
- digitValue() (gives the integer value of any of the numerous digit
- characters), and a host of constructors.
-
- More information can be found in the document \link tqunicode.html
- About Unicode. \endlink
-
- \sa TQString TQCharRef
-*/
-
-/*!
- \enum TQChar::Category
-
- This enum maps the Unicode character categories.
-
- The following characters are normative in Unicode:
-
- \value Mark_NonSpacing Unicode class name Mn
-
- \value Mark_SpacingCombining Unicode class name Mc
-
- \value Mark_Enclosing Unicode class name Me
-
- \value Number_DecimalDigit Unicode class name Nd
-
- \value Number_Letter Unicode class name Nl
-
- \value Number_Other Unicode class name No
-
- \value Separator_Space Unicode class name Zs
-
- \value Separator_Line Unicode class name Zl
-
- \value Separator_Paragraph Unicode class name Zp
-
- \value Other_Control Unicode class name Cc
-
- \value Other_Format Unicode class name Cf
-
- \value Other_Surrogate Unicode class name Cs
-
- \value Other_PrivateUse Unicode class name Co
-
- \value Other_NotAssigned Unicode class name Cn
-
-
- The following categories are informative in Unicode:
-
- \value Letter_Uppercase Unicode class name Lu
-
- \value Letter_Lowercase Unicode class name Ll
-
- \value Letter_Titlecase Unicode class name Lt
-
- \value Letter_Modifier Unicode class name Lm
-
- \value Letter_Other Unicode class name Lo
-
- \value Punctuation_Connector Unicode class name Pc
-
- \value Punctuation_Dash Unicode class name Pd
-
- \value Punctuation_Open Unicode class name Ps
-
- \value Punctuation_Close Unicode class name Pe
-
- \value Punctuation_InitialQuote Unicode class name Pi
-
- \value Punctuation_FinalQuote Unicode class name Pf
-
- \value Punctuation_Other Unicode class name Po
-
- \value Symbol_Math Unicode class name Sm
-
- \value Symbol_Currency Unicode class name Sc
-
- \value Symbol_Modifier Unicode class name Sk
-
- \value Symbol_Other Unicode class name So
-
-
- There are two categories that are specific to TQt:
-
- \value NoCategory used when TQt is dazed and confused and cannot
- make sense of anything.
-
- \value Punctuation_Dask old typo alias for Punctuation_Dash
-
-*/
-
-/*!
- \enum TQChar::Direction
-
- This enum type defines the Unicode direction attributes. See \link
- http://www.tqunicode.org/ the Unicode Standard\endlink for a
- description of the values.
-
- In order to conform to C/C++ naming conventions "Dir" is prepended
- to the codes used in the Unicode Standard.
-*/
-
-/*!
- \enum TQChar::Decomposition
-
- This enum type defines the Unicode decomposition attributes. See
- \link http://www.tqunicode.org/ the Unicode Standard\endlink for a
- description of the values.
-*/
-
-/*!
- \enum TQChar::Joining
-
- This enum type defines the Unicode joining attributes. See \link
- http://www.tqunicode.org/ the Unicode Standard\endlink for a
- description of the values.
-*/
-
-/*!
- \enum TQChar::CombiningClass
-
- This enum type defines names for some of the Unicode combining
- classes. See \link http://www.tqunicode.org/ the Unicode
- Standard\endlink for a description of the values.
-*/
-
-/*!
- \fn void TQChar::setCell( uchar cell )
- \internal
-*/
-
-/*!
- \fn void TQChar::setRow( uchar row )
- \internal
-*/
-
-
-/*!
- \fn TQChar::TQChar()
-
- Constructs a null TQChar (one that isNull()).
-*/
-
-
-/*!
- \fn TQChar::TQChar( char c )
-
- Constructs a TQChar corresponding to ASCII/Latin-1 character \a c.
-*/
-
-
-/*!
- \fn TQChar::TQChar( uchar c )
-
- Constructs a TQChar corresponding to ASCII/Latin-1 character \a c.
-*/
-
-
-/*!
- \fn TQChar::TQChar( uchar c, uchar r )
-
- Constructs a TQChar for Unicode cell \a c in row \a r.
-*/
-
-
-/*!
- \fn TQChar::TQChar( const TQChar& c )
-
- Constructs a copy of \a c. This is a deep copy, if such a
- lightweight object can be said to have deep copies.
-*/
-
-
-/*!
- \fn TQChar::TQChar( ushort rc )
-
- Constructs a TQChar for the character with Unicode code point \a rc.
-*/
-
-
-/*!
- \fn TQChar::TQChar( short rc )
-
- Constructs a TQChar for the character with Unicode code point \a rc.
-*/
-
-
-/*!
- \fn TQChar::TQChar( uint rc )
-
- Constructs a TQChar for the character with Unicode code point \a rc.
-*/
-
-
-/*!
- \fn TQChar::TQChar( int rc )
-
- Constructs a TQChar for the character with Unicode code point \a rc.
-*/
-
-
-/*!
- \fn bool TQChar::networkOrdered ()
-
- \obsolete
-
- Returns TRUE if this character is in network byte order (MSB
- first); otherwise returns FALSE. This is platform dependent.
-*/
-
-
-/*!
- \fn bool TQChar::isNull() const
-
- Returns TRUE if the character is the Unicode character 0x0000
- (ASCII NUL); otherwise returns FALSE.
-*/
-
-/*!
- \fn uchar TQChar::cell () const
-
- Returns the cell (least significant byte) of the Unicode
- character.
-*/
-
-/*!
- \fn uchar TQChar::row () const
-
- Returns the row (most significant byte) of the Unicode character.
-*/
-
-/*!
- Returns TRUE if the character is a printable character; otherwise
- returns FALSE. This is any character not of category Cc or Cn.
-
- Note that this gives no indication of whether the character is
- available in a particular \link TQFont font\endlink.
-*/
-bool TQChar::isPrint() const
-{
- Category c = ::category( *this );
- return !(c == Other_Control || c == Other_NotAssigned);
-}
-
-/*!
- Returns TRUE if the character is a separator character
- (Separator_* categories); otherwise returns FALSE.
-*/
-bool TQChar::isSpace() const
-{
- return ::isSpace( *this );
-}
-
-/*!
- Returns TRUE if the character is a mark (Mark_* categories);
- otherwise returns FALSE.
-*/
-bool TQChar::isMark() const
-{
- Category c = ::category( *this );
- return c >= Mark_NonSpacing && c <= Mark_Enclosing;
-}
-
-/*!
- Returns TRUE if the character is a punctuation mark (Punctuation_*
- categories); otherwise returns FALSE.
-*/
-bool TQChar::isPunct() const
-{
- Category c = ::category( *this );
- return (c >= Punctuation_Connector && c <= Punctuation_Other);
-}
-
-/*!
- Returns TRUE if the character is a letter (Letter_* categories);
- otherwise returns FALSE.
-*/
-bool TQChar::isLetter() const
-{
- Category c = ::category( *this );
- return (c >= Letter_Uppercase && c <= Letter_Other);
-}
-
-/*!
- Returns TRUE if the character is a number (of any sort - Number_*
- categories); otherwise returns FALSE.
-
- \sa isDigit()
-*/
-bool TQChar::isNumber() const
-{
- Category c = ::category( *this );
- return c >= Number_DecimalDigit && c <= Number_Other;
-}
-
-/*!
- Returns TRUE if the character is a letter or number (Letter_* or
- Number_* categories); otherwise returns FALSE.
-*/
-bool TQChar::isLetterOrNumber() const
-{
- Category c = ::category( *this );
- return (c >= Letter_Uppercase && c <= Letter_Other)
- || (c >= Number_DecimalDigit && c <= Number_Other);
-}
-
-
-/*!
- Returns TRUE if the character is a decimal digit
- (Number_DecimalDigit); otherwise returns FALSE.
-*/
-bool TQChar::isDigit() const
-{
- return (::category( *this ) == Number_DecimalDigit);
-}
-
-
-/*!
- Returns TRUE if the character is a symbol (Symbol_* categories);
- otherwise returns FALSE.
-*/
-bool TQChar::isSymbol() const
-{
- Category c = ::category( *this );
- return c >= Symbol_Math && c <= Symbol_Other;
-}
-
-/*!
- Returns the numeric value of the digit, or -1 if the character is
- not a digit.
-*/
-int TQChar::digitValue() const
-{
-#ifndef TQT_NO_UNICODETABLES
- register int pos = TQUnicodeTables::decimal_info[row()];
- if( !pos )
- return -1;
- return TQUnicodeTables::decimal_info[(pos<<8) + cell()];
-#else
- // ##### just latin1
- if ( ucs < '0' || ucs > '9' )
- return -1;
- else
- return ucs - '0';
-#endif
-}
-
-/*!
- Returns the character category.
-
- \sa Category
-*/
-TQChar::Category TQChar::category() const
-{
- return ::category( *this );
-}
-
-/*!
- Returns the character's direction.
-
- \sa Direction
-*/
-TQChar::Direction TQChar::direction() const
-{
- return ::direction( *this );
-}
-
-/*!
- \warning This function is not supported (it may change to use
- Unicode character classes).
-
- Returns information about the joining properties of the character
- (needed for example, for Arabic).
-*/
-TQChar::Joining TQChar::joining() const
-{
- return ::joining( *this );
-}
-
-
-/*!
- Returns TRUE if the character is a mirrored character (one that
- should be reversed if the text direction is reversed); otherwise
- returns FALSE.
-*/
-bool TQChar::mirrored() const
-{
- return ::mirrored( *this );
-}
-
-/*!
- Returns the mirrored character if this character is a mirrored
- character, otherwise returns the character itself.
-*/
-TQChar TQChar::mirroredChar() const
-{
- return ::mirroredChar( *this );
-}
-
-#ifndef TQT_NO_UNICODETABLES
-// ### REMOVE ME 4.0
-static TQString shared_decomp;
-#endif
-/*!
- \nonreentrant
-
- Decomposes a character into its parts. Returns TQString::null if no
- decomposition exists.
-*/
-const TQString &TQChar::decomposition() const
-{
-#ifndef TQT_NO_UNICODETABLES
- register int pos = TQUnicodeTables::decomposition_info[row()];
- if(!pos) return TQString::null;
-
- pos = TQUnicodeTables::decomposition_info[(pos<<8)+cell()];
- if(!pos) return TQString::null;
- pos+=2;
-
- TQString s;
- TQ_UINT16 c;
- while ( (c = TQUnicodeTables::decomposition_map[pos++]) != 0 )
- s += TQChar( c );
- // ### In 4.0, return s, and not shared_decomp. shared_decomp
- // prevents this function from being reentrant.
- shared_decomp = s;
- return shared_decomp;
-#else
- return TQString::null;
-#endif
-}
-
-/*!
- Returns the tag defining the composition of the character. Returns
- TQChar::Single if no decomposition exists.
-*/
-TQChar::Decomposition TQChar::decompositionTag() const
-{
-#ifndef TQT_NO_UNICODETABLES
- register int pos = TQUnicodeTables::decomposition_info[row()];
- if(!pos) return TQChar::Single;
-
- pos = TQUnicodeTables::decomposition_info[(pos<<8)+cell()];
- if(!pos) return TQChar::Single;
-
- return (TQChar::Decomposition) TQUnicodeTables::decomposition_map[pos];
-#else
- return Single; // ########### FIX eg. just latin1
-#endif
-}
-
-/*!
- Returns the combining class for the character as defined in the
- Unicode standard. This is mainly useful as a positioning hint for
- marks attached to a base character.
-
- The TQt text rendering engine uses this information to correctly
- position non spacing marks around a base character.
-*/
-unsigned char TQChar::combiningClass() const
-{
- return ::combiningClass( *this );
-}
-
-
-/*!
- Returns the lowercase equivalent if the character is uppercase;
- otherwise returns the character itself.
-*/
-TQChar TQChar::lower() const
-{
- return ::lower( *this );
-}
-
-/*!
- Returns the uppercase equivalent if the character is lowercase;
- otherwise returns the character itself.
-*/
-TQChar TQChar::upper() const
-{
- return ::upper( *this );
-}
-
-/*!
- \fn TQChar::operator char() const
-
- Returns the Latin-1 character equivalent to the TQChar, or 0. This
- is mainly useful for non-internationalized software.
-
- \sa tqunicode()
-*/
-
-/*!
- \fn ushort TQChar::tqunicode() const
-
- Returns the numeric Unicode value equal to the TQChar. Normally,
- you should use TQChar objects as they are equivalent, but for some
- low-level tasks (e.g. indexing into an array of Unicode
- information), this function is useful.
-*/
-
-/*!
- \fn ushort & TQChar::tqunicode()
-
- \overload
-
- Returns a reference to the numeric Unicode value equal to the
- TQChar.
-*/
-
-/*****************************************************************************
- Documentation of TQChar related functions
- *****************************************************************************/
-
-/*!
- \fn bool operator==( TQChar c1, TQChar c2 )
-
- \relates TQChar
-
- Returns TRUE if \a c1 and \a c2 are the same Unicode character;
- otherwise returns FALSE.
-*/
-
-/*!
- \fn bool operator==( char ch, TQChar c )
-
- \overload
- \relates TQChar
-
- Returns TRUE if \a c is the ASCII/Latin-1 character \a ch;
- otherwise returns FALSE.
-*/
-
-/*!
- \fn bool operator==( TQChar c, char ch )
-
- \overload
- \relates TQChar
-
- Returns TRUE if \a c is the ASCII/Latin-1 character \a ch;
- otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator!=( TQChar c1, TQChar c2 )
-
- \relates TQChar
-
- Returns TRUE if \a c1 and \a c2 are not the same Unicode
- character; otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator!=( char ch, TQChar c )
-
- \overload
- \relates TQChar
-
- Returns TRUE if \a c is not the ASCII/Latin-1 character \a ch;
- otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator!=( TQChar c, char ch )
-
- \overload
- \relates TQChar
-
- Returns TRUE if \a c is not the ASCII/Latin-1 character \a ch;
- otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator<=( TQChar c1, TQChar c2 )
-
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of \a c1 is less than
- that of \a c2, or they are the same Unicode character; otherwise
- returns FALSE.
-*/
-
-/*!
- \fn int operator<=( TQChar c, char ch )
-
- \overload
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of \a c is less than or
- equal to that of the ASCII/Latin-1 character \a ch; otherwise
- returns FALSE.
-*/
-
-/*!
- \fn int operator<=( char ch, TQChar c )
-
- \overload
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of the ASCII/Latin-1
- character \a ch is less than or equal to that of \a c; otherwise
- returns FALSE.
-*/
-
-/*!
- \fn int operator>=( TQChar c1, TQChar c2 )
-
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of \a c1 is greater than
- that of \a c2, or they are the same Unicode character; otherwise
- returns FALSE.
-*/
-
-/*!
- \fn int operator>=( TQChar c, char ch )
-
- \overload
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of \a c is greater than
- or equal to that of the ASCII/Latin-1 character \a ch; otherwise
- returns FALSE.
-*/
-
-/*!
- \fn int operator>=( char ch, TQChar c )
-
- \overload
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of the ASCII/Latin-1
- character \a ch is greater than or equal to that of \a c;
- otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator<( TQChar c1, TQChar c2 )
-
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of \a c1 is less than
- that of \a c2; otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator<( TQChar c, char ch )
-
- \overload
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of \a c is less than that
- of the ASCII/Latin-1 character \a ch; otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator<( char ch, TQChar c )
-
- \overload
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of the ASCII/Latin-1
- character \a ch is less than that of \a c; otherwise returns
- FALSE.
-*/
-
-/*!
- \fn int operator>( TQChar c1, TQChar c2 )
-
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of \a c1 is greater than
- that of \a c2; otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator>( TQChar c, char ch )
-
- \overload
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of \a c is greater than
- that of the ASCII/Latin-1 character \a ch; otherwise returns FALSE.
-*/
-
-/*!
- \fn int operator>( char ch, TQChar c )
-
- \overload
- \relates TQChar
-
- Returns TRUE if the numeric Unicode value of the ASCII/Latin-1
- character \a ch is greater than that of \a c; otherwise returns
- FALSE.
-*/
-
-#ifndef TQT_NO_UNICODETABLES
-
-// small class used internally in TQString::Compose()
-class TQLigature
-{
-public:
- TQLigature( TQChar c );
-
- TQ_UINT16 first() { cur = ligatures; return cur ? *cur : 0; }
- TQ_UINT16 next() { return cur && *cur ? *(cur++) : 0; }
- TQ_UINT16 current() { return cur ? *cur : 0; }
-
- int match(TQString & str, unsigned int index);
- TQChar head();
- TQChar::Decomposition tag();
-
-private:
- TQ_UINT16 *ligatures;
- TQ_UINT16 *cur;
-};
-
-TQLigature::TQLigature( TQChar c )
-{
- register int pos = TQUnicodeTables::ligature_info[c.row()];
- if( !pos )
- ligatures = 0;
- else
- {
- pos = TQUnicodeTables::ligature_info[(pos<<8)+c.cell()];
- ligatures = (TQ_UINT16 *)&(TQUnicodeTables::ligature_map[pos]);
- }
- cur = ligatures;
-}
-
-TQChar TQLigature::head()
-{
- if(current())
- return TQChar(TQUnicodeTables::decomposition_map[current()+1]);
-
- return TQChar::null;
-}
-
-TQChar::Decomposition TQLigature::tag()
-{
- if(current())
- return (TQChar::Decomposition) TQUnicodeTables::decomposition_map[current()];
-
- return TQChar::Canonical;
-}
-
-int TQLigature::match(TQString & str, unsigned int index)
-{
- unsigned int i=index;
-
- if(!current()) return 0;
-
- TQ_UINT16 lig = current() + 2;
- TQ_UINT16 ch;
-
- while ((i < str.length()) && (ch = TQUnicodeTables::decomposition_map[lig])) {
- if (str[(int)i] != TQChar(ch))
- return 0;
- i++;
- lig++;
- }
-
- if (!TQUnicodeTables::decomposition_map[lig])
- {
- return i-index;
- }
- return 0;
-}
-
-
-// this function is just used in TQString::compose()
-static inline bool format(TQChar::Decomposition tag, TQString & str,
- int index, int len)
-{
- unsigned int l = index + len;
- unsigned int r = index;
-
- bool left = FALSE, right = FALSE;
-
- left = ((l < str.length()) &&
- ((str[(int)l].joining() == TQChar::Dual) ||
- (str[(int)l].joining() == TQChar::Right)));
- if (r > 0) {
- r--;
- //printf("joining(right) = %d\n", str[(int)r].joining());
- right = (str[(int)r].joining() == TQChar::Dual);
- }
-
-
- switch (tag) {
- case TQChar::Medial:
- return (left & right);
- case TQChar::Initial:
- return (left && !right);
- case TQChar::Final:
- return (right);// && !left);
- case TQChar::Isolated:
- default:
- return (!right && !left);
- }
-} // format()
-#endif
-
-/*
- TQString::compose() and visual() were developed by Gordon Tisher
- <[email protected]>, with input from Lars Knoll <[email protected]>,
- who developed the tqunicode data tables.
-*/
-/*!
- \warning This function is not supported in TQt 3.x. It is provided
- for experimental and illustrative purposes only. It is mainly of
- interest to those experimenting with Arabic and other
- composition-rich texts.
-
- Applies possible ligatures to a TQString. Useful when
- composition-rich text requires rendering with glyph-poor fonts,
- but it also makes compositions such as TQChar(0x0041) ('A') and
- TQChar(0x0308) (Unicode accent diaresis), giving TQChar(0x00c4)
- (German A Umlaut).
-*/
-void TQString::compose()
-{
-#ifndef TQT_NO_UNICODETABLES
- unsigned int index=0, len;
- unsigned int cindex = 0;
-
- TQChar code, head;
-
- TQMemArray<TQChar> dia;
-
- TQString composed = *this;
-
- while (index < length()) {
- code = at(index);
- //printf("\n\nligature for 0x%x:\n", code.tqunicode());
- TQLigature ligature(code);
- ligature.first();
- while ( ligature.current() ) {
- if ((len = ligature.match(*this, index)) != 0) {
- head = ligature.head();
- unsigned short code = head.tqunicode();
- // we exclude Arabic presentation forms A and a few
- // other ligatures, which are undefined in most fonts
- if(!(code > 0xfb50 && code < 0xfe80) &&
- !(code > 0xfb00 && code < 0xfb2a)) {
- // joining info is only needed for Arabic
- if (format(ligature.tag(), *this, index, len)) {
- //printf("using ligature 0x%x, len=%d\n",code,len);
- // replace letter
- composed.replace(cindex, len, TQChar(head));
- index += len-1;
- // we continue searching in case we have a final
- // form because medial ones are preferred.
- if ( len != 1 || ligature.tag() !=TQChar::Final )
- break;
- }
- }
- }
- ligature.next();
- }
- cindex++;
- index++;
- }
- *this = composed;
-#endif
-}
-
-
-// These macros are used for efficient allocation of TQChar strings.
-// IMPORTANT! If you change these, make sure you also change the
-// "delete tqunicode" statement in ~TQStringData() in tqstring.h correspondingly!
-
-#define TQT_ALLOC_TQCHAR_VEC( N ) (TQChar*) new char[ sizeof(TQChar)*( N ) ]
-#define TQT_DELETE_TQCHAR_VEC( P ) delete[] ((char*)( P ))
-
-
-/*!
- This utility function converts the 8-bit string \a ba to Unicode,
- returning the result.
-
- The caller is responsible for deleting the return value with
- delete[].
-*/
-
-TQChar* TQString::latin1ToUnicode( const TQByteArray& ba, uint* len )
-{
- if ( ba.isNull() ) {
- *len = 0;
- return 0;
- }
- int l = 0;
- while ( l < (int)ba.size() && ba[l] )
- l++;
- const char* str = ba.data();
- TQChar *uc = new TQChar[ l ]; // Can't use macro, since function is public
- TQChar *result = uc;
- if ( len )
- *len = l;
- while (l--)
- *uc++ = *str++;
- return result;
-}
-
-static TQChar* internalLatin1ToUnicode( const TQByteArray& ba, uint* len )
-{
- if ( ba.isNull() ) {
- *len = 0;
- return 0;
- }
- int l = 0;
- while ( l < (int)ba.size() && ba[l] )
- l++;
- const char* str = ba.data();
- TQChar *uc = TQT_ALLOC_TQCHAR_VEC( l );
- TQChar *result = uc;
- if ( len )
- *len = l;
- while (l--)
- *uc++ = *str++;
- return result;
-}
-
-/*!
- \overload
-
- This utility function converts the '\0'-terminated 8-bit string \a
- str to Unicode, returning the result and setting \a *len to the
- length of the Unicode string.
-
- The caller is responsible for deleting the return value with
- delete[].
-*/
-
-TQChar* TQString::latin1ToUnicode( const char *str, uint* len, uint maxlen )
-{
- TQChar* result = 0;
- uint l = 0;
- if ( str ) {
- if ( maxlen != (uint)-1 ) {
- while ( l < maxlen && str[l] )
- l++;
- } else {
- // Faster?
- l = int(strlen( str ));
- }
- TQChar *uc = new TQChar[ l ]; // Can't use macro since function is public
- result = uc;
- uint i = l;
- while ( i-- )
- *uc++ = *str++;
- }
- if ( len )
- *len = l;
- return result;
-}
-
-static TQChar* internalLatin1ToUnicode( const char *str, uint* len,
- uint maxlen = (uint)-1 )
-{
- TQChar* result = 0;
- uint l = 0;
- if ( str ) {
- if ( maxlen != (uint)-1 ) {
- while ( l < maxlen && str[l] )
- l++;
- } else {
- // Faster?
- l = int(strlen( str ));
- }
- TQChar *uc = TQT_ALLOC_TQCHAR_VEC( l );
- result = uc;
- uint i = l;
- while ( i-- )
- *uc++ = *str++;
- }
- if ( len )
- *len = l;
- return result;
-}
-
-/*!
- This utility function converts \a l 16-bit characters from \a uc
- to ASCII, returning a '\0'-terminated string.
-
- The caller is responsible for deleting the resultant string with
- delete[].
-*/
-char* TQString::tqunicodeToLatin1(const TQChar *uc, uint l)
-{
- if (!uc) {
- return 0;
- }
- char *a = new char[l+1];
- char *result = a;
- while (l--) {
- *a++ = (uc->tqunicode() > 0xff) ? '?' : (char)uc->tqunicode();
- uc++;
- }
- *a = '\0';
- return result;
-}
-
-/*****************************************************************************
- TQString member functions
- *****************************************************************************/
-
-/*!
- \class TQString tqstring.h
- \reentrant
-
- \brief The TQString class provides an abstraction of Unicode text
- and the classic C '\0'-terminated char array.
-
- \ingroup tools
- \ingroup shared
- \ingroup text
- \mainclass
-
- TQString uses \link shclass.html implicit sharing\endlink, which
- makes it very efficient and easy to use.
-
- In all of the TQString methods that take \c {const char *}
- parameters, the \c {const char *} is interpreted as a classic
- C-style '\0'-terminated ASCII string. It is legal for the \c
- {const char *} parameter to be 0. If the \c {const char *} is not
- '\0'-terminated, the results are undefined. Functions that copy
- classic C strings into a TQString will not copy the terminating
- '\0' character. The TQChar array of the TQString (as returned by
- tqunicode()) is generally not terminated by a '\0'. If you need to
- pass a TQString to a function that requires a C '\0'-terminated
- string use latin1().
-
- \keyword TQString::null
- A TQString that has not been assigned to anything is \e null, i.e.
- both the length and data pointer is 0. A TQString that references
- the empty string ("", a single '\0' char) is \e empty. Both null
- and empty TQStrings are legal parameters to the methods. Assigning
- \c{(const char *) 0} to TQString gives a null TQString. For
- convenience, \c TQString::null is a null TQString. When sorting,
- empty strings come first, followed by non-empty strings, followed
- by null strings. We recommend using \c{if ( !str.isNull() )} to
- check for a non-null string rather than \c{if ( !str )}; see \l
- operator!() for an explanation.
-
- Note that if you find that you are mixing usage of \l TQCString,
- TQString, and \l TQByteArray, this causes lots of unnecessary
- copying and might indicate that the true nature of the data you
- are dealing with is uncertain. If the data is '\0'-terminated 8-bit
- data, use \l TQCString; if it is unterminated (i.e. contains '\0's)
- 8-bit data, use \l TQByteArray; if it is text, use TQString.
-
- Lists of strings are handled by the TQStringList class. You can
- split a string into a list of strings using TQStringList::split(),
- and join a list of strings into a single string with an optional
- separator using TQStringList::join(). You can obtain a list of
- strings from a string list that contain a particular substring or
- that match a particular \link tqregexp.html regex\endlink using
- TQStringList::grep().
-
- <b>Note for C programmers</b>
-
- Due to C++'s type system and the fact that TQString is implicitly
- shared, TQStrings can be treated like ints or other simple base
- types. For example:
-
- \code
- TQString boolToString( bool b )
- {
- TQString result;
- if ( b )
- result = "True";
- else
- result = "False";
- return result;
- }
- \endcode
-
- The variable, result, is an auto variable allocated on the stack.
- When return is called, because we're returning by value, The copy
- constructor is called and a copy of the string is returned. (No
- actual copying takes place thanks to the implicit sharing, see
- below.)
-
- Throughout TQt's source code you will encounter TQString usages like
- this:
- \code
- TQString func( const TQString& input )
- {
- TQString output = input;
- // process output
- return output;
- }
- \endcode
-
- The 'copying' of input to output is almost as fast as copying a
- pointer because behind the scenes copying is achieved by
- incrementing a reference count. TQString (like all TQt's implicitly
- shared classes) operates on a copy-on-write basis, only copying if
- an instance is actually changed.
-
- If you wish to create a deep copy of a TQString without losing any
- Unicode information then you should use TQDeepCopy.
-
- \sa TQChar TQCString TQByteArray TQConstString
-*/
-
-/*! \enum TQt::ComparisonFlags
-\internal
-*/
-/*!
- \enum TQt::StringComparisonMode
-
- This enum type is used to set the string comparison mode when
- searching for an item. It is used by TQListBox, TQListView and
- TQIconView, for example. We'll refer to the string being searched
- as the 'target' string.
-
- \value CaseSensitive The strings must match case sensitively.
- \value ExactMatch The target and search strings must match exactly.
- \value BeginsWith The target string begins with the search string.
- \value EndsWith The target string ends with the search string.
- \value Contains The target string contains the search string.
-
- If you OR these flags together (excluding \c CaseSensitive), the
- search criteria be applied in the following order: \c ExactMatch,
- \c BeginsWith, \c EndsWith, \c Contains.
-
- Matching is case-insensitive unless \c CaseSensitive is set. \c
- CaseSensitive can be OR-ed with any combination of the other
- flags.
-
-*/
-TQ_EXPORT TQStringData *TQString::shared_null = 0;
-TQT_STATIC_CONST_IMPL TQString TQString::null;
-TQT_STATIC_CONST_IMPL TQChar TQChar::null;
-TQT_STATIC_CONST_IMPL TQChar TQChar::replacement((ushort)0xfffd);
-TQT_STATIC_CONST_IMPL TQChar TQChar::byteOrderMark((ushort)0xfeff);
-TQT_STATIC_CONST_IMPL TQChar TQChar::byteOrderSwapped((ushort)0xfffe);
-TQT_STATIC_CONST_IMPL TQChar TQChar::nbsp((ushort)0x00a0);
-
-TQStringData* TQString::makeSharedNull()
-{
- TQString::shared_null = new TQStringData;
-#if defined( TQ_OS_MAC ) || defined(TQ_OS_SOLARIS) || defined(TQ_OS_HPUX) || defined(TQ_OS_AIX)
- TQString *that = const_cast<TQString *>(&TQString::null);
- that->d = TQString::shared_null;
-#endif
- return TQString::shared_null;
-}
-
-/*!
- \fn TQString::TQString()
-
- Constructs a null string, i.e. both the length and data pointer
- are 0.
-
- \sa isNull()
-*/
-
-/*!
- Constructs a string of length one, containing the character \a ch.
-*/
-TQString::TQString( TQChar ch )
-{
- d = new TQStringData( TQT_ALLOC_TQCHAR_VEC( 1 ), 1, 1 );
- d->tqunicode[0] = ch;
-}
-
-/*!
- Constructs an implicitly shared copy of \a s. This is very fast
- since it only involves incrementing a reference count.
-*/
-TQString::TQString( const TQString &s ) :
- d(s.d)
-{
- d->ref();
-}
-
-#ifdef USE_QT4
-
-// Interoperability
-// FIXME
-// These conversions are probably too weak
-
-/*!
- QT4 INTEROPERABILITY
-*/
-TQString::TQString( const QString &qs )
-{
- setAscii( TQString(qs).ascii() );
-}
-
-/*!
- QT4 INTEROPERABILITY
-*/
-TQString::operator QString() const
-{
- return QString::fromUtf8( this->utf8() );
-}
-
-/*!
- QT4 INTEROPERABILITY
-*/
-TQString &TQString::operator=( const QString &qs )
-{
- return setAscii( TQString(qs).ascii() );
-}
-
-bool operator==( const QString &s1, const TQString &s2 )
-{
- return (TQString(s1).ascii() == s2.ascii());
-}
-
-#endif // USE_QT4
-
-/*!
- \internal
-
- Private function.
-
- Constructs a string with preallocated space for \a size characters.
-
- The string is empty.
-
- \sa isNull()
-*/
-
-TQString::TQString( int size, bool /*dummy*/ )
-{
- if ( size ) {
- int l = size;
- TQChar* uc = TQT_ALLOC_TQCHAR_VEC( l );
- d = new TQStringData( uc, 0, l );
- } else {
- d = shared_null ? shared_null : (shared_null=new TQStringData);
- d->ref();
- }
-}
-
-/*!
- Constructs a string that is a deep copy of \a ba interpreted as a
- classic C string.
-*/
-
-TQString::TQString( const TQByteArray& ba )
-{
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() ) {
- d = 0;
- *this = fromAscii( ba.data(), ba.size() );
- return;
- }
-#endif
- uint l;
- TQChar *uc = internalLatin1ToUnicode(ba,&l);
- d = new TQStringData(uc,l,l);
-}
-
-/*!
- Constructs a string that is a deep copy of the first \a length
- characters in the TQChar array.
-
- If \a tqunicode and \a length are 0, then a null string is created.
-
- If only \a tqunicode is 0, the string is empty but has \a length
- characters of space preallocated: TQString expands automatically
- anyway, but this may speed up some cases a little. We recommend
- using the plain constructor and setLength() for this purpose since
- it will result in more readable code.
-
- \sa isNull() setLength()
-*/
-
-TQString::TQString( const TQChar* tqunicode, uint length )
-{
- if ( !tqunicode && !length ) {
- d = shared_null ? shared_null : makeSharedNull();
- d->ref();
- } else {
- TQChar* uc = TQT_ALLOC_TQCHAR_VEC( length );
- if ( tqunicode )
- memcpy(uc, tqunicode, length*sizeof(TQChar));
- d = new TQStringData(uc,tqunicode ? length : 0,length);
- }
-}
-
-/*!
- Constructs a string that is a deep copy of \a str, interpreted as
- a classic C string. The encoding is assumed to be Latin-1, unless
- you change it using TQTextCodec::setCodecForCStrings().
-
- If \a str is 0, then a null string is created.
-
- This is a cast constructor, but it is perfectly safe: converting a
- Latin-1 \c{const char *} to TQString preserves all the information. You
- can disable this constructor by defining \c TQT_NO_CAST_ASCII when
- you compile your applications. You can also make TQString objects
- by using setLatin1(), tqfromLatin1(), fromLocal8Bit(), and
- fromUtf8(). Or whatever encoding is appropriate for the 8-bit data
- you have.
-
- \sa isNull(), fromAscii()
-*/
-
-TQString::TQString( const char *str )
-{
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() ) {
- d = 0;
- *this = fromAscii( str );
- return;
- }
-#endif
- uint l;
- TQChar *uc = internalLatin1ToUnicode(str,&l);
- d = new TQStringData(uc,l,l);
-}
-
-#ifndef TQT_NO_STL
-/*!
- Constructs a string that is a deep copy of \a str.
-
- This is the same as fromAscii(\a str).
-*/
-
-TQString::TQString( const std::string &str )
-{
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() ) {
- d = 0;
- *this = fromAscii( str.c_str() );
- return;
- }
-#endif
- uint l;
- TQChar *uc = internalLatin1ToUnicode(str.c_str(),&l);
- d = new TQStringData(uc,l,l);
-}
-#endif
-
-/*!
- \fn TQString::~TQString()
-
- Destroys the string and frees the string's data if this is the
- last reference to the string.
-*/
-
-
-/*!
- Deallocates any space reserved solely by this TQString.
-
- If the string does not share its data with another TQString
- instance, nothing happens; otherwise the function creates a new,
- unique copy of this string. This function is called whenever the
- string is modified.
-*/
-
-void TQString::real_detach()
-{
- setLength( length() );
-}
-
-void TQString::deref()
-{
- if ( d && d->deref() ) {
- if ( d != shared_null )
- delete d;
- d = 0;
- }
-}
-
-void TQStringData::deleteSelf()
-{
- delete this;
-}
-
-/*!
- \fn TQString& TQString::operator=( TQChar c )
-
- Sets the string to contain just the single character \a c.
-*/
-
-/*!
- \fn TQString& TQString::operator=( const std::string& s )
-
- \overload
-
- Makes a deep copy of \a s and returns a reference to the deep
- copy.
-*/
-
-/*!
- \fn TQString& TQString::operator=( char c )
-
- \overload
-
- Sets the string to contain just the single character \a c.
-*/
-
-/*!
- \overload
-
- Assigns a shallow copy of \a s to this string and returns a
- reference to this string. This is very fast because the string
- isn't actually copied.
-*/
-TQString &TQString::operator=( const TQString &s )
-{
- s.d->ref();
- deref();
- d = s.d;
- return *this;
-}
-
-/*!
- \overload
-
- Assigns a deep copy of \a cstr, interpreted as a classic C
- string, to this string. Returns a reference to this string.
-*/
-TQString &TQString::operator=( const TQCString& cstr )
-{
- return setAscii( cstr );
-}
-
-
-/*!
- \overload
-
- Assigns a deep copy of \a str, interpreted as a classic C string
- to this string and returns a reference to this string.
-
- If \a str is 0, then a null string is created.
-
- \sa isNull()
-*/
-TQString &TQString::operator=( const char *str )
-{
- return setAscii(str);
-}
-
-
-/*!
- \fn bool TQString::isNull() const
-
- Returns TRUE if the string is null; otherwise returns FALSE. A
- null string is always empty.
-
- \code
- TQString a; // a.tqunicode() == 0, a.length() == 0
- a.isNull(); // TRUE, because a.tqunicode() == 0
- a.isEmpty(); // TRUE, because a.length() == 0
- \endcode
-
- \sa isEmpty(), length()
-*/
-
-/*!
- \fn bool TQString::isEmpty() const
-
- Returns TRUE if the string is empty, i.e. if length() == 0;
- otherwise returns FALSE. Null strings are also empty.
-
- \code
- TQString a( "" );
- a.isEmpty(); // TRUE
- a.isNull(); // FALSE
-
- TQString b;
- b.isEmpty(); // TRUE
- b.isNull(); // TRUE
- \endcode
-
- \sa isNull(), length()
-*/
-
-/*!
- \fn uint TQString::length() const
-
- Returns the length of the string.
-
- Null strings and empty strings have zero length.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- If \a newLen is less than the length of the string, then the
- string is truncated at position \a newLen. Otherwise nothing
- happens.
-
- \code
- TQString s = "truncate me";
- s.truncate( 5 ); // s == "trunc"
- \endcode
-
- \sa setLength()
-*/
-
-void TQString::truncate( uint newLen )
-{
- if ( newLen < d->len )
- setLength( newLen );
-}
-
-/*!
- Ensures that at least \a newLen characters are allocated to the
- string, and sets the length of the string to \a newLen. Any new
- space allocated contains arbitrary data.
-
- \sa reserve(), truncate()
-*/
-void TQString::setLength( uint newLen )
-{
- if ( d->count != 1 || newLen > d->maxl ||
- ( newLen * 4 < d->maxl && d->maxl > 4 ) ) {
- // detach, grow or shrink
- uint newMax = computeNewMax( newLen );
- TQChar* nd = TQT_ALLOC_TQCHAR_VEC( newMax );
- if ( nd ) {
- uint len = TQMIN( d->len, newLen );
- memcpy( nd, d->tqunicode, sizeof(TQChar) * len );
- deref();
- d = new TQStringData( nd, newLen, newMax );
- }
- } else {
- d->len = newLen;
- d->setDirty();
- }
-}
-
-/*!
- \fn uint TQString::capacity() const
-
- Returns the number of characters this string can hold
- in the allocated memory.
-
- \sa reserve(), squeeze()
-*/
-
-/*!
- Ensures that at least \a minCapacity characters are allocated to
- the string.
-
- This function is useful for code that needs to build up a long
- string and wants to avoid repeated reallocation. In this example,
- we want to add to the string until some condition is true, and
- we're fairly sure that size is big enough:
- \code
- TQString result;
- int len = 0;
- result.reserve(maxLen);
- while (...) {
- result[len++] = ... // fill part of the space
- }
- result.squeeze();
- \endcode
-
- If \e maxLen is an underestimate, the worst that will happen is
- that the loop will slow down.
-
- If it is not possible to allocate enough memory, the string
- remains unchanged.
-
- \sa capacity(), squeeze(), setLength()
-*/
-
-void TQString::reserve( uint minCapacity )
-{
- if ( d->maxl < minCapacity ) {
- TQChar *nd = TQT_ALLOC_TQCHAR_VEC( minCapacity );
- if ( nd ) {
- uint len = d->len;
- if ( len )
- memcpy( nd, d->tqunicode, sizeof(TQChar) * len );
- deref();
- d = new TQStringData( nd, len, minCapacity );
- }
- }
-}
-
-
-/*!
- Squeezes the string's capacity to the current content.
-
- \sa capacity(), reserve()
-*/
-void TQString::squeeze()
-{
- if ( d->maxl > d->len ) {
- TQChar *nd = TQT_ALLOC_TQCHAR_VEC( d->len );
- if ( nd ) {
- uint len = d->len;
- if ( len )
- memcpy( nd, d->tqunicode, sizeof(TQChar) * len );
- deref();
- d = new TQStringData( nd, len, len );
- }
- }
-}
-
-/*!
- \internal
-
- Like setLength, but doesn't shrink the allocated memory.
-*/
-void TQString::grow( uint newLen )
-{
- if ( d->count != 1 || newLen > d->maxl ) {
- setLength( newLen );
- } else {
- d->len = newLen;
- d->setDirty();
- }
-}
-
-struct ArgEscapeData
-{
- uint min_escape; // lowest escape sequence number
- uint occurrences; // number of occurences of the lowest escape
- // sequence number
- uint locale_occurrences; // number of occurences of the lowest escape
- // sequence number which contain 'L'
- uint escape_len; // total length of escape sequences which will
- // be replaced
-};
-
-static ArgEscapeData findArgEscapes(const TQString &s)
-{
- const TQChar *uc_begin = s.tqunicode();
- const TQChar *uc_end = uc_begin + s.length();
-
- ArgEscapeData d;
-
- d.min_escape = 10;
- d.occurrences = 0;
- d.escape_len = 0;
- d.locale_occurrences = 0;
-
- const TQChar *c = uc_begin;
- while (c != uc_end) {
- while (c != uc_end && c->tqunicode() != '%')
- ++c;
-
- if (c == uc_end || ++c == uc_end)
- break;
-
- bool locale_arg = FALSE;
- if (c->tqunicode() == 'L') {
- locale_arg = TRUE;
- if (++c == uc_end)
- break;
- }
-
- if (c->tqunicode() < '0' || c->tqunicode() > '9')
- continue;
-
- uint escape = c->tqunicode() - '0';
- ++c;
-
- if (escape > d.min_escape)
- continue;
-
- if (escape < d.min_escape) {
- d.min_escape = escape;
- d.occurrences = 0;
- d.escape_len = 0;
- d.locale_occurrences = 0;
- }
-
-#if TQT_VERSION < 0x040000
- // ### remove preprocessor in TQt 4.0
- /* Since in TQt < 4.0 only the first instance is replaced,
- escape_len should hold the length of only the first escape
- sequence */
- if (d.occurrences == 0)
-#endif
- {
- ++d.occurrences;
- if (locale_arg) {
- ++d.locale_occurrences;
- d.escape_len += 3;
- }
- else
- d.escape_len += 2;
- }
- }
-
- return d;
-}
-
-static TQString replaceArgEscapes(const TQString &s, const ArgEscapeData &d, int field_width,
- const TQString &arg, const TQString &larg)
-{
- const TQChar *uc_begin = s.tqunicode();
- const TQChar *uc_end = uc_begin + s.length();
-
- uint abs_field_width = TQABS(field_width);
- uint result_len = s.length()
- - d.escape_len
- + (d.occurrences - d.locale_occurrences)
- *TQMAX(abs_field_width, arg.length())
- + d.locale_occurrences
- *TQMAX(abs_field_width, larg.length());
-
- TQString result;
- result.setLength(result_len);
- TQChar *result_buff = (TQChar*) result.tqunicode();
-
- TQChar *rc = result_buff;
- const TQChar *c = uc_begin;
- uint repl_cnt = 0;
- while (c != uc_end) {
- /* We don't have to check if we run off the end of the string with c,
- because as long as d.occurrences > 0 we KNOW there are valid escape
- sequences. */
-
- const TQChar *text_start = c;
-
- while (c->tqunicode() != '%')
- ++c;
-
- const TQChar *escape_start = c++;
-
- bool locale_arg = FALSE;
- if (c->tqunicode() == 'L') {
- locale_arg = TRUE;
- ++c;
- }
-
- if (c->tqunicode() != '0' + d.min_escape) {
- memcpy(rc, text_start, (c - text_start)*sizeof(TQChar));
- rc += c - text_start;
- }
- else {
- ++c;
-
- memcpy(rc, text_start, (escape_start - text_start)*sizeof(TQChar));
- rc += escape_start - text_start;
-
- uint pad_chars;
- if (locale_arg)
- pad_chars = TQMAX(abs_field_width, larg.length()) - larg.length();
- else
- pad_chars = TQMAX(abs_field_width, arg.length()) - arg.length();
-
- if (field_width > 0) { // left padded
- for (uint i = 0; i < pad_chars; ++i)
- (rc++)->tqunicode() = ' ';
- }
-
- if (locale_arg) {
- memcpy(rc, larg.tqunicode(), larg.length()*sizeof(TQChar));
- rc += larg.length();
- }
- else {
- memcpy(rc, arg.tqunicode(), arg.length()*sizeof(TQChar));
- rc += arg.length();
- }
-
- if (field_width < 0) { // right padded
- for (uint i = 0; i < pad_chars; ++i)
- (rc++)->tqunicode() = ' ';
- }
-
- if (++repl_cnt == d.occurrences) {
- memcpy(rc, c, (uc_end - c)*sizeof(TQChar));
- rc += uc_end - c;
- TQ_ASSERT(rc - result_buff == (int)result_len);
- c = uc_end;
- }
- }
- }
-
- return result;
-}
-
-/*!
- This function will return a string that replaces the lowest
- numbered occurrence of \c %1, \c %2, ..., \c %9 with \a a.
-
- The \a fieldWidth value specifies the minimum amount of space that
- \a a is padded to. A positive value will produce right-aligned
- text, whereas a negative value will produce left-aligned text.
-
- The following example shows how we could create a 'status' string
- when processing a list of files:
- \code
- TQString status = TQString( "Processing file %1 of %2: %3" )
- .arg( i ) // current file's number
- .arg( total ) // number of files to process
- .arg( fileName ); // current file's name
- \endcode
-
- It is generally fine to use filenames and numbers as we have done
- in the example above. But note that using arg() to construct
- natural language sentences does not usually translate well into
- other languages because sentence structure and word order often
- differ between languages.
-
- If there is no place marker (\c %1, \c %2, etc.), a warning
- message (qWarning()) is output and the result is undefined.
-
- \warning If any placeholder occurs more than once, the result is undefined.
-
-*/
-TQString TQString::arg( const TQString& a, int fieldWidth ) const
-{
- ArgEscapeData d = findArgEscapes(*this);
-
- if (d.occurrences == 0) {
- qWarning( "TQString::arg(): Argument missing: %s, %s", latin1(),
- a.latin1() );
- return *this;
- }
-
- return replaceArgEscapes(*this, d, fieldWidth, a, a);
-}
-
-/*!
- \fn TQString TQString::arg( const TQString& a1, const TQString& a2 ) const
-
- \overload
-
- This is the same as str.arg(\a a1).arg(\a a2), except that
- the strings are replaced in one pass. This can make a difference
- if \a a1 contains e.g. \c{%1}:
-
- \code
- TQString str( "%1 %2" );
- str.arg( "Hello", "world" ); // returns "Hello world"
- str.arg( "Hello" ).arg( "world" ); // returns "Hello world"
-
- str.arg( "(%1)", "Hello" ); // returns "(%1) Hello"
- str.arg( "(%1)" ).arg( "Hello" ); // returns "(Hello) %2"
- \endcode
-*/
-
-/*!
- \fn TQString TQString::arg( const TQString& a1, const TQString& a2,
- const TQString& a3 ) const
- \overload
-
- This is the same as calling str.arg(\a a1).arg(\a a2).arg(\a a3),
- except that the strings are replaced in one pass.
-*/
-
-/*!
- \fn TQString TQString::arg( const TQString& a1, const TQString& a2,
- const TQString& a3, const TQString& a4 ) const
- \overload
-
- This is the same as calling
- str.arg(\a a1).arg(\a a2).arg(\a a3).arg(\a a4),
- except that the strings are replaced in one pass.
-*/
-
-/*!
- \overload
-
- The \a fieldWidth value specifies the minimum amount of space that
- \a a is padded to. A positive value will produce a right-aligned
- number, whereas a negative value will produce a left-aligned
- number.
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36.
-
- The '%' can be followed by an 'L', in which case the sequence is
- replaced with a localized representation of \a a. The conversion
- uses the default locale. The default locale is determined from the
- system's locale settings at application startup. It can be changed
- using TQLocale::setDefault(). The 'L' flag is ignored if \a base is
- not 10.
-
- \code
- TQString str;
- str = TQString( "Decimal 63 is %1 in hexadecimal" )
- .arg( 63, 0, 16 );
- // str == "Decimal 63 is 3f in hexadecimal"
-
- TQLocale::setDefault(TQLocale::English, TQLocale::UnitedStates);
- str = TQString( "%1 %L2 %L3" )
- .arg( 12345 )
- .arg( 12345 )
- .arg( 12345, 0, 16 );
- // str == "12345 12,345 3039"
- \endcode
-*/
-TQString TQString::arg( long a, int fieldWidth, int base ) const
-{
- return arg((TQ_LLONG)a, fieldWidth, base);
-}
-
-/*!
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-TQString TQString::arg( ulong a, int fieldWidth, int base ) const
-{
- return arg((TQ_ULLONG)a, fieldWidth, base);
-}
-
-/*!
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-TQString TQString::arg( TQ_LLONG a, int fieldWidth, int base ) const
-{
- ArgEscapeData d = findArgEscapes(*this);
-
- if (d.occurrences == 0) {
- qWarning( "TQString::arg(): Argument missing: %s, %lld", latin1(),
- a );
- return *this;
- }
-
- TQString arg;
- if (d.occurrences > d.locale_occurrences)
- arg = number(a, base);
-
- TQString locale_arg;
- if (d.locale_occurrences > 0) {
- TQLocale locale;
- locale_arg = locale.d->longLongToString(a, -1, base, -1, TQLocalePrivate::ThousandsGroup);
- }
-
- return replaceArgEscapes(*this, d, fieldWidth, arg, locale_arg);
-}
-
-/*!
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-TQString TQString::arg( TQ_ULLONG a, int fieldWidth, int base ) const
-{
- ArgEscapeData d = findArgEscapes(*this);
-
- if (d.occurrences == 0) {
- qWarning( "TQString::arg(): Argument missing: %s, %llu", latin1(),
- a );
- return *this;
- }
-
- TQString arg;
- if (d.occurrences > d.locale_occurrences)
- arg = number(a, base);
-
- TQString locale_arg;
- if (d.locale_occurrences > 0) {
- TQLocale locale;
- locale_arg = locale.d->unsLongLongToString(a, -1, base, -1, TQLocalePrivate::ThousandsGroup);
- }
-
- return replaceArgEscapes(*this, d, fieldWidth, arg, locale_arg);
-}
-
-/*!
- \fn TQString TQString::arg( int a, int fieldWidth, int base ) const
-
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-
-/*!
- \fn TQString TQString::arg( uint a, int fieldWidth, int base ) const
-
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-
-/*!
- \fn TQString TQString::arg( short a, int fieldWidth, int base ) const
-
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-
-/*!
- \fn TQString TQString::arg( ushort a, int fieldWidth, int base ) const
-
- \overload
-
- \a a is expressed in base \a base, which is 10 by default and must
- be between 2 and 36. If \a base is 10, the '%L' syntax can be used
- to produce localized strings.
-*/
-
-
-/*!
- \overload
-
- \a a is assumed to be in the Latin-1 character set.
-*/
-TQString TQString::arg( char a, int fieldWidth ) const
-{
- TQString c;
- c += a;
- return arg( c, fieldWidth );
-}
-
-/*!
- \overload
-*/
-TQString TQString::arg( TQChar a, int fieldWidth ) const
-{
- TQString c;
- c += a;
- return arg( c, fieldWidth );
-}
-
-/*!
- \overload
-
- \target arg-formats
-
- Argument \a a is formatted according to the \a fmt format specified,
- which is 'g' by default and can be any of the following:
-
- \table
- \header \i Format \i Meaning
- \row \i \c e \i format as [-]9.9e[+|-]999
- \row \i \c E \i format as [-]9.9E[+|-]999
- \row \i \c f \i format as [-]9.9
- \row \i \c g \i use \c e or \c f format, whichever is the most concise
- \row \i \c G \i use \c E or \c f format, whichever is the most concise
- \endtable
-
- With 'e', 'E', and 'f', \a prec is the number of digits after the
- decimal point. With 'g' and 'G', \a prec is the maximum number of
- significant digits (trailing zeroes are omitted).
-
- \code
- double d = 12.34;
- TQString ds = TQString( "'E' format, precision 3, gives %1" )
- .arg( d, 0, 'E', 3 );
- // ds == "'E' format, precision 3, gives 1.234E+01"
- \endcode
-
- The '%L' syntax can be used to produce localized strings.
-*/
-TQString TQString::arg( double a, int fieldWidth, char fmt, int prec ) const
-{
- ArgEscapeData d = findArgEscapes(*this);
-
- if (d.occurrences == 0) {
- qWarning( "TQString::arg(): Argument missing: %s, %g", latin1(),
- a );
- return *this;
- }
-
- TQString arg;
- if (d.occurrences > d.locale_occurrences)
- arg = number(a, fmt, prec);
-
- TQString locale_arg;
- if (d.locale_occurrences > 0) {
- TQLocale locale;
-
- TQLocalePrivate::DoubleForm form = TQLocalePrivate::DFDecimal;
- uint flags = 0;
-
- if (qIsUpper(fmt))
- flags = TQLocalePrivate::CapitalEorX;
- fmt = qToLower(fmt);
-
- switch (fmt) {
- case 'f':
- form = TQLocalePrivate::DFDecimal;
- break;
- case 'e':
- form = TQLocalePrivate::DFExponent;
- break;
- case 'g':
- form = TQLocalePrivate::DFSignificantDigits;
- break;
- default:
-#if defined(TQT_CHECK_RANGE)
- qWarning( "TQString::setNum: Invalid format char '%c'", fmt );
-#endif
- break;
- }
-
- flags |= TQLocalePrivate::ThousandsGroup;
-
- locale_arg = locale.d->doubleToString(a, prec, form, -1, flags);
- }
-
- return replaceArgEscapes(*this, d, fieldWidth, arg, locale_arg);
-}
-
-TQString TQString::multiArg( int numArgs, const TQString& a1, const TQString& a2,
- const TQString& a3, const TQString& a4 ) const
-{
- TQString result;
- union {
- int digitUsed[10];
- int argForDigit[10];
- };
- register const TQChar *uc = d->tqunicode;
- const TQString *args[4];
- const int len = (int) length();
- const int end = len - 1;
- int lastDigit = -1;
- int i;
-
- memset( digitUsed, 0, sizeof(digitUsed) );
- args[0] = &a1;
- args[1] = &a2;
- args[2] = &a3;
- args[3] = &a4;
-
- for ( i = 0; i < end; i++ ) {
- if ( uc[i] == '%' ) {
- int digit = uc[i + 1].tqunicode() - '0';
- if ( digit >= 0 && digit <= 9 )
- digitUsed[digit]++;
- }
- }
-
- for ( i = 0; i < numArgs; i++ ) {
- do {
- ++lastDigit;
- } while ( lastDigit < 10 && digitUsed[lastDigit] == 0 );
-
- if ( lastDigit == 10 ) {
- qWarning( "TQString::arg(): Argument missing: %s, %s",
- latin1(), args[i]->latin1() );
- numArgs = i;
- lastDigit = 9;
- break;
- }
- argForDigit[lastDigit] = i;
- }
-
- i = 0;
- while ( i < len ) {
- if ( uc[i] == '%' && i != end ) {
- int digit = uc[i + 1].tqunicode() - '0';
- if ( digit >= 0 && digit <= lastDigit ) {
- result += *args[argForDigit[digit]];
- i += 2;
- continue;
- }
- }
- result += uc[i++];
- }
- return result;
-}
-
-
-/*!
- Safely builds a formatted string from the format string \a cformat
- and an arbitrary list of arguments. The format string supports all
- the escape sequences of printf() in the standard C library.
-
- The %s escape sequence expects a utf8() encoded string. The format
- string \e cformat is expected to be in latin1. If you need a
- Unicode format string, use arg() instead. For typesafe string
- building, with full Unicode support, you can use TQTextOStream like
- this:
-
- \code
- TQString str;
- TQString s = ...;
- int x = ...;
- TQTextOStream( &str ) << s << " : " << x;
- \endcode
-
- For \link TQObject::tr() translations,\endlink especially if the
- strings contains more than one escape sequence, you should
- consider using the arg() function instead. This allows the order
- of the replacements to be controlled by the translator, and has
- Unicode support.
-
- The %lc escape sequence expects a tqunicode character of type ushort
- (as returned by TQChar::tqunicode()).
- The %ls escape sequence expects a pointer to a zero-terminated
- array of tqunicode characters of type ushort (as returned by
- TQString::ucs2()).
-
- \sa arg()
-*/
-
-#ifndef TQT_NO_SPRINTF
-TQString &TQString::sprintf( const char* cformat, ... )
-{
- TQLocale locale(TQLocale::C);
-
- va_list ap;
- va_start( ap, cformat );
-
- if ( !cformat || !*cformat ) {
- // TQt 1.x compat
- *this = tqfromLatin1( "" );
- return *this;
- }
-
- // Parse cformat
-
- TQString result;
- const char *c = cformat;
- for (;;) {
- // Copy non-escape chars to result
- while (*c != '\0' && *c != '%')
- result.append(*c++);
-
- if (*c == '\0')
- break;
-
- // Found '%'
- const char *escape_start = c;
- ++c;
-
- if (*c == '\0') {
- result.append('%'); // a % at the end of the string - treat as non-escape text
- break;
- }
- if (*c == '%') {
- result.append('%'); // %%
- ++c;
- continue;
- }
-
- // Parse flag characters
- unsigned flags = 0;
- bool no_more_flags = FALSE;
- do {
- switch (*c) {
- case '#': flags |= TQLocalePrivate::Alternate; break;
- case '0': flags |= TQLocalePrivate::ZeroPadded; break;
- case '-': flags |= TQLocalePrivate::LeftAdjusted; break;
- case ' ': flags |= TQLocalePrivate::BlankBeforePositive; break;
- case '+': flags |= TQLocalePrivate::AlwaysShowSign; break;
- case '\'': flags |= TQLocalePrivate::ThousandsGroup; break;
- default: no_more_flags = TRUE; break;
- }
-
- if (!no_more_flags)
- ++c;
- } while (!no_more_flags);
-
- if (*c == '\0') {
- result.append(escape_start); // incomplete escape, treat as non-escape text
- break;
- }
-
- // Parse field width
- int width = -1; // -1 means unspecified
- if (qIsDigit(*c)) {
- TQString width_str;
- while (*c != '\0' && qIsDigit(*c))
- width_str.append(*c++);
-
- // can't be negative - started with a digit
- // contains at least one digit
- width = width_str.toInt();
- }
- else if (*c == '*') {
- width = va_arg(ap, int);
- if (width < 0)
- width = -1; // treat all negative numbers as unspecified
- ++c;
- }
-
- if (*c == '\0') {
- result.append(escape_start); // incomplete escape, treat as non-escape text
- break;
- }
-
- // Parse precision
- int precision = -1; // -1 means unspecified
- if (*c == '.') {
- ++c;
- if (qIsDigit(*c)) {
- TQString precision_str;
- while (*c != '\0' && qIsDigit(*c))
- precision_str.append(*c++);
-
- // can't be negative - started with a digit
- // contains at least one digit
- precision = precision_str.toInt();
- }
- else if (*c == '*') {
- precision = va_arg(ap, int);
- if (precision < 0)
- precision = -1; // treat all negative numbers as unspecified
- ++c;
- }
- }
-
- if (*c == '\0') {
- result.append(escape_start); // incomplete escape, treat as non-escape text
- break;
- }
-
- // Parse the length modifier
- enum LengthMod { lm_none, lm_hh, lm_h, lm_l, lm_ll, lm_L, lm_j, lm_z, lm_t };
- LengthMod length_mod = lm_none;
- switch (*c) {
- case 'h':
- ++c;
- if (*c == 'h') {
- length_mod = lm_hh;
- ++c;
- }
- else
- length_mod = lm_h;
- break;
-
- case 'l':
- ++c;
- if (*c == 'l') {
- length_mod = lm_ll;
- ++c;
- }
- else
- length_mod = lm_l;
- break;
-
- case 'L':
- ++c;
- length_mod = lm_L;
- break;
-
- case 'j':
- ++c;
- length_mod = lm_j;
- break;
-
- case 'z':
- case 'Z':
- ++c;
- length_mod = lm_z;
- break;
-
- case 't':
- ++c;
- length_mod = lm_t;
- break;
-
- default: break;
- }
-
- if (*c == '\0') {
- result.append(escape_start); // incomplete escape, treat as non-escape text
- break;
- }
-
- // Parse the conversion specifier and do the conversion
- TQString subst;
- switch (*c) {
- case 'd':
- case 'i': {
- TQ_LLONG i;
- switch (length_mod) {
- case lm_none: i = va_arg(ap, int); break;
- case lm_hh: i = va_arg(ap, int); break;
- case lm_h: i = va_arg(ap, int); break;
- case lm_l: i = va_arg(ap, long int); break;
- case lm_ll: i = va_arg(ap, TQ_LLONG); break;
- case lm_j: i = va_arg(ap, long int); break;
- case lm_z: i = va_arg(ap, size_t); break;
- case lm_t: i = va_arg(ap, int); break;
- default: i = 0; break;
- }
- subst = locale.d->longLongToString(i, precision, 10, width, flags);
- ++c;
- break;
- }
- case 'o':
- case 'u':
- case 'x':
- case 'X': {
- TQ_ULLONG u;
- switch (length_mod) {
- case lm_none: u = va_arg(ap, unsigned int); break;
- case lm_hh: u = va_arg(ap, unsigned int); break;
- case lm_h: u = va_arg(ap, unsigned int); break;
- case lm_l: u = va_arg(ap, unsigned long int); break;
- case lm_ll: u = va_arg(ap, TQ_ULLONG); break;
- default: u = 0; break;
- }
-
- if (qIsUpper(*c))
- flags |= TQLocalePrivate::CapitalEorX;
-
- int base = 10;
- switch (qToLower(*c)) {
- case 'o':
- base = 8; break;
- case 'u':
- base = 10; break;
- case 'x':
- base = 16; break;
- default: break;
- }
- subst = locale.d->unsLongLongToString(u, precision, base, width, flags);
- ++c;
- break;
- }
- case 'E':
- case 'e':
- case 'F':
- case 'f':
- case 'G':
- case 'g':
- case 'A':
- case 'a': {
- double d;
- if (length_mod == lm_L)
- d = va_arg(ap, long double); // not supported - converted to a double
- else
- d = va_arg(ap, double);
-
- if (qIsUpper(*c))
- flags |= TQLocalePrivate::CapitalEorX;
-
- TQLocalePrivate::DoubleForm form = TQLocalePrivate::DFDecimal;
- switch (qToLower(*c)) {
- case 'e': form = TQLocalePrivate::DFExponent; break;
- case 'a': // not supported - decimal form used instead
- case 'f': form = TQLocalePrivate::DFDecimal; break;
- case 'g': form = TQLocalePrivate::DFSignificantDigits; break;
- default: break;
- }
- subst = locale.d->doubleToString(d, precision, form, width, flags);
- ++c;
- break;
- }
- case 'c': {
- if (length_mod == lm_l)
- subst = TQChar((ushort) va_arg(ap, int));
- else
- subst = (uchar) va_arg(ap, int);
- ++c;
- break;
- }
- case 's': {
- if (length_mod == lm_l) {
- const ushort *buff = va_arg(ap, const ushort*);
- const ushort *ch = buff;
- while (*ch != 0)
- ++ch;
- subst.setUnicodeCodes(buff, ch - buff);
- } else
- subst = TQString::fromUtf8(va_arg(ap, const char*));
- if (precision != -1)
- subst.truncate(precision);
- ++c;
- break;
- }
- case 'p': {
- TQ_ULLONG i;
-#ifdef TQ_OS_WIN64
- i = (TQ_ULLONG) va_arg(ap, void*);
-#else
- i = (TQ_ULONG) va_arg(ap, void*);
-#endif
-
-#ifdef TQ_OS_WIN32
- flags |= TQLocalePrivate::CapitalEorX; // Windows does 1234ABCD
-#else
- flags |= TQLocalePrivate::Alternate; // Unix and Mac do 0x1234abcd
-#endif
-
- subst = locale.d->unsLongLongToString(i, precision, 16, width, flags);
- ++c;
- break;
- }
- case 'n':
- switch (length_mod) {
- case lm_hh: {
- signed char *n = va_arg(ap, signed char*);
- *n = result.length();
- break;
- }
- case lm_h: {
- short int *n = va_arg(ap, short int*);
- *n = result.length();
- break;
- }
- case lm_l: {
- long int *n = va_arg(ap, long int*);
- *n = result.length();
- break;
- }
- case lm_ll: {
- TQ_LLONG *n = va_arg(ap, TQ_LLONG*);
- volatile uint tmp = result.length(); // egcs-2.91.66 gets internal
- *n = tmp; // compiler error without volatile
- break;
- }
- default: {
- int *n = va_arg(ap, int*);
- *n = result.length();
- break;
- }
- }
- ++c;
- break;
-
- default: // bad escape, treat as non-escape text
- for (const char *cc = escape_start; cc != c; ++cc)
- result.append(*cc);
- continue;
- }
-
- if (flags & TQLocalePrivate::LeftAdjusted)
- result.append(subst.leftJustify(width));
- else
- result.append(subst.rightJustify(width));
- }
-
- va_end(ap);
- *this = result;
-
- return *this;
-}
-#endif
-
-/*!
- Fills the string with \a len characters of value \a c, and returns
- a reference to the string.
-
- If \a len is negative (the default), the current string length is
- used.
-
- \code
- TQString str;
- str.fill( 'g', 5 ); // string == "ggggg"
- \endcode
-*/
-
-TQString& TQString::fill( TQChar c, int len )
-{
- if ( len < 0 )
- len = length();
- if ( len == 0 ) {
- *this = "";
- } else {
- deref();
- TQChar * nd = TQT_ALLOC_TQCHAR_VEC( len );
- d = new TQStringData(nd,len,len);
- while (len--) *nd++ = c;
- }
- return *this;
-}
-
-
-/*!
- \fn TQString TQString::copy() const
-
- \obsolete
-
- In TQt 2.0 and later, all calls to this function are needless. Just
- remove them.
-*/
-
-/*!
- \overload
-
- Finds the first occurrence of the character \a c, starting at
- position \a index. If \a index is -1, the search starts at the
- last character; if -2, at the next to last character and so on.
- (See findRev() for searching backwards.)
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- Returns the position of \a c or -1 if \a c could not be found.
-*/
-
-int TQString::find( TQChar c, int index, bool cs ) const
-{
- const uint l = length();
- if ( index < 0 )
- index += l;
- if ( (uint)index >= l )
- return -1;
- register const TQChar *uc = tqunicode()+index;
- const TQChar *end = tqunicode() + l;
- if ( cs ) {
- while ( uc < end && *uc != c )
- uc++;
- } else {
- c = ::lower( c );
- while ( uc < end && ::lower( *uc ) != c )
- uc++;
- }
- if ( uint(uc - tqunicode()) >= l )
- return -1;
- return (int)(uc - tqunicode());
-}
-
-/* an implementation of the Boyer-Moore search algorithm
-*/
-
-/* initializes the skiptable to know haw far ahead we can skip on a wrong match
-*/
-static void bm_init_skiptable( const TQString &pattern, uint *skiptable, bool cs )
-{
- int i = 0;
- register uint *st = skiptable;
- int l = pattern.length();
- while ( i++ < 0x100/8 ) {
- *(st++) = l;
- *(st++) = l;
- *(st++) = l;
- *(st++) = l;
- *(st++) = l;
- *(st++) = l;
- *(st++) = l;
- *(st++) = l;
- }
- const TQChar *uc = pattern.tqunicode();
- if ( cs ) {
- while ( l-- ) {
- skiptable[ uc->cell() ] = l;
- uc++;
- }
- } else {
- while ( l-- ) {
- skiptable[ ::lower( *uc ).cell() ] = l;
- uc++;
- }
- }
-}
-
-static int bm_find( const TQString &str, int index, const TQString &pattern, uint *skiptable, bool cs )
-{
- const uint l = str.length();
- if ( pattern.isEmpty() )
- return index > (int)l ? -1 : index;
-
- const TQChar *uc = str.tqunicode();
- const TQChar *puc = pattern.tqunicode();
- const uint pl = pattern.length();
- const uint pl_minus_one = pl - 1;
-
- register const TQChar *current = uc + index + pl_minus_one;
- const TQChar *end = uc + l;
- if ( cs ) {
- while ( current < end ) {
- uint skip = skiptable[ current->cell() ];
- if ( !skip ) {
- // possible match
- while ( skip < pl ) {
- if ( *(current - skip ) != puc[pl_minus_one-skip] )
- break;
- skip++;
- }
- if ( skip > pl_minus_one ) { // we have a match
- return (current - uc) - skip + 1;
- }
- // in case we don't have a match we are a bit inefficient as we only skip by one
- // when we have the non matching char in the string.
- if ( skiptable[ (current-skip)->cell() ] == pl )
- skip = pl - skip;
- else
- skip = 1;
- }
- current += skip;
- }
- } else {
- while ( current < end ) {
- uint skip = skiptable[ ::lower( *current ).cell() ];
- if ( !skip ) {
- // possible match
- while ( skip < pl ) {
- if ( ::lower( *(current - skip) ) != ::lower( puc[pl_minus_one-skip] ) )
- break;
- skip++;
- }
- if ( skip > pl_minus_one ) // we have a match
- return (current - uc) - skip + 1;
- // in case we don't have a match we are a bit inefficient as we only skip by one
- // when we have the non matching char in the string.
- if ( skiptable[ ::lower(*(current - skip)).cell() ] == pl )
- skip = pl - skip;
- else
- skip = 1;
- }
- current += skip;
- }
- }
- // not found
- return -1;
-}
-
-
-#define REHASH( a ) \
- if ( sl_minus_1 < sizeof(uint) * CHAR_BIT ) \
- hashHaystack -= (a) << sl_minus_1; \
- hashHaystack <<= 1
-
-/*!
- \overload
-
- Finds the first occurrence of the string \a str, starting at
- position \a index. If \a index is -1, the search starts at the
- last character, if it is -2, at the next to last character and so
- on. (See findRev() for searching backwards.)
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- Returns the position of \a str or -1 if \a str could not be found.
-*/
-
-int TQString::find( const TQString& str, int index, bool cs ) const
-{
- const uint l = length();
- const uint sl = str.length();
- if ( index < 0 )
- index += l;
- if ( sl + index > l )
- return -1;
- if ( !sl )
- return index;
- if (!l)
- return -1;
-
-#if defined(TQ_OS_MACX) && defined(TQT_MACOSX_VERSION) && TQT_MACOSX_VERSION >= 0x1020
- if ( sl == 1 )
- return find( *str.tqunicode(), index, cs );
-#endif
-
- // we use the Boyer-Moore algorithm in cases where the overhead
- // for the hash table should pay off, otherwise we use a simple
- // hash function
- if ( l > 500 && sl > 5 ) {
- uint skiptable[0x100];
- bm_init_skiptable( str, skiptable, cs );
- return bm_find( *this, index, str, skiptable, cs );
- }
-
- /*
- We use some hashing for efficiency's sake. Instead of
- comparing strings, we compare the hash value of str with that of
- a part of this TQString. Only if that matches, we call ucstrncmp
- or ucstrnicmp.
- */
- const TQChar* needle = str.tqunicode();
- const TQChar* haystack = tqunicode() + index;
- const TQChar* end = tqunicode() + (l-sl);
- const uint sl_minus_1 = sl-1;
- uint hashNeedle = 0, hashHaystack = 0, i;
-
- if ( cs ) {
- for ( i = 0; i < sl; ++i ) {
- hashNeedle = ((hashNeedle<<1) + needle[i].tqunicode() );
- hashHaystack = ((hashHaystack<<1) + haystack[i].tqunicode() );
- }
- hashHaystack -= (haystack+sl_minus_1)->tqunicode();
-
- while ( haystack <= end ) {
- hashHaystack += (haystack+sl_minus_1)->tqunicode();
- if ( hashHaystack == hashNeedle
- && ucstrncmp( needle, haystack, sl ) == 0 )
- return haystack-tqunicode();
-
- REHASH( haystack->tqunicode() );
- ++haystack;
- }
- } else {
- for ( i = 0; i < sl; ++i ) {
- hashNeedle = ((hashNeedle<<1) +
- ::lower( needle[i].tqunicode() ).tqunicode() );
- hashHaystack = ((hashHaystack<<1) +
- ::lower( haystack[i].tqunicode() ).tqunicode() );
- }
-
- hashHaystack -= ::lower(*(haystack+sl_minus_1)).tqunicode();
- while ( haystack <= end ) {
- hashHaystack += ::lower(*(haystack+sl_minus_1)).tqunicode();
- if ( hashHaystack == hashNeedle
- && ucstrnicmp( needle, haystack, sl ) == 0 )
- return haystack-tqunicode();
-
- REHASH( ::lower(*haystack).tqunicode() );
- ++haystack;
- }
- }
- return -1;
-}
-
-/*!
- \fn int TQString::findRev( const char* str, int index ) const
-
- Equivalent to findRev(TQString(\a str), \a index).
-*/
-
-/*!
- \fn int TQString::find( const char* str, int index ) const
-
- \overload
-
- Equivalent to find(TQString(\a str), \a index).
-*/
-
-/*!
- \overload
-
- Finds the first occurrence of the character \a c, starting at
- position \a index and searching backwards. If the index is -1, the
- search starts at the last character, if it is -2, at the next to
- last character and so on.
-
- Returns the position of \a c or -1 if \a c could not be found.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- \code
- TQString string( "bananas" );
- int i = string.findRev( 'a' ); // i == 5
- \endcode
-*/
-
-int TQString::findRev( TQChar c, int index, bool cs ) const
-{
-#if defined(TQ_OS_MACX) && defined(TQT_MACOSX_VERSION) && TQT_MACOSX_VERSION < 0x1020
- return findRev( TQString( c ), index, cs );
-#else
- const uint l = length();
- if ( index < 0 )
- index += l;
- if ( (uint)index >= l )
- return -1;
- const TQChar *end = tqunicode();
- register const TQChar *uc = end + index;
- if ( cs ) {
- while ( uc >= end && *uc != c )
- uc--;
- } else {
- c = ::lower( c );
- while ( uc >= end && ::lower( *uc ) != c )
- uc--;
- }
- return uc - end;
-#endif
-}
-
-/*!
- \overload
-
- Finds the first occurrence of the string \a str, starting at
- position \a index and searching backwards. If the index is -1, the
- search starts at the last character, if it is -2, at the next to
- last character and so on.
-
- Returns the position of \a str or -1 if \a str could not be found.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- \code
- TQString string("bananas");
- int i = string.findRev( "ana" ); // i == 3
- \endcode
-*/
-
-int TQString::findRev( const TQString& str, int index, bool cs ) const
-{
- /*
- See TQString::find() for explanations.
- */
- const uint l = length();
- if ( index < 0 )
- index += l;
- const uint sl = str.length();
- int delta = l-sl;
- if ( index < 0 || index > (int)l || delta < 0 )
- return -1;
- if ( index > delta )
- index = delta;
-
-#if defined(TQ_OS_MACX) && defined(TQT_MACOSX_VERSION) && TQT_MACOSX_VERSION >= 0x1020
- if ( sl == 1 )
- return findRev( *str.tqunicode(), index, cs );
-#endif
-
- const TQChar* needle = str.tqunicode();
- const TQChar* haystack = tqunicode() + index;
- const TQChar* end = tqunicode();
- const uint sl_minus_1 = sl-1;
- const TQChar* n = needle+sl_minus_1;
- const TQChar* h = haystack+sl_minus_1;
- uint hashNeedle = 0, hashHaystack = 0, i;
-
- if ( cs ) {
- for ( i = 0; i < sl; ++i ) {
- hashNeedle = ((hashNeedle<<1) + (n-i)->tqunicode() );
- hashHaystack = ((hashHaystack<<1) + (h-i)->tqunicode() );
- }
- hashHaystack -= haystack->tqunicode();
-
- while ( haystack >= end ) {
- hashHaystack += haystack->tqunicode();
- if ( hashHaystack == hashNeedle
- && ucstrncmp( needle, haystack, sl ) == 0 )
- return haystack-tqunicode();
- --haystack;
- REHASH( (haystack+sl)->tqunicode() );
- }
- } else {
- for ( i = 0; i < sl; ++i ) {
- hashNeedle = ((hashNeedle<<1)
- + ::lower( (n-i)->tqunicode() ).tqunicode() );
- hashHaystack = ((hashHaystack<<1)
- + ::lower( (h-i)->tqunicode() ).tqunicode() );
- }
- hashHaystack -= ::lower(*haystack).tqunicode();
-
- while ( haystack >= end ) {
- hashHaystack += ::lower(*haystack).tqunicode();
- if ( hashHaystack == hashNeedle
- && ucstrnicmp( needle, haystack, sl ) == 0 )
- return haystack-tqunicode();
- --haystack;
- REHASH( ::lower(*(haystack+sl)).tqunicode() );
- }
- }
- return -1;
-}
-
-#undef REHASH
-
-/*!
- \enum TQString::SectionFlags
-
- \value SectionDefault Empty fields are counted, leading and
- trailing separators are not included, and the separator is
- compared case sensitively.
-
- \value SectionSkipEmpty Treat empty fields as if they don't exist,
- i.e. they are not considered as far as \e start and \e end are
- concerned.
-
- \value SectionIncludeLeadingSep Include the leading separator (if
- any) in the result string.
-
- \value SectionIncludeTrailingSep Include the trailing separator
- (if any) in the result string.
-
- \value SectionCaseInsensitiveSeps Compare the separator
- case-insensitively.
-
- Any of the last four values can be OR-ed together to form a flag.
-
- \sa section()
-*/
-
-/*!
- \fn TQString TQString::section( TQChar sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const
-
- This function returns a section of the string.
-
- This string is treated as a sequence of fields separated by the
- character, \a sep. The returned string consists of the fields from
- position \a start to position \a end inclusive. If \a end is not
- specified, all fields from position \a start to the end of the
- string are included. Fields are numbered 0, 1, 2, etc., counting
- from the left, and -1, -2, etc., counting from right to left.
-
- The \a flags argument can be used to affect some aspects of the
- function's behaviour, e.g. whether to be case sensitive, whether
- to skip empty fields and how to deal with leading and trailing
- separators; see \l{SectionFlags}.
-
- \code
- TQString csv( "forename,middlename,surname,phone" );
- TQString s = csv.section( ',', 2, 2 ); // s == "surname"
-
- TQString path( "/usr/local/bin/myapp" ); // First field is empty
- TQString s = path.section( '/', 3, 4 ); // s == "bin/myapp"
- TQString s = path.section( '/', 3, 3, SectionSkipEmpty ); // s == "myapp"
- \endcode
-
- If \a start or \a end is negative, we count fields from the right
- of the string, the right-most field being -1, the one from
- right-most field being -2, and so on.
-
- \code
- TQString csv( "forename,middlename,surname,phone" );
- TQString s = csv.section( ',', -3, -2 ); // s == "middlename,surname"
-
- TQString path( "/usr/local/bin/myapp" ); // First field is empty
- TQString s = path.section( '/', -1 ); // s == "myapp"
- \endcode
-
- \sa TQStringList::split()
-*/
-
-/*!
- \overload
-
- This function returns a section of the string.
-
- This string is treated as a sequence of fields separated by the
- string, \a sep. The returned string consists of the fields from
- position \a start to position \a end inclusive. If \a end is not
- specified, all fields from position \a start to the end of the
- string are included. Fields are numbered 0, 1, 2, etc., counting
- from the left, and -1, -2, etc., counting from right to left.
-
- The \a flags argument can be used to affect some aspects of the
- function's behaviour, e.g. whether to be case sensitive, whether
- to skip empty fields and how to deal with leading and trailing
- separators; see \l{SectionFlags}.
-
- \code
- TQString data( "forename**middlename**surname**phone" );
- TQString s = data.section( "**", 2, 2 ); // s == "surname"
- \endcode
-
- If \a start or \a end is negative, we count fields from the right
- of the string, the right-most field being -1, the one from
- right-most field being -2, and so on.
-
- \code
- TQString data( "forename**middlename**surname**phone" );
- TQString s = data.section( "**", -3, -2 ); // s == "middlename**surname"
- \endcode
-
- \sa TQStringList::split()
-*/
-
-TQString TQString::section( const TQString &sep, int start, int end, int flags ) const
-{
- TQStringList sections = TQStringList::split(sep, *this, TRUE);
- if(sections.isEmpty())
- return TQString();
- if(!(flags & SectionSkipEmpty)) {
- if(start < 0)
- start += int(sections.count());
- if(end < 0)
- end += int(sections.count());
- } else {
- int skip = 0;
- for(TQStringList::Iterator it = sections.begin(); it != sections.end(); ++it) {
- if((*it).isEmpty())
- skip++;
- }
- if(start < 0)
- start += int(sections.count()) - skip;
- if(end < 0)
- end += int(sections.count()) - skip;
- }
- int x = 0, run = 0;
- TQString ret;
- for(TQStringList::Iterator it = sections.begin(); x <= end && it != sections.end(); ++it) {
- if(x >= start) {
- if((*it).isEmpty()) {
- run++;
- } else {
- if(!ret.isEmpty() || !(flags & SectionSkipEmpty)) {
- int i_end = run;
- if(!ret.isEmpty() && !(flags & SectionIncludeTrailingSep))
- i_end++;
- if((flags & SectionIncludeLeadingSep) && it != sections.begin() && x == start)
- i_end++;
- for(int i = 0; i < i_end; i++)
- ret += sep;
- } else if((flags & SectionIncludeLeadingSep) && it != sections.begin()) {
- ret += sep;
- }
- run = 0;
- ret += (*it);
- if((flags & SectionIncludeTrailingSep) && it != sections.end())
- ret += sep;
- }
- }
- if(!(*it).isEmpty() || !(flags & SectionSkipEmpty))
- x++;
- }
- return ret;
-}
-
-#ifndef TQT_NO_REGEXP
-class section_chunk {
-public:
- section_chunk(int l, TQString s) { length = l; string = s; }
- int length;
- TQString string;
-};
-/*!
- \overload
-
- This function returns a section of the string.
-
- This string is treated as a sequence of fields separated by the
- regular expression, \a reg. The returned string consists of the
- fields from position \a start to position \a end inclusive. If \a
- end is not specified, all fields from position \a start to the end
- of the string are included. Fields are numbered 0, 1, 2, etc., counting
- from the left, and -1, -2, etc., counting from right to left.
-
- The \a flags argument can be used to affect some aspects of the
- function's behaviour, e.g. whether to be case sensitive, whether
- to skip empty fields and how to deal with leading and trailing
- separators; see \l{SectionFlags}.
-
- \code
- TQString line( "forename\tmiddlename surname \t \t phone" );
- TQRegExp sep( "\s+" );
- TQString s = line.section( sep, 2, 2 ); // s == "surname"
- \endcode
-
- If \a start or \a end is negative, we count fields from the right
- of the string, the right-most field being -1, the one from
- right-most field being -2, and so on.
-
- \code
- TQString line( "forename\tmiddlename surname \t \t phone" );
- TQRegExp sep( "\\s+" );
- TQString s = line.section( sep, -3, -2 ); // s == "middlename surname"
- \endcode
-
- \warning Using this TQRegExp version is much more expensive than
- the overloaded string and character versions.
-
- \sa TQStringList::split() simplifyWhiteSpace()
-*/
-
-TQString TQString::section( const TQRegExp &reg, int start, int end, int flags ) const
-{
- const TQChar *uc = tqunicode();
- if(!uc)
- return TQString();
-
- TQRegExp sep(reg);
- sep.setCaseSensitive(!(flags & SectionCaseInsensitiveSeps));
-
- TQPtrList<section_chunk> l;
- l.setAutoDelete(TRUE);
- int n = length(), m = 0, last_m = 0, last = 0, last_len = 0;
-
- while ( ( m = sep.search( *this, m ) ) != -1 ) {
- l.append(new section_chunk(last_len, TQString(uc + last_m, m - last_m)));
- last_m = m;
- last_len = sep.matchedLength();
- if((m += TQMAX(sep.matchedLength(), 1)) >= n) {
- last = 1;
- break;
- }
- }
- if(!last)
- l.append(new section_chunk(last_len, TQString(uc + last_m, n - last_m)));
-
- if(start < 0)
- start = l.count() + start;
- if(end == -1)
- end = l.count();
- else if(end < 0)
- end = l.count() + end;
-
- int i = 0;
- TQString ret;
- for ( section_chunk *chk=l.first(); chk; chk=l.next(), i++ ) {
- if((flags & SectionSkipEmpty) && chk->length == (int)chk->string.length()) {
- if(i <= start)
- start++;
- end++;
- }
- if(i == start) {
- ret = (flags & SectionIncludeLeadingSep) ? chk->string : chk->string.mid(chk->length);
- } else if(i > start) {
- ret += chk->string;
- }
- if(i == end) {
- if((chk=l.next()) && flags & SectionIncludeTrailingSep)
- ret += chk->string.left(chk->length);
- break;
- }
- }
- return ret;
-}
-#endif
-
-/*!
- \fn TQString TQString::section( char sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const
-
- \overload
-*/
-
-/*!
- \fn TQString TQString::section( const char *sep, int start, int end = 0xffffffff, int flags = SectionDefault ) const
-
- \overload
-*/
-
-
-/*!
- Returns the number of times the character \a c occurs in the
- string.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- \code
- TQString string( "Trolltech and TQt" );
- int n = string.contains( 't', FALSE );
- // n == 3
- \endcode
-*/
-
-int TQString::contains( TQChar c, bool cs ) const
-{
- int count = 0;
- const TQChar *uc = tqunicode();
- if ( !uc )
- return 0;
- int n = length();
- if ( cs ) {
- while ( n-- ) {
- if ( *uc == c )
- count++;
- uc++;
- }
- } else {
- c = ::lower( c );
- while ( n-- ) {
- if ( ::lower( *uc ) == c )
- count++;
- uc++;
- }
- }
- return count;
-}
-
-/*!
- \overload
-
- Returns the number of times the string \a str occurs in the string.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-*/
-int TQString::contains( const char* str, bool cs ) const
-{
- return contains( TQString(str), cs );
-}
-
-/*!
- \fn int TQString::contains( char c, bool cs ) const
-
- \overload
-*/
-
-/*!
- \fn int TQString::find( char c, int index, bool cs ) const
-
- \overload
-
- Find character \a c starting from position \a index.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-*/
-
-/*!
- \fn int TQString::findRev( char c, int index, bool cs ) const
-
- \overload
-
- Find character \a c starting from position \a index and working
- backwards.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-*/
-
-/*!
- \overload
-
- Returns the number of times \a str occurs in the string.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- This function counts overlapping strings, so in the example below,
- there are two instances of "ana" in "bananas".
-
- \code
- TQString str( "bananas" );
- int i = str.contains( "ana" ); // i == 2
- \endcode
-
- \sa findRev()
-*/
-
-int TQString::contains( const TQString &str, bool cs ) const
-{
- if ( isNull() )
- return 0;
- int count = 0;
- uint skiptable[0x100];
- bm_init_skiptable( str, skiptable, cs );
- int i = -1;
- // use boyer-moore for the ultimate speed experience
- while ( ( i = bm_find( *this, i + 1, str, skiptable, cs ) ) != -1 )
- count++;
- return count;
-}
-
-/*!
- Returns a substring that contains the \a len leftmost characters
- of the string.
-
- The whole string is returned if \a len exceeds the length of the
- string.
-
- \code
- TQString s = "Pineapple";
- TQString t = s.left( 4 ); // t == "Pine"
- \endcode
-
- \sa right(), mid(), isEmpty()
-*/
-
-TQString TQString::left( uint len ) const
-{
- if ( isEmpty() ) {
- return TQString();
- } else if ( len == 0 ) { // ## just for 1.x compat:
- return tqfromLatin1( "" );
- } else if ( len >= length() ) {
- return *this;
- } else {
- TQString s( len, TRUE );
- memcpy( s.d->tqunicode, d->tqunicode, len * sizeof(TQChar) );
- s.d->len = len;
- return s;
- }
-}
-
-/*!
- Returns a string that contains the \a len rightmost characters of
- the string.
-
- If \a len is greater than the length of the string then the whole
- string is returned.
-
- \code
- TQString string( "Pineapple" );
- TQString t = string.right( 5 ); // t == "apple"
- \endcode
-
- \sa left(), mid(), isEmpty()
-*/
-
-TQString TQString::right( uint len ) const
-{
- if ( isEmpty() ) {
- return TQString();
- } else if ( len == 0 ) { // ## just for 1.x compat:
- return tqfromLatin1( "" );
- } else {
- uint l = length();
- if ( len >= l )
- return *this;
- TQString s( len, TRUE );
- memcpy( s.d->tqunicode, d->tqunicode+(l-len), len*sizeof(TQChar) );
- s.d->len = len;
- return s;
- }
-}
-
-/*!
- Returns a string that contains the \a len characters of this
- string, starting at position \a index.
-
- Returns a null string if the string is empty or \a index is out of
- range. Returns the whole string from \a index if \a index + \a len
- exceeds the length of the string.
-
- \code
- TQString s( "Five pineapples" );
- TQString t = s.mid( 5, 4 ); // t == "pine"
- \endcode
-
- \sa left(), right()
-*/
-
-TQString TQString::mid( uint index, uint len ) const
-{
- uint slen = length();
- if ( isEmpty() || index >= slen ) {
- return TQString();
- } else if ( len == 0 ) { // ## just for 1.x compat:
- return tqfromLatin1( "" );
- } else {
- if ( len > slen-index )
- len = slen - index;
- if ( index == 0 && len == slen )
- return *this;
- register const TQChar *p = tqunicode()+index;
- TQString s( len, TRUE );
- memcpy( s.d->tqunicode, p, len * sizeof(TQChar) );
- s.d->len = len;
- return s;
- }
-}
-
-/*!
- Returns a string of length \a width that contains this string
- padded by the \a fill character.
-
- If \a truncate is FALSE and the length of the string is more than
- \a width, then the returned string is a copy of the string.
-
- If \a truncate is TRUE and the length of the string is more than
- \a width, then any characters in a copy of the string after length
- \a width are removed, and the copy is returned.
-
- \code
- TQString s( "apple" );
- TQString t = s.leftJustify( 8, '.' ); // t == "apple..."
- \endcode
-
- \sa rightJustify()
-*/
-
-TQString TQString::leftJustify( uint width, TQChar fill, bool truncate ) const
-{
- TQString result;
- int len = length();
- int padlen = width - len;
- if ( padlen > 0 ) {
- result.setLength(len+padlen);
- if ( len )
- memcpy( result.d->tqunicode, tqunicode(), sizeof(TQChar)*len );
- TQChar* uc = result.d->tqunicode + len;
- while (padlen--)
- *uc++ = fill;
- } else {
- if ( truncate )
- result = left( width );
- else
- result = *this;
- }
- return result;
-}
-
-/*!
- Returns a string of length \a width that contains the \a fill
- character followed by the string.
-
- If \a truncate is FALSE and the length of the string is more than
- \a width, then the returned string is a copy of the string.
-
- If \a truncate is TRUE and the length of the string is more than
- \a width, then the resulting string is truncated at position \a
- width.
-
- \code
- TQString string( "apple" );
- TQString t = string.rightJustify( 8, '.' ); // t == "...apple"
- \endcode
-
- \sa leftJustify()
-*/
-
-TQString TQString::rightJustify( uint width, TQChar fill, bool truncate ) const
-{
- TQString result;
- int len = length();
- int padlen = width - len;
- if ( padlen > 0 ) {
- result.setLength( len+padlen );
- TQChar* uc = result.d->tqunicode;
- while (padlen--)
- *uc++ = fill;
- if ( len )
- memcpy( uc, tqunicode(), sizeof(TQChar)*len );
- } else {
- if ( truncate )
- result = left( width );
- else
- result = *this;
- }
- return result;
-}
-
-/*!
- Returns a lowercase copy of the string.
-
- \code
- TQString string( "TROlltECH" );
- str = string.lower(); // str == "trolltech"
- \endcode
-
- \sa upper()
-*/
-
-TQString TQString::lower() const
-{
- int l = length();
- register TQChar *p = d->tqunicode;
- while ( l ) {
- if ( *p != ::lower(*p) ) {
- TQString s( *this );
- s.real_detach();
- p = s.d->tqunicode + ( p - d->tqunicode );
- while ( l ) {
- *p = ::lower( *p );
- l--;
- p++;
- }
- return s;
- }
- l--;
- p++;
- }
- return *this;
-}
-
-/*!
- Returns an uppercase copy of the string.
-
- \code
- TQString string( "TeXt" );
- str = string.upper(); // t == "TEXT"
- \endcode
-
- \sa lower()
-*/
-
-TQString TQString::upper() const
-{
- int l = length();
- register TQChar *p = d->tqunicode;
- while ( l ) {
- if ( *p != ::upper(*p) ) {
- TQString s( *this );
- s.real_detach();
- p = s.d->tqunicode + ( p - d->tqunicode );
- while ( l ) {
- *p = ::upper( *p );
- l--;
- p++;
- }
- return s;
- }
- l--;
- p++;
- }
- return *this;
-}
-
-
-/*!
- Returns a string that has whitespace removed from the start and
- the end.
-
- Whitespace means any character for which TQChar::isSpace() returns
- TRUE. This includes Unicode characters with decimal values 9
- (TAB), 10 (LF), 11 (VT), 12 (FF), 13 (CR) and 32 (Space), and may
- also include other Unicode characters.
-
- \code
- TQString string = " white space ";
- TQString s = string.stripWhiteSpace(); // s == "white space"
- \endcode
-
- \sa simplifyWhiteSpace()
-*/
-
-TQString TQString::stripWhiteSpace() const
-{
- if ( isEmpty() ) // nothing to do
- return *this;
- register const TQChar *s = tqunicode();
- if ( !s->isSpace() && !s[length()-1].isSpace() )
- return *this;
-
- int start = 0;
- int end = length() - 1;
- while ( start<=end && s[start].isSpace() ) // skip white space from start
- start++;
- if ( start <= end ) { // only white space
- while ( end && s[end].isSpace() ) // skip white space from end
- end--;
- }
- int l = end - start + 1;
- if ( l <= 0 )
- return TQString::tqfromLatin1("");
-
- TQString result( l, TRUE );
- memcpy( result.d->tqunicode, &s[start], sizeof(TQChar)*l );
- result.d->len = l;
- return result;
-}
-
-
-/*!
- Returns a string that has whitespace removed from the start and
- the end, and which has each sequence of internal whitespace
- replaced with a single space.
-
- Whitespace means any character for which TQChar::isSpace() returns
- TRUE. This includes Unicode characters with decimal values 9
- (TAB), 10 (LF), 11 (VT), 12 (FF), 13 (CR), and 32 (Space).
-
- \code
- TQString string = " lots\t of\nwhite space ";
- TQString t = string.simplifyWhiteSpace();
- // t == "lots of white space"
- \endcode
-
- \sa stripWhiteSpace()
-*/
-
-TQString TQString::simplifyWhiteSpace() const
-{
- if ( isEmpty() )
- return *this;
- TQString result;
- result.setLength( length() );
- const TQChar *from = tqunicode();
- const TQChar *fromend = from+length();
- int outc=0;
- TQChar *to = result.d->tqunicode;
- for (;;) {
- while ( from!=fromend && from->isSpace() )
- from++;
- while ( from!=fromend && !from->isSpace() )
- to[outc++] = *from++;
- if ( from!=fromend )
- to[outc++] = ' ';
- else
- break;
- }
- if ( outc > 0 && to[outc-1] == ' ' )
- outc--;
- result.truncate( outc );
- return result;
-}
-
-
-/*!
- Inserts \a s into the string at position \a index.
-
- If \a index is beyond the end of the string, the string is
- extended with spaces to length \a index and \a s is then appended
- and returns a reference to the string.
-
- \code
- TQString string( "I like fish" );
- str = string.insert( 2, "don't " );
- // str == "I don't like fish"
- \endcode
-
- \sa remove(), replace()
-*/
-
-TQString &TQString::insert( uint index, const TQString &s )
-{
- // the sub function takes care of &s == this case.
- return insert( index, s.tqunicode(), s.length() );
-}
-
-/*! \fn TQString &TQString::insert( uint index, const TQByteArray &s )
- \overload
-
- Inserts \a s into the string at position \a index and returns
- a reference to the string.
-*/
-
-/*! \fn TQString &TQString::insert( uint index, const char *s )
- \overload
-
- Inserts \a s into the string at position \a index and returns
- a reference to the string.
-*/
-
-#ifndef TQT_NO_CAST_ASCII
-TQString &TQString::insertHelper( uint index, const char *s, uint len )
-{
- if ( s ) {
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() )
- return insert( index, fromAscii( s, len ) );
-#endif
- if ( len == UINT_MAX )
- len = int(strlen( s ));
- if ( len == 0 )
- return *this;
-
- uint olen = length();
- int nlen = olen + len;
-
- if ( index >= olen ) { // insert after end of string
- grow( len + index );
- int n = index - olen;
- TQChar* uc = d->tqunicode + olen;
- while ( n-- )
- *uc++ = ' ';
-
- uc = d->tqunicode + index;
- while ( len-- )
- *uc++ = *s++;
- } else { // normal insert
- grow( nlen );
- memmove( d->tqunicode + index + len, tqunicode() + index,
- sizeof(TQChar) * (olen - index) );
-
- TQChar* uc = d->tqunicode + index;
- while ( len-- )
- *uc++ = *s++;
- }
- }
- return *this;
-}
-#endif
-
-/*!
- \overload
-
- Inserts the first \a len characters in \a s into the string at
- position \a index and returns a reference to the string.
-*/
-
-TQString &TQString::insert( uint index, const TQChar* s, uint len )
-{
- if ( len == 0 )
- return *this;
- uint olen = length();
- int nlen = olen + len;
-
- if ( s >= d->tqunicode && (uint)(s - d->tqunicode) < d->maxl ) {
- // Part of me - take a copy.
- TQChar *tmp = TQT_ALLOC_TQCHAR_VEC( len );
- memcpy(tmp,s,len*sizeof(TQChar));
- insert(index,tmp,len);
- TQT_DELETE_TQCHAR_VEC( tmp );
- return *this;
- }
-
- if ( index >= olen ) { // insert after end of string
- grow( len + index );
- int n = index - olen;
- TQChar* uc = d->tqunicode+olen;
- while (n--)
- *uc++ = ' ';
- memcpy( d->tqunicode+index, s, sizeof(TQChar)*len );
- } else { // normal insert
- grow( nlen );
- memmove( d->tqunicode + index + len, tqunicode() + index,
- sizeof(TQChar) * (olen - index) );
- memcpy( d->tqunicode + index, s, sizeof(TQChar) * len );
- }
- return *this;
-}
-
-/*!
- \overload
-
- Insert \a c into the string at position \a index and returns a
- reference to the string.
-
- If \a index is beyond the end of the string, the string is
- extended with spaces (ASCII 32) to length \a index and \a c is
- then appended.
-*/
-
-TQString &TQString::insert( uint index, TQChar c ) // insert char
-{
- TQString s( c );
- return insert( index, s );
-}
-
-/*!
- \fn TQString& TQString::insert( uint index, char c )
-
- \overload
-
- Insert character \a c at position \a index.
-*/
-
-/*!
- \fn TQString &TQString::prepend( const TQString &s )
-
- Inserts \a s at the beginning of the string and returns a
- reference to the string.
-
- Equivalent to insert(0, \a s).
-
- \code
- TQString string = "42";
- string.prepend( "The answer is " );
- // string == "The answer is 42"
- \endcode
-
- \sa insert()
-*/
-
-/*!
- \fn TQString& TQString::prepend( char ch )
-
- \overload
-
- Inserts \a ch at the beginning of the string and returns a
- reference to the string.
-
- Equivalent to insert(0, \a ch).
-
- \sa insert()
-*/
-
-/*!
- \fn TQString& TQString::prepend( TQChar ch )
-
- \overload
-
- Inserts \a ch at the beginning of the string and returns a
- reference to the string.
-
- Equivalent to insert(0, \a ch).
-
- \sa insert()
-*/
-
-/*! \fn TQString& TQString::prepend( const TQByteArray &s )
- \overload
-
- Inserts \a s at the beginning of the string and returns a reference to the string.
-
- Equivalent to insert(0, \a s).
-
- \sa insert()
- */
-
-/*! \fn TQString& TQString::prepend( const std::string &s )
- \overload
-
- Inserts \a s at the beginning of the string and returns a reference to the string.
-
- Equivalent to insert(0, \a s).
-
- \sa insert()
-*/
-
-/*!
- \overload
-
- Inserts \a s at the beginning of the string and returns a reference to the string.
-
- Equivalent to insert(0, \a s).
-
- \sa insert()
- */
-TQString &TQString::prepend( const char *s )
-{
- return insert( 0, TQString(s) );
-}
-
-/*!
- Removes \a len characters from the string starting at position \a
- index, and returns a reference to the string.
-
- If \a index is beyond the length of the string, nothing happens.
- If \a index is within the string, but \a index + \a len is beyond
- the end of the string, the string is truncated at position \a
- index.
-
- \code
- TQString string( "Montreal" );
- string.remove( 1, 4 ); // string == "Meal"
- \endcode
-
- \sa insert(), replace()
-*/
-
-TQString &TQString::remove( uint index, uint len )
-{
- uint olen = length();
- if ( index >= olen ) {
- // range problems
- } else if ( index + len >= olen ) { // index ok
- setLength( index );
- } else if ( len != 0 ) {
- real_detach();
- memmove( d->tqunicode+index, d->tqunicode+index+len,
- sizeof(TQChar)*(olen-index-len) );
- setLength( olen-len );
- }
- return *this;
-}
-
-/*! \overload
-
- Removes every occurrence of the character \a c in the string.
- Returns a reference to the string.
-
- This is the same as replace(\a c, "").
-*/
-TQString &TQString::remove( TQChar c )
-{
- int i = 0;
- while ( i < (int) length() ) {
- if ( constref(i) == c ) {
- remove( i, 1 );
- } else {
- i++;
- }
- }
- return *this;
-}
-
-/*! \overload
-
- \fn TQString &TQString::remove( char c )
-
- Removes every occurrence of the character \a c in the string.
- Returns a reference to the string.
-
- This is the same as replace(\a c, "").
-*/
-
-/*! \overload
-
- Removes every occurrence of \a str in the string. Returns a
- reference to the string.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- This is the same as replace(\a str, "", \a cs).
-*/
-TQString &TQString::remove( const TQString & str, bool cs )
-{
- if ( str.isEmpty() ) {
- if ( isNull() )
- real_detach();
- } else {
- int index = 0;
- while ( (index = find(str, index, cs)) != -1 )
- remove( index, str.length() );
- }
- return *this;
-}
-
-TQString &TQString::remove( const TQString & str )
-{
- return remove( str, TRUE );
-}
-
-/*! \overload
-
- Replaces every occurrence of \a c1 with the char \a c2. Returns a
- reference to the string.
-*/
-TQString &TQString::replace( TQChar c1, TQChar c2 )
-{
- if ( isEmpty() )
- return *this;
-
- real_detach();
- uint i = 0;
- while ( i < d->len ) {
- if ( d->tqunicode[i] == c1 )
- d->tqunicode[i] = c2;
- i++;
- }
- return *this;
-}
-
-#ifndef TQT_NO_REGEXP_CAPTURE
-
-/*! \overload
-
- Removes every occurrence of the regular expression \a rx in the
- string. Returns a reference to the string.
-
- This is the same as replace(\a rx, "").
-*/
-
-TQString &TQString::remove( const TQRegExp & rx )
-{
- return replace( rx, TQString::null );
-}
-
-#endif
-
-/*!
- \overload
-
- Removes every occurrence of \a str in the string. Returns a
- reference to the string.
-*/
-TQString &TQString::remove( const char *str )
-{
- return remove( TQString::fromAscii(str), TRUE );
-}
-
-/*!
- Replaces \a len characters from the string with \a s, starting at
- position \a index, and returns a reference to the string.
-
- If \a index is beyond the length of the string, nothing is deleted
- and \a s is appended at the end of the string. If \a index is
- valid, but \a index + \a len is beyond the end of the string,
- the string is truncated at position \a index, then \a s is
- appended at the end.
-
- \code
- TQString string( "Say yes!" );
- string = string.replace( 4, 3, "NO" );
- // string == "Say NO!"
- \endcode
-
- \warning TQt 3.3.3 and earlier had different semantics for the
- case \a index >= length(), which contradicted the documentation.
- To avoid portability problems between TQt 3 versions and with TQt
- 4, we recommend that you never call the function with \a index >=
- length().
-
- \sa insert(), remove()
-*/
-
-TQString &TQString::replace( uint index, uint len, const TQString &s )
-{
- return replace( index, len, s.tqunicode(), s.length() );
-}
-
-/*! \overload
-
- This is the same as replace(\a index, \a len, TQString(\a c)).
-*/
-TQString &TQString::replace( uint index, uint len, TQChar c )
-{
- return replace( index, len, &c, 1 );
-}
-
-/*! \overload
- \fn TQString &TQString::replace( uint index, uint len, char c )
-
- This is the same as replace(\a index, \a len, TQChar(\a c)).
-*/
-
-/*!
- \overload
-
- Replaces \a len characters with \a slen characters of TQChar data
- from \a s, starting at position \a index, and returns a reference
- to the string.
-
- \sa insert(), remove()
-*/
-
-TQString &TQString::replace( uint index, uint len, const TQChar* s, uint slen )
-{
- if (index > length())
- index = length();
- real_detach();
- if ( len == slen && index + len <= length() ) {
- // Optimized common case: replace without size change
- memcpy( d->tqunicode+index, s, len * sizeof(TQChar) );
- } else if ( s >= d->tqunicode && (uint)(s - d->tqunicode) < d->maxl ) {
- // Part of me - take a copy.
- TQChar *tmp = TQT_ALLOC_TQCHAR_VEC( slen );
- memcpy( tmp, s, slen * sizeof(TQChar) );
- replace( index, len, tmp, slen );
- TQT_DELETE_TQCHAR_VEC( tmp );
- } else {
- remove( index, len );
- insert( index, s, slen );
- }
- return *this;
-}
-
-/*! \overload
-
- Replaces every occurrence of the character \a c in the string
- with \a after. Returns a reference to the string.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- Example:
- \code
- TQString s = "a,b,c";
- s.replace( TQChar(','), " or " );
- // s == "a or b or c"
- \endcode
-*/
-TQString &TQString::replace( TQChar c, const TQString & after, bool cs )
-{
- return replace( TQString( c ), after, cs );
-}
-
-TQString &TQString::replace( TQChar c, const TQString & after )
-{
- return replace( TQString( c ), after, TRUE );
-}
-
-/*! \overload
- \fn TQString &TQString::replace( char c, const TQString & after, bool cs )
-
- Replaces every occurrence of the character \a c in the string
- with \a after. Returns a reference to the string.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-*/
-
-/*! \overload
-
- Replaces every occurrence of the string \a before in the string
- with the string \a after. Returns a reference to the string.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- Example:
- \code
- TQString s = "Greek is Greek";
- s.replace( "Greek", "English" );
- // s == "English is English"
- \endcode
-*/
-TQString &TQString::replace( const TQString & before, const TQString & after,
- bool cs )
-{
- if ( isEmpty() ) {
- if ( !before.isEmpty() )
- return *this;
- } else {
- if ( cs && before == after )
- return *this;
- }
-
- real_detach();
-
- int index = 0;
- uint skiptable[256];
- bm_init_skiptable( before, skiptable, cs );
- const int bl = before.length();
- const int al = after.length();
-
- if ( bl == al ) {
- if ( bl ) {
- const TQChar *auc = after.tqunicode();
- while ( (index = bm_find(*this, index, before, skiptable, cs) ) != -1 ) {
- memcpy( d->tqunicode + index, auc, al * sizeof(TQChar) );
- index += bl;
- }
- }
- } else if ( al < bl ) {
- const TQChar *auc = after.tqunicode();
- uint to = 0;
- uint movestart = 0;
- uint num = 0;
- while ( (index = bm_find(*this, index, before, skiptable, cs)) != -1 ) {
- if ( num ) {
- int msize = index - movestart;
- if ( msize > 0 ) {
- memmove( d->tqunicode + to, d->tqunicode + movestart, msize*sizeof(TQChar) );
- to += msize;
- }
- } else {
- to = index;
- }
- if ( al ) {
- memcpy( d->tqunicode+to, auc, al*sizeof(TQChar) );
- to += al;
- }
- index += bl;
- movestart = index;
- num++;
- }
- if ( num ) {
- int msize = d->len - movestart;
- if ( msize > 0 )
- memmove( d->tqunicode + to, d->tqunicode + movestart, msize*sizeof(TQChar) );
- setLength( d->len - num*(bl-al) );
- }
- } else {
- // the most complex case. We don't want to loose performance by doing repeated
- // copies and reallocs of the string.
- while ( index != -1 ) {
- uint indices[4096];
- uint pos = 0;
- while ( pos < 4095 ) {
- index = bm_find( *this, index, before, skiptable, cs );
- if ( index == -1 )
- break;
- indices[pos++] = index;
- index += bl;
- // avoid infinite loop
- if ( !bl )
- index++;
- }
- if ( !pos )
- break;
-
- // we have a table of replacement positions, use them for fast replacing
- int adjust = pos*(al-bl);
- // index has to be adjusted in case we get back into the loop above.
- if ( index != -1 )
- index += adjust;
- uint newlen = d->len + adjust;
- int moveend = d->len;
- if ( newlen > d->len )
- setLength( newlen );
-
- while ( pos ) {
- pos--;
- int movestart = indices[pos] + bl;
- int insertstart = indices[pos] + pos*(al-bl);
- int moveto = insertstart + al;
- memmove( d->tqunicode + moveto, d->tqunicode + movestart, (moveend - movestart)*sizeof(TQChar) );
- memcpy( d->tqunicode + insertstart, after.tqunicode(), al*sizeof(TQChar) );
- moveend = movestart-bl;
- }
- }
- }
- return *this;
-}
-
-TQString &TQString::replace( const TQString & before, const TQString & after )
-{
- return replace( before, after, TRUE );
-}
-
-#ifndef TQT_NO_REGEXP_CAPTURE
-/*! \overload
-
- Replaces every occurrence of the regexp \a rx in the string with
- \a after. Returns a reference to the string. For example:
- \code
- TQString s = "banana";
- s.replace( TQRegExp("an"), "" );
- // s == "ba"
- \endcode
-
- For regexps containing \link tqregexp.html#capturing-text capturing
- parentheses \endlink, occurrences of <b>\\1</b>, <b>\\2</b>, ...,
- in \a after are replaced with \a{rx}.cap(1), cap(2), ...
-
- \code
- TQString t = "A <i>bon mot</i>.";
- t.replace( TQRegExp("<i>([^<]*)</i>"), "\\emph{\\1}" );
- // t == "A \\emph{bon mot}."
- \endcode
-
- \sa find(), findRev(), TQRegExp::cap()
-*/
-
-TQString &TQString::replace( const TQRegExp &rx, const TQString &after )
-{
- TQRegExp rx2 = rx;
-
- if ( isEmpty() && rx2.search(*this) == -1 )
- return *this;
-
- real_detach();
-
- int index = 0;
- int numCaptures = rx2.numCaptures();
- int al = after.length();
- TQRegExp::CaretMode caretMode = TQRegExp::CaretAtZero;
-
- if ( numCaptures > 0 ) {
- if ( numCaptures > 9 )
- numCaptures = 9;
-
- const TQChar *uc = after.tqunicode();
- int numBackRefs = 0;
-
- for ( int i = 0; i < al - 1; i++ ) {
- if ( uc[i] == '\\' ) {
- int no = uc[i + 1].digitValue();
- if ( no > 0 && no <= numCaptures )
- numBackRefs++;
- }
- }
-
- /*
- This is the harder case where we have back-references.
- We don't try to optimize it.
- */
- if ( numBackRefs > 0 ) {
- int *capturePositions = new int[numBackRefs];
- int *captureNumbers = new int[numBackRefs];
- int j = 0;
-
- for ( int i = 0; i < al - 1; i++ ) {
- if ( uc[i] == '\\' ) {
- int no = uc[i + 1].digitValue();
- if ( no > 0 && no <= numCaptures ) {
- capturePositions[j] = i;
- captureNumbers[j] = no;
- j++;
- }
- }
- }
-
- while ( index <= (int)length() ) {
- index = rx2.search( *this, index, caretMode );
- if ( index == -1 )
- break;
-
- TQString after2 = after;
- for ( j = numBackRefs - 1; j >= 0; j-- )
- after2.replace( capturePositions[j], 2,
- rx2.cap(captureNumbers[j]) );
-
- replace( index, rx2.matchedLength(), after2 );
- index += after2.length();
-
- if ( rx2.matchedLength() == 0 ) {
- // avoid infinite loop on 0-length matches (e.g., [a-z]*)
- index++;
- }
- caretMode = TQRegExp::CaretWontMatch;
- }
- delete[] capturePositions;
- delete[] captureNumbers;
- return *this;
- }
- }
-
- /*
- This is the simple and optimized case where we don't have
- back-references.
- */
- while ( index != -1 ) {
- struct {
- int pos;
- int length;
- } replacements[2048];
-
- uint pos = 0;
- int adjust = 0;
- while ( pos < 2047 ) {
- index = rx2.search( *this, index, caretMode );
- if ( index == -1 )
- break;
- int ml = rx2.matchedLength();
- replacements[pos].pos = index;
- replacements[pos++].length = ml;
- index += ml;
- adjust += al - ml;
- // avoid infinite loop
- if ( !ml )
- index++;
- }
- if ( !pos )
- break;
- replacements[pos].pos = d->len;
- uint newlen = d->len + adjust;
-
- // to continue searching at the right position after we did
- // the first round of replacements
- if ( index != -1 )
- index += adjust;
- TQChar *newuc = TQT_ALLOC_TQCHAR_VEC( newlen + 1 );
- TQChar *uc = newuc;
- int copystart = 0;
- uint i = 0;
- while ( i < pos ) {
- int copyend = replacements[i].pos;
- int size = copyend - copystart;
- memcpy( uc, d->tqunicode + copystart, size * sizeof(TQChar) );
- uc += size;
- memcpy( uc, after.tqunicode(), al * sizeof(TQChar) );
- uc += al;
- copystart = copyend + replacements[i].length;
- i++;
- }
- memcpy( uc, d->tqunicode + copystart,
- (d->len - copystart) * sizeof(TQChar) );
- TQT_DELETE_TQCHAR_VEC( d->tqunicode );
- d->tqunicode = newuc;
- d->len = newlen;
- d->maxl = newlen + 1;
- d->setDirty();
- caretMode = TQRegExp::CaretWontMatch;
- }
- return *this;
-}
-#endif
-
-#ifndef TQT_NO_REGEXP
-/*!
- Finds the first match of the regular expression \a rx, starting
- from position \a index. If \a index is -1, the search starts at
- the last character; if -2, at the next to last character and so
- on. (See findRev() for searching backwards.)
-
- Returns the position of the first match of \a rx or -1 if no match
- was found.
-
- \code
- TQString string( "bananas" );
- int i = string.find( TQRegExp("an"), 0 ); // i == 1
- \endcode
-
- \sa findRev() replace() contains()
-*/
-
-int TQString::find( const TQRegExp &rx, int index ) const
-{
- return rx.search( *this, index );
-}
-
-/*!
- \overload
-
- Finds the first match of the regexp \a rx, starting at position \a
- index and searching backwards. If the index is -1, the search
- starts at the last character, if it is -2, at the next to last
- character and so on. (See findRev() for searching backwards.)
-
- Returns the position of the match or -1 if no match was found.
-
- \code
- TQString string( "bananas" );
- int i = string.findRev( TQRegExp("an") ); // i == 3
- \endcode
-
- \sa find()
-*/
-
-int TQString::findRev( const TQRegExp &rx, int index ) const
-{
- return rx.searchRev( *this, index );
-}
-
-/*!
- \overload
-
- Returns the number of times the regexp, \a rx, matches in the
- string.
-
- This function counts overlapping matches, so in the example below,
- there are four instances of "ana" or "ama".
-
- \code
- TQString str = "banana and panama";
- TQRegExp rxp = TQRegExp( "a[nm]a", TRUE, FALSE );
- int i = str.contains( rxp ); // i == 4
- \endcode
-
- \sa find() findRev()
-*/
-
-int TQString::contains( const TQRegExp &rx ) const
-{
- int count = 0;
- int index = -1;
- int len = length();
- while ( index < len - 1 ) { // count overlapping matches
- index = rx.search( *this, index + 1 );
- if ( index == -1 )
- break;
- count++;
- }
- return count;
-}
-
-#endif //TQT_NO_REGEXP
-
-/*!
- Returns the string converted to a \c long using base \a
- base, which is 10 by default and must be between 2 and 36 or 0. If
- \a base is 0, the base is determined automatically using the
- following rules:
- <ul>
- <li>If the string begins with "0x", it is assumed to
- be hexadecimal;
- <li>If it begins with "0", it is assumed to be octal;
- <li>Otherwise it is assumed to be decimal.
- </ul>
-
- Returns 0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- Leading and trailing whitespace is ignored by this function.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \sa number()
-*/
-
-long TQString::toLong( bool *ok, int base ) const
-{
- TQ_LLONG v = toLongLong( ok, base );
- if ( v < LONG_MIN || v > LONG_MAX ) {
- if ( ok )
- *ok = FALSE;
- v = 0;
- }
- return long(v);
-}
-
-/*!
- Returns the string converted to a \c {long long} using base \a
- base, which is 10 by default and must be between 2 and 36 or 0. If
- \a base is 0, the base is determined automatically using the
- following rules:
- <ul>
- <li>If the string begins with "0x", it is assumed to
- be hexadecimal;
- <li>If it begins with "0", it is assumed to be octal;
- <li>Otherwise it is assumed to be decimal.
- </ul>
-
- Returns 0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- Leading and trailing whitespace is ignored by this function.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \sa number()
-*/
-
-TQ_LLONG TQString::toLongLong( bool *ok, int base ) const
-{
-#if defined(TQT_CHECK_RANGE)
- if ( base != 0 && (base < 2 || base > 36) ) {
- qWarning( "TQString::toLongLong: Invalid base (%d)", base );
- base = 10;
- }
-#endif
-
- bool my_ok;
- TQLocale def_locale;
- TQ_LLONG result = def_locale.d->stringToLongLong(*this, base, &my_ok, TQLocalePrivate::FailOnGroupSeparators);
- if (my_ok) {
- if (ok != 0)
- *ok = TRUE;
- return result;
- }
-
- // If the default was not "C", try the "C" locale
- if (def_locale.language() == TQLocale::C) {
- if (ok != 0)
- *ok = FALSE;
- return 0;
- }
-
- TQLocale c_locale(TQLocale::C);
- return c_locale.d->stringToLongLong(*this, base, ok, TQLocalePrivate::FailOnGroupSeparators);
-}
-
-/*!
- Returns the string converted to an \c {unsigned long} using base \a
- base, which is 10 by default and must be between 2 and 36 or 0. If
- \a base is 0, the base is determined automatically using the
- following rules:
- <ul>
- <li>If the string begins with "0x", it is assumed to
- be hexadecimal;
- <li>If it begins with "0", it is assumed to be octal;
- <li>Otherwise it is assumed to be decimal.
- </ul>
-
- Returns 0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- Leading and trailing whitespace is ignored by this function.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \sa number()
-*/
-
-ulong TQString::toULong( bool *ok, int base ) const
-{
- TQ_ULLONG v = toULongLong( ok, base );
- if ( v > ULONG_MAX ) {
- if ( ok )
- *ok = FALSE;
- v = 0;
- }
- return ulong(v);
-}
-
-/*!
- Returns the string converted to an \c {unsigned long long} using base \a
- base, which is 10 by default and must be between 2 and 36 or 0. If
- \a base is 0, the base is determined automatically using the
- following rules:
- <ul>
- <li>If the string begins with "0x", it is assumed to
- be hexadecimal;
- <li>If it begins with "0", it is assumed to be octal;
- <li>Otherwise it is assumed to be decimal.
- </ul>
-
- Returns 0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- Leading and trailing whitespace is ignored by this function.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \sa number()
-*/
-
-TQ_ULLONG TQString::toULongLong( bool *ok, int base ) const
-{
-#if defined(TQT_CHECK_RANGE)
- if ( base != 0 && (base < 2 || base > 36) ) {
- qWarning( "TQString::toULongLong: Invalid base %d", base );
- base = 10;
- }
-#endif
-
- bool my_ok;
- TQLocale def_locale;
- TQ_ULLONG result = def_locale.d->stringToUnsLongLong(*this, base, &my_ok, TQLocalePrivate::FailOnGroupSeparators);
- if (my_ok) {
- if (ok != 0)
- *ok = TRUE;
- return result;
- }
-
- // If the default was not "C", try the "C" locale
- if (def_locale.language() == TQLocale::C) {
- if (ok != 0)
- *ok = FALSE;
- return 0;
- }
-
- TQLocale c_locale(TQLocale::C);
- return c_locale.d->stringToUnsLongLong(*this, base, ok, TQLocalePrivate::FailOnGroupSeparators);
-}
-
-/*!
- Returns the string converted to a \c short using base \a
- base, which is 10 by default and must be between 2 and 36 or 0. If
- \a base is 0, the base is determined automatically using the
- following rules:
- <ul>
- <li>If the string begins with "0x", it is assumed to
- be hexadecimal;
- <li>If it begins with "0", it is assumed to be octal;
- <li>Otherwise it is assumed to be decimal.
- </ul>
-
-
- Returns 0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- Leading and trailing whitespace is ignored by this function.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \sa number()
-*/
-
-
-short TQString::toShort( bool *ok, int base ) const
-{
- TQ_LLONG v = toLongLong( ok, base );
- if ( v < SHRT_MIN || v > SHRT_MAX ) {
- if ( ok )
- *ok = FALSE;
- v = 0;
- }
- return (short)v;
-}
-
-/*!
- Returns the string converted to an \c {unsigned short} using base \a
- base, which is 10 by default and must be between 2 and 36 or 0. If
- \a base is 0, the base is determined automatically using the
- following rules:
- <ul>
- <li>If the string begins with "0x", it is assumed to
- be hexadecimal;
- <li>If it begins with "0", it is assumed to be octal;
- <li>Otherwise it is assumed to be decimal.
- </ul>
-
-
- Returns 0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- Leading and trailing whitespace is ignored by this function.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \sa number()
-*/
-
-ushort TQString::toUShort( bool *ok, int base ) const
-{
- TQ_ULLONG v = toULongLong( ok, base );
- if ( v > USHRT_MAX ) {
- if ( ok )
- *ok = FALSE;
- v = 0;
- }
- return (ushort)v;
-}
-
-
-/*!
- Returns the string converted to an \c int using base \a
- base, which is 10 by default and must be between 2 and 36 or 0. If
- \a base is 0, the base is determined automatically using the
- following rules:
- <ul>
- <li>If the string begins with "0x", it is assumed to
- be hexadecimal;
- <li>If it begins with "0", it is assumed to be octal;
- <li>Otherwise it is assumed to be decimal.
- </ul>
-
-
- Returns 0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- \code
- TQString str( "FF" );
- bool ok;
- int hex = str.toInt( &ok, 16 ); // hex == 255, ok == TRUE
- int dec = str.toInt( &ok, 10 ); // dec == 0, ok == FALSE
- \endcode
-
- Leading and trailing whitespace is ignored by this function.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \sa number()
-*/
-
-int TQString::toInt( bool *ok, int base ) const
-{
- TQ_LLONG v = toLongLong( ok, base );
- if ( v < INT_MIN || v > INT_MAX ) {
- if ( ok )
- *ok = FALSE;
- v = 0;
- }
- return (int)v;
-}
-
-/*!
- Returns the string converted to an \c {unsigned int} using base \a
- base, which is 10 by default and must be between 2 and 36 or 0. If
- \a base is 0, the base is determined automatically using the
- following rules:
- <ul>
- <li>If the string begins with "0x", it is assumed to
- be hexadecimal;
- <li>If it begins with "0", it is assumed to be octal;
- <li>Otherwise it is assumed to be decimal.
- </ul>
-
- Returns 0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- Leading and trailing whitespace is ignored by this function.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \sa number()
-*/
-
-uint TQString::toUInt( bool *ok, int base ) const
-{
- TQ_ULLONG v = toULongLong( ok, base );
- if ( v > UINT_MAX ) {
- if ( ok )
- *ok = FALSE;
- v = 0;
- }
- return (uint)v;
-}
-
-/*!
- Returns the string converted to a \c double value.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- \code
- TQString string( "1234.56" );
- double a = string.toDouble(); // a == 1234.56
- \endcode
-
- The string-to-number functions:
- \list
- \i toShort()
- \i toUShort()
- \i toInt()
- \i toUInt()
- \i toLong()
- \i toULong()
- \i toLongLong()
- \i toULongLong()
- \i toFloat()
- \i toDouble()
- \endlist
- can handle numbers
- represented in various locales. These representations may use different
- characters for the decimal point, thousands group sepearator
- and even individual digits. TQString's functions try to interpret
- the string according to the current locale. The current locale is
- determined from the system at application startup and can be changed
- by calling TQLocale::setDefault(). If the string cannot be interpreted
- according to the current locale, this function falls back
- on the "C" locale.
-
- \code
- bool ok;
- double d;
-
- TQLocale::setDefault(TQLocale::C);
- d = TQString( "1234,56" ).toDouble(&ok); // ok == false
- d = TQString( "1234.56" ).toDouble(&ok); // ok == true, d == 1234.56
-
- TQLocale::setDefault(TQLocale::German);
- d = TQString( "1234,56" ).toDouble(&ok); // ok == true, d == 1234.56
- d = TQString( "1234.56" ).toDouble(&ok); // ok == true, d == 1234.56
- \endcode
-
- Due to the ambiguity between the decimal point and thousands group
- separator in various locales, these functions do not handle
- thousands group separators. If you need to convert such numbers,
- use the corresponding function in TQLocale.
-
- \code
- bool ok;
- TQLocale::setDefault(TQLocale::C);
- double d = TQString( "1,234,567.89" ).toDouble(&ok); // ok == false
- \endcode
-
- \warning If the string contains trailing whitespace this function
- will fail, and set \a *ok to false if \a ok is not 0. Leading
- whitespace is ignored.
-
- \sa number() TQLocale::setDefault() TQLocale::toDouble() stripWhiteSpace()
-*/
-
-double TQString::toDouble( bool *ok ) const
-{
- // If there is trailing whitespace, set ok to false but return the correct
- // result anyway to preserve behavour of pervious versions of TQt
- if (length() > 0 && tqunicode()[length() - 1].isSpace()) {
- TQString tmp = stripWhiteSpace();
- if (ok != 0)
- *ok = FALSE;
- return tmp.toDouble();
- }
-
- // Try the default locale
- bool my_ok;
- TQLocale def_locale;
- double result = def_locale.d->stringToDouble(*this, &my_ok, TQLocalePrivate::FailOnGroupSeparators);
- if (my_ok) {
- if (ok != 0)
- *ok = TRUE;
- return result;
- }
-
- // If the default was not "C", try the "C" locale
- if (def_locale.language() == TQLocale::C) {
- if (ok != 0)
- *ok = FALSE;
- return 0.0;
- }
-
- TQLocale c_locale(TQLocale::C);
- return c_locale.d->stringToDouble(*this, ok, TQLocalePrivate::FailOnGroupSeparators);
-}
-
-/*!
- Returns the string converted to a \c float value.
-
- Returns 0.0 if the conversion fails.
-
- If \a ok is not 0: if a conversion error occurs, \a *ok is set to
- FALSE; otherwise \a *ok is set to TRUE.
-
- For information on how string-to-number functions in TQString handle
- localized input, see toDouble().
-
- \warning If the string contains trailing whitespace this function
- will fail, settings \a *ok to false if \a ok is not 0.
- Leading whitespace is ignored.
-
- \sa number()
-*/
-
-#define TQT_MAX_FLOAT 3.4028234663852886e+38
-
-float TQString::toFloat( bool *ok ) const
-{
- bool myOk;
- double d = toDouble(&myOk);
- if (!myOk || d > TQT_MAX_FLOAT || d < -TQT_MAX_FLOAT) {
- if (ok != 0)
- *ok = FALSE;
- return 0.0;
- }
- if (ok != 0)
- *ok = TRUE;
- return (float) d;
-}
-
-/*!
- Sets the string to the printed value of \a n in base \a base and
- returns a reference to the string. The returned string is in "C" locale.
-
- The base is 10 by default and must be between 2 and 36.
-
- \code
- TQString string;
- string = string.setNum( 1234 ); // string == "1234"
- \endcode
-*/
-
-TQString &TQString::setNum( TQ_LLONG n, int base )
-{
-#if defined(TQT_CHECK_RANGE)
- if ( base < 2 || base > 36 ) {
- qWarning( "TQString::setNum: Invalid base %d", base );
- base = 10;
- }
-#endif
- TQLocale locale(TQLocale::C);
- *this = locale.d->longLongToString(n, -1, base);
- return *this;
-}
-
-/*!
- \overload
-
- Sets the string to the printed value of \a n in base \a base and
- returns a reference to the string.
-
- The base is 10 by default and must be between 2 and 36.
-*/
-
-TQString &TQString::setNum( TQ_ULLONG n, int base )
-{
-#if defined(TQT_CHECK_RANGE)
- if ( base < 2 || base > 36 ) {
- qWarning( "TQString::setNum: Invalid base %d", base );
- base = 10;
- }
-#endif
- TQLocale locale(TQLocale::C);
- *this = locale.d->unsLongLongToString(n, -1, base);
- return *this;
-}
-
-/*!
- \fn TQString &TQString::setNum( long n, int base )
-
- \overload
-*/
-// ### 4.0: inline
-TQString &TQString::setNum( long n, int base )
-{
- return setNum( (TQ_LLONG)n, base );
-}
-
-/*!
- \fn TQString &TQString::setNum( ulong n, int base )
-
- \overload
-*/
-// ### 4.0: inline
-TQString &TQString::setNum( ulong n, int base )
-{
- return setNum( (TQ_ULLONG)n, base );
-}
-
-/*!
- \fn TQString &TQString::setNum( int n, int base )
-
- \overload
-
- Sets the string to the printed value of \a n in base \a base and
- returns a reference to the string.
-
- The base is 10 by default and must be between 2 and 36.
-*/
-
-/*!
- \fn TQString &TQString::setNum( uint n, int base )
-
- \overload
-
- Sets the string to the printed value of \a n in base \a base and
- returns a reference to the string.
-
- The base is 10 by default and must be between 2 and 36.
-*/
-
-/*!
- \fn TQString &TQString::setNum( short n, int base )
-
- \overload
-
- Sets the string to the printed value of \a n in base \a base and
- returns a reference to the string.
-
- The base is 10 by default and must be between 2 and 36.
-*/
-
-/*!
- \fn TQString &TQString::setNum( ushort n, int base )
-
- \overload
-
- Sets the string to the printed value of \a n in base \a base and
- returns a reference to the string.
-
- The base is 10 by default and must be between 2 and 36.
-*/
-
-/*!
- \overload
-
- Sets the string to the printed value of \a n, formatted in format
- \a f with precision \a prec, and returns a reference to the
- string.
-
- The format \a f can be 'f', 'F', 'e', 'E', 'g' or 'G'. See \link
- #arg-formats arg \endlink() for an explanation of the formats.
-*/
-
-TQString &TQString::setNum( double n, char f, int prec )
-{
- TQLocalePrivate::DoubleForm form = TQLocalePrivate::DFDecimal;
- uint flags = 0;
-
- if (qIsUpper(f))
- flags = TQLocalePrivate::CapitalEorX;
- f = qToLower(f);
-
- switch (f) {
- case 'f':
- form = TQLocalePrivate::DFDecimal;
- break;
- case 'e':
- form = TQLocalePrivate::DFExponent;
- break;
- case 'g':
- form = TQLocalePrivate::DFSignificantDigits;
- break;
- default:
-#if defined(TQT_CHECK_RANGE)
- qWarning( "TQString::setNum: Invalid format char '%c'", f );
-#endif
- break;
- }
-
- TQLocale locale(TQLocale::C);
- *this = locale.d->doubleToString(n, prec, form, -1, flags);
- return *this;
-}
-
-/*!
- \fn TQString &TQString::setNum( float n, char f, int prec )
-
- \overload
-
- Sets the string to the printed value of \a n, formatted in format
- \a f with precision \a prec, and returns a reference to the
- string.
-
- The format \a f can be 'f', 'F', 'e', 'E', 'g' or 'G'. See \link
- #arg-formats arg \endlink() for an explanation of the formats.
-*/
-
-
-/*!
- A convenience function that returns a string equivalent of the
- number \a n to base \a base, which is 10 by default and must be
- between 2 and 36. The returned string is in "C" locale.
-
- \code
- long a = 63;
- TQString str = TQString::number( a, 16 ); // str == "3f"
- TQString str = TQString::number( a, 16 ).upper(); // str == "3F"
- \endcode
-
- \sa setNum()
-*/
-TQString TQString::number( long n, int base )
-{
- TQString s;
- s.setNum( n, base );
- return s;
-}
-
-/*!
- \overload
-
- \sa setNum()
-*/
-TQString TQString::number( ulong n, int base )
-{
- TQString s;
- s.setNum( n, base );
- return s;
-}
-
-/*!
- \overload
-
- \sa setNum()
-*/
-TQString TQString::number( TQ_LLONG n, int base )
-{
- TQString s;
- s.setNum( n, base );
- return s;
-}
-
-/*!
- \overload
-
- \sa setNum()
-*/
-TQString TQString::number( TQ_ULLONG n, int base )
-{
- TQString s;
- s.setNum( n, base );
- return s;
-}
-
-/*!
- \overload
-
- \sa setNum()
-*/
-TQString TQString::number( int n, int base )
-{
- TQString s;
- s.setNum( n, base );
- return s;
-}
-
-/*!
- \overload
-
- A convenience factory function that returns a string
- representation of the number \a n to the base \a base, which is 10
- by default and must be between 2 and 36.
-
- \sa setNum()
-*/
-TQString TQString::number( uint n, int base )
-{
- TQString s;
- s.setNum( n, base );
- return s;
-}
-
-/*!
- \overload
-
- Argument \a n is formatted according to the \a f format specified,
- which is \c g by default, and can be any of the following:
-
- \table
- \header \i Format \i Meaning
- \row \i \c e \i format as [-]9.9e[+|-]999
- \row \i \c E \i format as [-]9.9E[+|-]999
- \row \i \c f \i format as [-]9.9
- \row \i \c g \i use \c e or \c f format, whichever is the most concise
- \row \i \c G \i use \c E or \c f format, whichever is the most concise
- \endtable
-
- With 'e', 'E', and 'f', \a prec is the number of digits after the
- decimal point. With 'g' and 'G', \a prec is the maximum number of
- significant digits (trailing zeroes are omitted).
-
- \code
- double d = 12.34;
- TQString ds = TQString( "'E' format, precision 3, gives %1" )
- .arg( d, 0, 'E', 3 );
- // ds == "1.234E+001"
- \endcode
-
- \sa setNum()
- */
-TQString TQString::number( double n, char f, int prec )
-{
- TQString s;
- s.setNum( n, f, prec );
- return s;
-}
-
-
-/*! \obsolete
-
- Sets the character at position \a index to \a c and expands the
- string if necessary, filling with spaces.
-
- This method is redundant in TQt 3.x, because operator[] will expand
- the string as necessary.
-*/
-
-void TQString::setExpand( uint index, TQChar c )
-{
- int spaces = index - d->len;
- at(index) = c;
- while (spaces-->0)
- d->tqunicode[--index]=' ';
-}
-
-
-/*!
- \fn const char* TQString::data() const
-
- \obsolete
-
- Returns a pointer to a '\0'-terminated classic C string.
-
- In TQt 1.x, this returned a char* allowing direct manipulation of the
- string as a sequence of bytes. In TQt 2.x where TQString is a Unicode
- string, char* conversion constructs a temporary string, and hence
- direct character operations are meaningless.
-*/
-
-/*!
- \fn bool TQString::operator!() const
-
- Returns TRUE if this is a null string; otherwise returns FALSE.
-
- \code
- TQString name = getName();
- if ( !name )
- name = "Rodney";
- \endcode
-
- Note that if you say
-
- \code
- TQString name = getName();
- if ( name )
- doSomethingWith(name);
- \endcode
-
- It will call "operator const char*()", which is inefficent; you
- may wish to define the macro \c TQT_NO_ASCII_CAST when writing code
- which you wish to remain Unicode-clean.
-
- When you want the above semantics, use:
-
- \code
- TQString name = getName();
- if ( !name.isNull() )
- doSomethingWith(name);
- \endcode
-
- \sa isEmpty()
-*/
-
-
-/*!
- \fn TQString& TQString::append( const TQString& str )
-
- Appends \a str to the string and returns a reference to the
- result.
-
- \code
- string = "Test";
- string.append( "ing" ); // string == "Testing"
- \endcode
-
- Equivalent to operator+=().
-*/
-
-/*!
- \fn TQString& TQString::append( char ch )
-
- \overload
-
- Appends character \a ch to the string and returns a reference to
- the result.
-
- Equivalent to operator+=().
-*/
-
-/*!
- \fn TQString& TQString::append( TQChar ch )
-
- \overload
-
- Appends character \a ch to the string and returns a reference to
- the result.
-
- Equivalent to operator+=().
-*/
-
-/*! \fn TQString& TQString::append( const TQByteArray &str )
- \overload
-
- Appends \a str to the string and returns a reference to the result.
-
- Equivalent to operator+=().
-*/
-
-/*! \fn TQString& TQString::append( const std::string &str )
- \overload
-
- Appends \a str to the string and returns a reference to the result.
-
- Equivalent to operator+=().
-*/
-
-/*! \fn TQString& TQString::append( const char *str )
- \overload
-
- Appends \a str to the string and returns a reference to the result.
-
- Equivalent to operator+=().
-*/
-
-/*!
- Appends \a str to the string and returns a reference to the string.
-*/
-TQString& TQString::operator+=( const TQString &str )
-{
- uint len1 = length();
- uint len2 = str.length();
- if ( len2 ) {
- if ( isEmpty() ) {
- operator=( str );
- } else {
- grow( len1+len2 );
- memcpy( d->tqunicode+len1, str.tqunicode(), sizeof(TQChar)*len2 );
- }
- } else if ( isNull() && !str.isNull() ) { // ## just for 1.x compat:
- *this = tqfromLatin1( "" );
- }
- return *this;
-}
-
-#ifndef TQT_NO_CAST_ASCII
-TQString &TQString::operatorPlusEqHelper( const char *s, uint len2 )
-{
- if ( s ) {
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() )
- return operator+=( fromAscii( s, len2 ) );
-#endif
-
- uint len1 = length();
- if ( len2 == UINT_MAX )
- len2 = int(strlen( s ));
- if ( len2 ) {
- grow( len1 + len2 );
- TQChar* uc = d->tqunicode + len1;
- while ( len2-- )
- *uc++ = *s++;
- } else if ( isNull() ) { // ## just for 1.x compat:
- *this = tqfromLatin1( "" );
- }
- }
- return *this;
-}
-#endif
-
-/*!
- \overload
-
- Appends \a str to the string and returns a reference to the string.
-*/
-#ifndef TQT_NO_CAST_ASCII
-TQString& TQString::operator+=( const char *str )
-{
- // ### TQt 4: make this function inline
- return operatorPlusEqHelper( str );
-}
-#endif
-
-/*! \overload
-
- Appends \a c to the string and returns a reference to the string.
-*/
-
-TQString &TQString::operator+=( TQChar c )
-{
- grow( length()+1 );
- d->tqunicode[length()-1] = c;
- return *this;
-}
-
-/*!
- \overload
-
- Appends \a c to the string and returns a reference to the string.
-*/
-
-TQString &TQString::operator+=( char c )
-{
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() )
- return operator+=( fromAscii( &c, 1 ) );
-#endif
- grow( length()+1 );
- d->tqunicode[length()-1] = c;
- return *this;
-}
-
-/*!
- \fn TQString &TQString::operator+=( const TQByteArray &str )
- \overload
-
- Appends \a str to the string and returns a reference to the string.
-*/
-
-/*!
- \fn TQString &TQString::operator+=( const std::string &str )
- \overload
-
- Appends \a str to the string and returns a reference to the string.
-*/
-
-/*!
- \fn char TQChar::latin1() const
-
- Returns the Latin-1 value of this character, or 0 if it
- cannot be represented in Latin-1.
-*/
-
-
-/*!
- Returns a Latin-1 representation of the string. The
- returned value is undefined if the string contains non-Latin-1
- characters. If you want to convert strings into formats other than
- Unicode, see the TQTextCodec classes.
-
- This function is mainly useful for boot-strapping legacy code to
- use Unicode.
-
- The result remains valid so long as one unmodified copy of the
- source string exists.
-
- \sa tqfromLatin1(), ascii(), utf8(), local8Bit()
-*/
-const char* TQString::latin1() const
-{
- if ( !d->ascii || !d->islatin1 ) {
- delete [] d->ascii;
- d->ascii = tqunicodeToLatin1( d->tqunicode, d->len );
- d->islatin1 = TRUE;
- }
- return d->ascii;
-}
-
-/*!
- Returns an 8-bit ASCII representation of the string.
-
- If a codec has been set using TQTextCodec::codecForCStrings(),
- it is used to convert Unicode to 8-bit char. Otherwise, this function
- does the same as latin1().
-
- \sa fromAscii(), latin1(), utf8(), local8Bit()
-*/
-const char* TQString::ascii() const
-{
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() ) {
- if ( !d->ascii || d->islatin1 ) {
- delete [] d->ascii;
- if (d->tqunicode) {
- TQCString s = TQTextCodec::codecForCStrings()->fromUnicode( *this );
- d->ascii = new char[s.length() + 1];
- memcpy(d->ascii, s.data(), s.length() + 1);
- } else {
- d->ascii = 0;
- }
- d->islatin1 = FALSE;
- }
- return d->ascii;
- }
-#endif // TQT_NO_TEXTCODEC
- return latin1();
-}
-
-/*!
- Returns the string encoded in UTF-8 format.
-
- See TQTextCodec for more diverse coding/decoding of Unicode strings.
-
- \sa fromUtf8(), ascii(), latin1(), local8Bit()
-*/
-TQCString TQString::utf8() const
-{
- int l = length();
- int rlen = l*3+1;
- TQCString rstr(rlen);
- uchar* cursor = (uchar*)rstr.data();
- const TQChar *ch = d->tqunicode;
- for (int i=0; i < l; i++) {
- uint u = ch->tqunicode();
- if ( u < 0x80 ) {
- *cursor++ = (uchar)u;
- } else {
- if ( u < 0x0800 ) {
- *cursor++ = 0xc0 | ((uchar) (u >> 6));
- } else {
- if (u >= 0xd800 && u < 0xdc00 && i < l-1) {
- unsigned short low = ch[1].tqunicode();
- if (low >= 0xdc00 && low < 0xe000) {
- ++ch;
- ++i;
- u = (u - 0xd800)*0x400 + (low - 0xdc00) + 0x10000;
- }
- }
- if (u > 0xffff) {
- // if people are working in utf8, but strings are encoded in eg. latin1, the resulting
- // name might be invalid utf8. This and the corresponding code in fromUtf8 takes care
- // we can handle this without loosing information. This can happen with latin filenames
- // and a utf8 locale under Unix.
- if (u > 0x10fe00 && u < 0x10ff00) {
- *cursor++ = (u - 0x10fe00);
- ++ch;
- continue;
- } else {
- *cursor++ = 0xf0 | ((uchar) (u >> 18));
- *cursor++ = 0x80 | ( ((uchar) (u >> 12)) & 0x3f);
- }
- } else {
- *cursor++ = 0xe0 | ((uchar) (u >> 12));
- }
- *cursor++ = 0x80 | ( ((uchar) (u >> 6)) & 0x3f);
- }
- *cursor++ = 0x80 | ((uchar) (u&0x3f));
- }
- ++ch;
- }
- rstr.truncate( cursor - (uchar*)rstr.data() );
- return rstr;
-}
-
-static TQChar *addOne(TQChar *qch, TQString &str)
-{
- long sidx = qch - str.tqunicode();
- str.setLength(str.length()+1);
- return (TQChar *)str.tqunicode() + sidx;
-}
-
-/*!
- Returns the Unicode string decoded from the first \a len
- bytes of \a utf8, ignoring the rest of \a utf8. If \a len is
- -1 then the length of \a utf8 is used. If \a len is bigger than
- the length of \a utf8 then it will use the length of \a utf8.
-
- \code
- TQString str = TQString::fromUtf8( "123456789", 5 );
- // str == "12345"
- \endcode
-
- See TQTextCodec for more diverse coding/decoding of Unicode strings.
-*/
-TQString TQString::fromUtf8( const char* utf8, int len )
-{
- if ( !utf8 )
- return TQString::null;
-
- int slen = 0;
- if (len >= 0) {
- while (slen < len && utf8[slen])
- slen++;
- } else {
- slen = int(strlen(utf8));
- }
- len = len < 0 ? slen : TQMIN(slen, len);
- TQString result;
- result.setLength( len ); // worst case
- TQChar *qch = (TQChar *)result.tqunicode();
- uint uc = 0;
- uint min_uc = 0;
- int need = 0;
- int error = -1;
- uchar ch;
- for (int i=0; i<len; i++) {
- ch = utf8[i];
- if (need) {
- if ( (ch&0xc0) == 0x80 ) {
- uc = (uc << 6) | (ch & 0x3f);
- need--;
- if ( !need ) {
- if (uc > 0xffff) {
- // surrogate pair
- uc -= 0x10000;
- unsigned short high = uc/0x400 + 0xd800;
- unsigned short low = uc%0x400 + 0xdc00;
- *qch++ = TQChar(high);
- *qch++ = TQChar(low);
- } else if (uc < min_uc || (uc >= 0xd800 && uc <= 0xdfff) || (uc >= 0xfffe)) {
- // overlong seqence, UTF16 surrogate or BOM
- i = error;
- qch = addOne(qch, result);
- *qch++ = TQChar(0xdbff);
- *qch++ = TQChar(0xde00+((uchar)utf8[i]));
- } else {
- *qch++ = uc;
- }
- }
- } else {
- // See TQString::utf8() for explanation.
- //
- // The surrogate below corresponds to a Unicode value of (0x10fe00+ch) which
- // is in one of the private use areas of Unicode.
- i = error;
- qch = addOne(qch, result);
- *qch++ = TQChar(0xdbff);
- *qch++ = TQChar(0xde00+((uchar)utf8[i]));
- need = 0;
- }
- } else {
- if ( ch < 128 ) {
- *qch++ = ch;
- } else if ((ch & 0xe0) == 0xc0) {
- uc = ch & 0x1f;
- need = 1;
- error = i;
- min_uc = 0x80;
- } else if ((ch & 0xf0) == 0xe0) {
- uc = ch & 0x0f;
- need = 2;
- error = i;
- min_uc = 0x800;
- } else if ((ch&0xf8) == 0xf0) {
- uc = ch & 0x07;
- need = 3;
- error = i;
- min_uc = 0x10000;
- } else {
- // Error
- qch = addOne(qch, result);
- *qch++ = TQChar(0xdbff);
- *qch++ = TQChar(0xde00+((uchar)utf8[i]));
- }
- }
- }
- if (need) {
- // we have some invalid characters remaining we need to add to the string
- for (int i = error; i < len; ++i) {
- qch = addOne(qch, result);
- *qch++ = TQChar(0xdbff);
- *qch++ = TQChar(0xde00+((uchar)utf8[i]));
- }
- }
-
- result.truncate( qch - result.tqunicode() );
- return result;
-}
-
-/*!
- Returns the Unicode string decoded from the first \a len
- bytes of \a ascii, ignoring the rest of \a ascii. If \a len
- is -1 then the length of \a ascii is used. If \a len is bigger
- than the length of \a ascii then it will use the length of \a
- ascii.
-
- If a codec has been set using TQTextCodec::codecForCStrings(),
- it is used to convert the string from 8-bit characters to Unicode.
- Otherwise, this function does the same as tqfromLatin1().
-
- This is the same as the TQString(const char*) constructor, but you
- can make that constructor invisible if you compile with the define
- \c TQT_NO_CAST_ASCII, in which case you can explicitly create a
- TQString from 8-bit ASCII text using this function.
-
- \code
- TQString str = TQString::fromAscii( "123456789", 5 );
- // str == "12345"
- \endcode
- */
-TQString TQString::fromAscii( const char* ascii, int len )
-{
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() ) {
- if ( !ascii )
- return TQString::null;
- if ( len < 0 )
- len = (int)strlen( ascii );
- if ( len == 0 || *ascii == '\0' )
- return TQString::tqfromLatin1( "" );
- return TQTextCodec::codecForCStrings()->toUnicode( ascii, len );
- }
-#endif
- return tqfromLatin1( ascii, len );
-}
-
-
-/*!
- Returns the Unicode string decoded from the first \a len
- bytes of \a chars, ignoring the rest of \a chars. If \a len
- is -1 then the length of \a chars is used. If \a len is bigger
- than the length of \a chars then it will use the length of \a
- chars.
-
- \sa fromAscii()
-*/
-TQString TQString::tqfromLatin1( const char* chars, int len )
-{
- uint l;
- TQChar *uc;
- if ( len < 0 )
- len = -1;
- uc = internalLatin1ToUnicode( chars, &l, len );
- return TQString( new TQStringData(uc, l, l), TRUE );
-}
-
-/*!
- \fn const TQChar* TQString::tqunicode() const
-
- Returns the Unicode representation of the string. The result
- remains valid until the string is modified.
-*/
-
-/*!
- Returns the string encoded in a locale-specific format. On X11,
- this is the TQTextCodec::codecForLocale(). On Windows, it is a
- system-defined encoding. On Mac OS X, this always uses UTF-8 as
- the encoding.
-
- See TQTextCodec for more diverse coding/decoding of Unicode
- strings.
-
- \sa fromLocal8Bit(), ascii(), latin1(), utf8()
-*/
-
-TQCString TQString::local8Bit() const
-{
-#ifdef TQT_NO_TEXTCODEC
- return latin1();
-#else
-#ifdef TQ_WS_X11
- TQTextCodec* codec = TQTextCodec::codecForLocale();
- return codec
- ? codec->fromUnicode(*this)
- : TQCString(latin1());
-#endif
-#if defined( TQ_WS_MACX )
- return utf8();
-#endif
-#if defined( TQ_WS_MAC9 )
- return TQCString(latin1()); //I'm evil..
-#endif
-#ifdef TQ_WS_WIN
- return isNull() ? TQCString("") : qt_winTQString2MB( *this );
-#endif
-#ifdef TQ_WS_TQWS
- return utf8(); // ### if there is any 8 bit format supported?
-#endif
-#endif
-}
-
-/*!
- Returns the Unicode string decoded from the first \a len
- bytes of \a local8Bit, ignoring the rest of \a local8Bit. If
- \a len is -1 then the length of \a local8Bit is used. If \a len is
- bigger than the length of \a local8Bit then it will use the length
- of \a local8Bit.
-
- \code
- TQString str = TQString::fromLocal8Bit( "123456789", 5 );
- // str == "12345"
- \endcode
-
- \a local8Bit is assumed to be encoded in a locale-specific format.
-
- See TQTextCodec for more diverse coding/decoding of Unicode strings.
-*/
-TQString TQString::fromLocal8Bit( const char* local8Bit, int len )
-{
-#ifdef TQT_NO_TEXTCODEC
- return tqfromLatin1( local8Bit, len );
-#else
-
- if ( !local8Bit )
- return TQString::null;
-#ifdef TQ_WS_X11
- TQTextCodec* codec = TQTextCodec::codecForLocale();
- if ( len < 0 )
- len = strlen( local8Bit );
- return codec
- ? codec->toUnicode( local8Bit, len )
- : tqfromLatin1( local8Bit, len );
-#endif
-#if defined( TQ_WS_MAC )
- return fromUtf8(local8Bit,len);
-#endif
-// Should this be OS_WIN32?
-#ifdef TQ_WS_WIN
- if ( len >= 0 ) {
- TQCString s(local8Bit,len+1);
- return qt_winMB2TQString(s);
- }
- return qt_winMB2TQString( local8Bit );
-#endif
-#ifdef TQ_WS_TQWS
- return fromUtf8(local8Bit,len);
-#endif
-#endif // TQT_NO_TEXTCODEC
-}
-
-/*!
- \fn TQString::operator const char *() const
-
- Returns ascii(). Be sure to see the warnings documented in the
- ascii() function. Note that for new code which you wish to be
- strictly Unicode-clean, you can define the macro \c
- TQT_NO_ASCII_CAST when compiling your code to hide this function so
- that automatic casts are not done. This has the added advantage
- that you catch the programming error described in operator!().
-*/
-
-/*!
- \fn TQString::operator std::string() const
-
- Returns ascii() as a std::string.
-
- \warning The function may cause an application to crash if a static C run-time is in use.
- This can happen in Microsoft Visual C++ if TQt is configured as single-threaded. A safe
- alternative is to call ascii() directly and construct a std::string manually.
-*/
-
-/*!
- Returns the TQString as a zero terminated array of unsigned shorts
- if the string is not null; otherwise returns zero.
-
- The result remains valid so long as one unmodified
- copy of the source string exists.
-*/
-const unsigned short *TQString::ucs2() const
-{
- if ( ! d->tqunicode )
- return 0;
- unsigned int len = d->len;
- if ( d->maxl < len + 1 ) {
- // detach, grow or shrink
- uint newMax = computeNewMax( len + 1 );
- TQChar* nd = TQT_ALLOC_TQCHAR_VEC( newMax );
- if ( nd ) {
- if ( d->tqunicode )
- memcpy( nd, d->tqunicode, sizeof(TQChar)*len );
- ((TQString *)this)->deref();
- ((TQString *)this)->d = new TQStringData( nd, len, newMax );
- }
- }
- d->tqunicode[len] = 0;
- return (unsigned short *) d->tqunicode;
-}
-
-/*!
- Constructs a string that is a deep copy of \a str, interpreted as a
- UCS2 encoded, zero terminated, Unicode string.
-
- If \a str is 0, then a null string is created.
-
- \sa isNull()
-*/
-TQString TQString::fromUcs2( const unsigned short *str )
-{
- if ( !str ) {
- return TQString::null;
- } else {
- int length = 0;
- while ( str[length] != 0 )
- length++;
- TQChar* uc = TQT_ALLOC_TQCHAR_VEC( length );
- memcpy( uc, str, length*sizeof(TQChar) );
- return TQString( new TQStringData( uc, length, length ), TRUE );
- }
-}
-
-/*!
- \fn TQChar TQString::at( uint ) const
-
- Returns the character at index \a i, or 0 if \a i is beyond the
- length of the string.
-
- \code
- const TQString string( "abcdefgh" );
- TQChar ch = string.at( 4 );
- // ch == 'e'
- \endcode
-
- If the TQString is not const (i.e. const TQString) or const& (i.e.
- const TQString &), then the non-const overload of at() will be used
- instead.
-*/
-
-/*!
- \fn TQChar TQString::constref(uint i) const
-
- Returns the TQChar at index \a i by value.
-
- Equivalent to at(\a i).
-
- \sa ref()
-*/
-
-/*!
- \fn TQChar& TQString::ref(uint i)
-
- Returns the TQChar at index \a i by reference, expanding the string
- with TQChar::null if necessary. The resulting reference can be
- assigned to, or otherwise used immediately, but becomes invalid
- once furher modifications are made to the string.
-
- \code
- TQString string("ABCDEF");
- TQChar ch = string.ref( 3 ); // ch == 'D'
- \endcode
-
- \sa constref()
-*/
-
-/*!
- \fn TQChar TQString::operator[]( int ) const
-
- Returns the character at index \a i, or TQChar::null if \a i is
- beyond the length of the string.
-
- If the TQString is not const (i.e., const TQString) or const\&
- (i.e., const TQString\&), then the non-const overload of operator[]
- will be used instead.
-*/
-
-/*!
- \fn TQCharRef TQString::operator[]( int )
-
- \overload
-
- The function returns a reference to the character at index \a i.
- The resulting reference can then be assigned to, or used
- immediately, but it will become invalid once further modifications
- are made to the original string.
-
- If \a i is beyond the length of the string then the string is
- expanded with TQChar::nulls, so that the TQCharRef references a
- valid (null) character in the string.
-
- The TQCharRef internal class can be used much like a constant
- TQChar, but if you assign to it, you change the original string
- (which will detach itself because of TQString's copy-on-write
- semantics). You will get compilation errors if you try to use the
- result as anything but a TQChar.
-*/
-
-/*!
- \fn TQCharRef TQString::at( uint i )
-
- \overload
-
- The function returns a reference to the character at index \a i.
- The resulting reference can then be assigned to, or used
- immediately, but it will become invalid once further modifications
- are made to the original string.
-
- If \a i is beyond the length of the string then the string is
- expanded with TQChar::null.
-*/
-
-/*
- Internal chunk of code to handle the
- uncommon cases of at() above.
-*/
-void TQString::subat( uint i )
-{
- uint olen = d->len;
- if ( i >= olen ) {
- setLength( i+1 ); // i is index; i+1 is needed length
- for ( uint j=olen; j<=i; j++ )
- d->tqunicode[j] = TQChar::null;
- } else {
- // Just be sure to detach
- real_detach();
- }
-}
-
-
-/*!
- Resizes the string to \a len characters and copies \a tqunicode into
- the string. If \a tqunicode is 0, nothing is copied, but the
- string is still resized to \a len. If \a len is zero, then the
- string becomes a \link isNull() null\endlink string.
-
- \sa setLatin1(), isNull()
-*/
-
-TQString& TQString::setUnicode( const TQChar *tqunicode, uint len )
-{
- if ( len == 0 ) { // set to null string
- if ( d != shared_null ) { // beware of nullstring being set to nullstring
- deref();
- d = shared_null ? shared_null : makeSharedNull();
- d->ref();
- }
- } else if ( d->count != 1 || len > d->maxl ||
- ( len * 4 < d->maxl && d->maxl > 4 ) ) {
- // detach, grown or shrink
- uint newMax = computeNewMax( len );
- TQChar* nd = TQT_ALLOC_TQCHAR_VEC( newMax );
- if ( tqunicode )
- memcpy( nd, tqunicode, sizeof(TQChar)*len );
- deref();
- d = new TQStringData( nd, len, newMax );
- } else {
- d->len = len;
- d->setDirty();
- if ( tqunicode )
- memcpy( d->tqunicode, tqunicode, sizeof(TQChar)*len );
- }
- return *this;
-}
-
-/*!
- Resizes the string to \a len characters and copies \a
- tqunicode_as_ushorts into the string (on some X11 client platforms
- this will involve a byte-swapping pass).
-
- If \a tqunicode_as_ushorts is 0, nothing is copied, but the string
- is still resized to \a len. If \a len is zero, the string becomes
- a \link isNull() null\endlink string.
-
- \sa setLatin1(), isNull()
-*/
-TQString& TQString::setUnicodeCodes( const ushort* tqunicode_as_ushorts, uint len )
-{
- return setUnicode((const TQChar*)tqunicode_as_ushorts, len);
-}
-
-
-/*!
- Sets this string to \a str, interpreted as a classic 8-bit ASCII C
- string. If \a len is -1 (the default), then it is set to
- strlen(str).
-
- If \a str is 0 a null string is created. If \a str is "", an empty
- string is created.
-
- \sa isNull(), isEmpty()
-*/
-
-TQString &TQString::setAscii( const char *str, int len )
-{
-#ifndef TQT_NO_TEXTCODEC
- if ( TQTextCodec::codecForCStrings() ) {
- *this = TQString::fromAscii( str, len );
- return *this;
- }
-#endif // TQT_NO_TEXTCODEC
- return setLatin1( str, len );
-}
-
-/*!
- Sets this string to \a str, interpreted as a classic Latin-1 C
- string. If \a len is -1 (the default), then it is set to
- strlen(str).
-
- If \a str is 0 a null string is created. If \a str is "", an empty
- string is created.
-
- \sa isNull(), isEmpty()
-*/
-
-TQString &TQString::setLatin1( const char *str, int len )
-{
- if ( str == 0 )
- return setUnicode(0,0);
- if ( len < 0 )
- len = int(strlen( str ));
- if ( len == 0 ) { // won't make a null string
- *this = TQString::tqfromLatin1( "" );
- } else {
- setUnicode( 0, len ); // resize but not copy
- TQChar *p = d->tqunicode;
- while ( len-- )
- *p++ = *str++;
- }
- return *this;
-}
-
-/*! \internal
- */
-void TQString::checkSimpleText() const
-{
- TQChar *p = d->tqunicode;
- TQChar *end = p + d->len;
- while ( p < end ) {
- ushort uc = p->tqunicode();
- // sort out regions of complex text formatting
- if ( uc > 0x058f && ( uc < 0x1100 || uc > 0xfb0f ) ) {
- d->issimpletext = FALSE;
- return;
- }
- p++;
- }
- d->issimpletext = TRUE;
-}
-
-/*! \fn bool TQString::simpleText() const
- \internal
-*/
-
-/*! \internal
- */
-bool TQString::isRightToLeft() const
-{
- int len = length();
- TQChar *p = d->tqunicode;
- while ( len-- ) {
- switch( ::direction( *p ) )
- {
- case TQChar::DirL:
- case TQChar::DirLRO:
- case TQChar::DirLRE:
- return FALSE;
- case TQChar::DirR:
- case TQChar::DirAL:
- case TQChar::DirRLO:
- case TQChar::DirRLE:
- return TRUE;
- default:
- break;
- }
- ++p;
- }
- return FALSE;
-}
-
-
-/*!
- \fn int TQString::compare( const TQString & s1, const TQString & s2 )
-
- Lexically compares \a s1 with \a s2 and returns an integer less
- than, equal to, or greater than zero if \a s1 is less than, equal
- to, or greater than \a s2.
-
- The comparison is based exclusively on the numeric Unicode values
- of the characters and is very fast, but is not what a human would
- expect. Consider sorting user-interface strings with
- TQString::localeAwareCompare().
-
- \code
- int a = TQString::compare( "def", "abc" ); // a > 0
- int b = TQString::compare( "abc", "def" ); // b < 0
- int c = TQString::compare( "abc", "abc" ); // c == 0
- \endcode
-*/
-
-/*!
- \overload
-
- Lexically compares this string with \a s and returns an integer
- less than, equal to, or greater than zero if it is less than, equal
- to, or greater than \a s.
-*/
-int TQString::compare( const TQString& s ) const
-{
- return ucstrcmp( *this, s );
-}
-
-/*!
- \fn int TQString::localeAwareCompare( const TQString & s1, const TQString & s2 )
-
- Compares \a s1 with \a s2 and returns an integer less than, equal
- to, or greater than zero if \a s1 is less than, equal to, or
- greater than \a s2.
-
- The comparison is performed in a locale- and also
- platform-dependent manner. Use this function to present sorted
- lists of strings to the user.
-
- \sa TQString::compare() TQTextCodec::locale()
-*/
-
-/*!
- \overload
-
- Compares this string with \a s.
-*/
-
-#if !defined(CSTR_LESS_THAN)
-#define CSTR_LESS_THAN 1
-#define CSTR_ETQUAL 2
-#define CSTR_GREATER_THAN 3
-#endif
-
-int TQString::localeAwareCompare( const TQString& s ) const
-{
- // do the right thing for null and empty
- if ( isEmpty() || s.isEmpty() )
- return compare( s );
-
-#if defined(TQ_WS_WIN)
- int res;
- TQT_WA( {
- const TCHAR* s1 = (TCHAR*)ucs2();
- const TCHAR* s2 = (TCHAR*)s.ucs2();
- res = CompareStringW( LOCALE_USER_DEFAULT, 0, s1, length(), s2, s.length() );
- } , {
- TQCString s1 = local8Bit();
- TQCString s2 = s.local8Bit();
- res = CompareStringA( LOCALE_USER_DEFAULT, 0, s1.data(), s1.length(), s2.data(), s2.length() );
- } );
-
- switch ( res ) {
- case CSTR_LESS_THAN:
- return -1;
- case CSTR_GREATER_THAN:
- return 1;
- default:
- return 0;
- }
-#elif defined(TQ_WS_MACX)
- int delta = 0;
-#if !defined(TQT_NO_TEXTCODEC)
- TQTextCodec *codec = TQTextCodec::codecForLocale();
- if (codec)
- delta = strcoll(codec->fromUnicode(*this), codec->fromUnicode(s));
- if (delta == 0)
-#endif
- delta = ucstrcmp(*this, s);
- return delta;
-#elif defined(TQ_WS_X11)
- // declared in <string.h>
- int delta = strcoll( local8Bit(), s.local8Bit() );
- if ( delta == 0 )
- delta = ucstrcmp( *this, s );
- return delta;
-#else
- return ucstrcmp( *this, s );
-#endif
-}
-
-bool operator==( const TQString &s1, const TQString &s2 )
-{
- if ( s1.tqunicode() == s2.tqunicode() )
- return TRUE;
- return (s1.length() == s2.length()) && s1.isNull() == s2.isNull() &&
- (memcmp((char*)s1.tqunicode(),(char*)s2.tqunicode(),
- s1.length()*sizeof(TQChar)) == 0 );
-}
-
-bool operator!=( const TQString &s1, const TQString &s2 )
-{ return !(s1==s2); }
-
-bool operator<( const TQString &s1, const TQString &s2 )
-{ return ucstrcmp(s1,s2) < 0; }
-
-bool operator<=( const TQString &s1, const TQString &s2 )
-{ return ucstrcmp(s1,s2) <= 0; }
-
-bool operator>( const TQString &s1, const TQString &s2 )
-{ return ucstrcmp(s1,s2) > 0; }
-
-bool operator>=( const TQString &s1, const TQString &s2 )
-{ return ucstrcmp(s1,s2) >= 0; }
-
-
-bool operator==( const TQString &s1, const char *s2 )
-{
- if ( !s2 )
- return s1.isNull();
-
- int len = s1.length();
- const TQChar *uc = s1.tqunicode();
- while ( len ) {
- if ( !(*s2) || uc->tqunicode() != (uchar) *s2 )
- return FALSE;
- ++uc;
- ++s2;
- --len;
- }
- return !*s2;
-}
-
-bool operator==( const char *s1, const TQString &s2 )
-{ return (s2 == s1); }
-
-bool operator!=( const TQString &s1, const char *s2 )
-{ return !(s1==s2); }
-
-bool operator!=( const char *s1, const TQString &s2 )
-{ return !(s1==s2); }
-
-bool operator<( const TQString &s1, const char *s2 )
-{ return ucstrcmp(s1,s2) < 0; }
-
-bool operator<( const char *s1, const TQString &s2 )
-{ return ucstrcmp(s1,s2) < 0; }
-
-bool operator<=( const TQString &s1, const char *s2 )
-{ return ucstrcmp(s1,s2) <= 0; }
-
-bool operator<=( const char *s1, const TQString &s2 )
-{ return ucstrcmp(s1,s2) <= 0; }
-
-bool operator>( const TQString &s1, const char *s2 )
-{ return ucstrcmp(s1,s2) > 0; }
-
-bool operator>( const char *s1, const TQString &s2 )
-{ return ucstrcmp(s1,s2) > 0; }
-
-bool operator>=( const TQString &s1, const char *s2 )
-{ return ucstrcmp(s1,s2) >= 0; }
-
-bool operator>=( const char *s1, const TQString &s2 )
-{ return ucstrcmp(s1,s2) >= 0; }
-
-
-/*****************************************************************************
- Documentation for TQString related functions
- *****************************************************************************/
-
-/*!
- \fn bool operator==( const TQString &s1, const TQString &s2 )
-
- \relates TQString
-
- Returns TRUE if \a s1 is equal to \a s2; otherwise returns FALSE.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) == 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator==( const TQString &s1, const char *s2 )
-
- \overload
- \relates TQString
-
- Returns TRUE if \a s1 is equal to \a s2; otherwise returns FALSE.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) == 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator==( const char *s1, const TQString &s2 )
-
- \overload
- \relates TQString
-
- Returns TRUE if \a s1 is equal to \a s2; otherwise returns FALSE.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) == 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator!=( const TQString &s1, const TQString &s2 )
-
- \relates TQString
-
- Returns TRUE if \a s1 is not equal to \a s2; otherwise returns FALSE.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) != 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator!=( const TQString &s1, const char *s2 )
-
- \overload
- \relates TQString
-
- Returns TRUE if \a s1 is not equal to \a s2; otherwise returns FALSE.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) != 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator!=( const char *s1, const TQString &s2 )
-
- \overload
- \relates TQString
-
- Returns TRUE if \a s1 is not equal to \a s2; otherwise returns FALSE.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) != 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator<( const TQString &s1, const char *s2 )
-
- \relates TQString
-
- Returns TRUE if \a s1 is lexically less than \a s2; otherwise returns FALSE.
- The comparison is case sensitive.
-
- Equivalent to compare(\a s1, \a s2) \< 0.
-*/
-
-/*!
- \fn bool operator<( const char *s1, const TQString &s2 )
-
- \overload
- \relates TQString
-
- Returns TRUE if \a s1 is lexically less than \a s2; otherwise returns FALSE.
- The comparison is case sensitive.
-
- Equivalent to compare(\a s1, \a s2) \< 0.
-*/
-
-/*!
- \fn bool operator<=( const TQString &s1, const char *s2 )
-
- \relates TQString
-
- Returns TRUE if \a s1 is lexically less than or equal to \a s2;
- otherwise returns FALSE.
- The comparison is case sensitive.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1,\a s2) \<= 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator<=( const char *s1, const TQString &s2 )
-
- \overload
- \relates TQString
-
- Returns TRUE if \a s1 is lexically less than or equal to \a s2;
- otherwise returns FALSE.
- The comparison is case sensitive.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) \<= 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator>( const TQString &s1, const char *s2 )
-
- \relates TQString
-
- Returns TRUE if \a s1 is lexically greater than \a s2; otherwise
- returns FALSE.
- The comparison is case sensitive.
-
- Equivalent to compare(\a s1, \a s2) \> 0.
-*/
-
-/*!
- \fn bool operator>( const char *s1, const TQString &s2 )
-
- \overload
- \relates TQString
-
- Returns TRUE if \a s1 is lexically greater than \a s2; otherwise
- returns FALSE.
- The comparison is case sensitive.
-
- Equivalent to compare(\a s1, \a s2) \> 0.
-*/
-
-/*!
- \fn bool operator>=( const TQString &s1, const char *s2 )
-
- \relates TQString
-
- Returns TRUE if \a s1 is lexically greater than or equal to \a s2;
- otherwise returns FALSE.
- The comparison is case sensitive.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) \>= 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn bool operator>=( const char *s1, const TQString &s2 )
-
- \overload
- \relates TQString
-
- Returns TRUE if \a s1 is lexically greater than or equal to \a s2;
- otherwise returns FALSE.
- The comparison is case sensitive.
- Note that a null string is not equal to a not-null empty string.
-
- Equivalent to compare(\a s1, \a s2) \>= 0.
-
- \sa isNull(), isEmpty()
-*/
-
-/*!
- \fn const TQString operator+( const TQString &s1, const TQString &s2 )
-
- \relates TQString
-
- Returns a string which is the result of concatenating the string
- \a s1 and the string \a s2.
-
- Equivalent to \a {s1}.append(\a s2).
-*/
-
-/*!
- \fn const TQString operator+( const TQString &s1, const char *s2 )
-
- \overload
- \relates TQString
-
- Returns a string which is the result of concatenating the string
- \a s1 and character \a s2.
-
- Equivalent to \a {s1}.append(\a s2).
-*/
-
-/*!
- \fn const TQString operator+( const char *s1, const TQString &s2 )
-
- \overload
- \relates TQString
-
- Returns a string which is the result of concatenating the
- character \a s1 and string \a s2.
-*/
-
-/*!
- \fn const TQString operator+( const TQString &s, char c )
-
- \overload
- \relates TQString
-
- Returns a string which is the result of concatenating the string
- \a s and character \a c.
-
- Equivalent to \a {s}.append(\a c).
-*/
-
-/*!
- \fn const TQString operator+( char c, const TQString &s )
-
- \overload
- \relates TQString
-
- Returns a string which is the result of concatenating the
- character \a c and string \a s.
-
- Equivalent to \a {s}.prepend(\a c).
-*/
-
-
-/*****************************************************************************
- TQString stream functions
- *****************************************************************************/
-#ifndef TQT_NO_DATASTREAM
-/*!
- \relates TQString
-
- Writes the string \a str to the stream \a s.
-
- See also \link datastreamformat.html Format of the TQDataStream operators \endlink
-*/
-
-TQDataStream &operator<<( TQDataStream &s, const TQString &str )
-{
- if ( s.version() == 1 ) {
- TQCString l( str.latin1() );
- s << l;
- }
- else {
- int byteOrder = s.byteOrder();
- const TQChar* ub = str.tqunicode();
- if ( ub || s.version() < 3 ) {
- static const uint auto_size = 1024;
- char t[auto_size];
- char *b;
- if ( str.length()*sizeof(TQChar) > auto_size ) {
- b = new char[str.length()*sizeof(TQChar)];
- } else {
- b = t;
- }
- int l = str.length();
- char *c=b;
- while ( l-- ) {
- if ( byteOrder == TQDataStream::BigEndian ) {
- *c++ = (char)ub->row();
- *c++ = (char)ub->cell();
- } else {
- *c++ = (char)ub->cell();
- *c++ = (char)ub->row();
- }
- ub++;
- }
- s.writeBytes( b, sizeof(TQChar)*str.length() );
- if ( str.length()*sizeof(TQChar) > auto_size )
- delete [] b;
- } else {
- // write null marker
- s << (TQ_UINT32)0xffffffff;
- }
- }
- return s;
-}
-
-/*!
- \relates TQString
-
- Reads a string from the stream \a s into string \a str.
-
- See also \link datastreamformat.html Format of the TQDataStream operators \endlink
-*/
-
-TQDataStream &operator>>( TQDataStream &s, TQString &str )
-{
-#ifdef TQT_TQSTRING_UCS_4
-#if defined(TQ_CC_GNU)
-#warning "operator>> not working properly"
-#endif
-#endif
- if ( s.version() == 1 ) {
- TQCString l;
- s >> l;
- str = TQString( l );
- }
- else {
- TQ_UINT32 bytes = 0;
- s >> bytes; // read size of string
- if ( bytes == 0xffffffff ) { // null string
- str = TQString::null;
- } else if ( bytes > 0 ) { // not empty
- int byteOrder = s.byteOrder();
- str.setLength( bytes/2 );
- TQChar* ch = str.d->tqunicode;
- static const uint auto_size = 1024;
- char t[auto_size];
- char *b;
- if ( bytes > auto_size ) {
- b = new char[bytes];
- } else {
- b = t;
- }
- s.readRawBytes( b, bytes );
- int bt = bytes/2;
- char *oldb = b;
- while ( bt-- ) {
- if ( byteOrder == TQDataStream::BigEndian )
- *ch++ = (ushort) (((ushort)b[0])<<8) | (uchar)b[1];
- else
- *ch++ = (ushort) (((ushort)b[1])<<8) | (uchar)b[0];
- b += 2;
- }
- if ( bytes > auto_size )
- delete [] oldb;
- } else {
- str = "";
- }
- }
- return s;
-}
-#endif // TQT_NO_DATASTREAM
-
-/*****************************************************************************
- TQConstString member functions
- *****************************************************************************/
-
-/*!
- \class TQConstString tqstring.h
- \reentrant
- \ingroup text
- \brief The TQConstString class provides string objects using constant Unicode data.
-
- In order to minimize copying, highly optimized applications can
- use TQConstString to provide a TQString-compatible object from
- existing Unicode data. It is then the programmer's responsibility
- to ensure that the Unicode data exists for the entire lifetime of
- the TQConstString object.
-
- A TQConstString is created with the TQConstString constructor. The
- string held by the object can be obtained by calling string().
-*/
-
-/*!
- Constructs a TQConstString that uses the first \a length Unicode
- characters in the array \a tqunicode. Any attempt to modify copies
- of the string will cause it to create a copy of the data, thus it
- remains forever unmodified.
-
- The data in \a tqunicode is not copied. The caller must be able to
- guarantee that \a tqunicode will not be deleted or modified.
-*/
-TQConstString::TQConstString( const TQChar* tqunicode, uint length ) :
- TQString( new TQStringData( (TQChar*)tqunicode, length, length ), TRUE )
-{
-}
-
-/*!
- Destroys the TQConstString, creating a copy of the data if other
- strings are still using it.
-*/
-TQConstString::~TQConstString()
-{
- if ( d->count > 1 ) {
- TQChar* cp = TQT_ALLOC_TQCHAR_VEC( d->len );
- memcpy( cp, d->tqunicode, d->len*sizeof(TQChar) );
- d->tqunicode = cp;
- } else {
- d->tqunicode = 0;
- }
-
- // The original d->tqunicode is now unlinked.
-}
-
-/*!
- \fn const TQString& TQConstString::string() const
-
- Returns a constant string referencing the data passed during
- construction.
-*/
-
-/*!
- Returns TRUE if the string starts with \a s; otherwise returns
- FALSE.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- \code
- TQString str( "Bananas" );
- str.startsWith( "Ban" ); // returns TRUE
- str.startsWith( "Car" ); // returns FALSE
- \endcode
-
- \sa endsWith()
-*/
-bool TQString::startsWith( const TQString& s, bool cs ) const
-{
- if ( isNull() )
- return s.isNull();
- if ( s.length() > length() )
- return FALSE;
- if ( cs ) {
- return memcmp((char*)d->tqunicode, (char*)s.d->tqunicode, s.length()*sizeof(TQChar)) == 0;
- } else {
- for ( int i = 0; i < (int) s.length(); i++ ) {
- if ( ::lower(d->tqunicode[i]) != ::lower(s.d->tqunicode[i]) )
- return FALSE;
- }
- }
- return TRUE;
-}
-
-bool TQString::startsWith( const TQString& s ) const
-{
- return startsWith( s, TRUE );
-}
-
-/*!
- Returns TRUE if the string ends with \a s; otherwise returns
- FALSE.
-
- If \a cs is TRUE (the default), the search is case sensitive;
- otherwise the search is case insensitive.
-
- \code
- TQString str( "Bananas" );
- str.endsWith( "anas" ); // returns TRUE
- str.endsWith( "pple" ); // returns FALSE
- \endcode
-
- \sa startsWith()
-*/
-bool TQString::endsWith( const TQString& s, bool cs ) const
-{
- if ( isNull() )
- return s.isNull();
- int pos = length() - s.length();
- if ( pos < 0 )
- return FALSE;
- if ( cs ) {
- return memcmp((char*)&d->tqunicode[pos], (char*)s.d->tqunicode, s.length()*sizeof(TQChar)) == 0;
- } else {
- for ( int i = 0; i < (int) s.length(); i++ ) {
- if ( ::lower(d->tqunicode[pos + i]) != ::lower(s.d->tqunicode[i]) )
- return FALSE;
- }
- }
- return TRUE;
-}
-
-bool TQString::endsWith( const TQString& s ) const
-{
- return endsWith( s, TRUE );
-}
-
-/*! \fn void TQString::detach()
- If the string does not share its data with another TQString instance,
- nothing happens; otherwise the function creates a new, unique copy of
- this string. This function is called whenever the string is modified. The
- implicit sharing mechanism is implemented this way.
-*/
-
-#if defined(TQ_OS_WIN32)
-
-#include <windows.h>
-
-/*!
- \obsolete
-
- Returns a static Windows TCHAR* from a TQString, adding NUL if \a
- addnul is TRUE.
-
- The lifetime of the return value is until the next call to this function,
- or until the last copy of str is deleted, whatever comes first.
-
- Use ucs2() instead.
-*/
-const void* qt_winTchar(const TQString& str, bool)
-{
- // So that the return value lives long enough.
- static TQString str_cache;
- str_cache = str;
-#ifdef UNICODE
- return str_cache.ucs2();
-#else
- return str_cache.latin1();
-#endif
-}
-
-/*!
- Makes a new '\0'-terminated Windows TCHAR* from a TQString.
-*/
-void* qt_winTchar_new(const TQString& str)
-{
- if ( str.isNull() )
- return 0;
- int l = str.length()+1;
- TCHAR *tc = new TCHAR[ l ];
-#ifdef UNICODE
- memcpy( tc, str.ucs2(), sizeof(TCHAR)*l );
-#else
- memcpy( tc, str.latin1(), sizeof(TCHAR)*l );
-#endif
- return tc;
-}
-
-/*!
- Makes a TQString from a Windows TCHAR*.
-*/
-TQString qt_winTQString(void* tc)
-{
-#ifdef UNICODE
- return TQString::fromUcs2( (ushort*)tc );
-#else
- return TQString::tqfromLatin1( (TCHAR *)tc );
-#endif
-}
-
-TQCString qt_winTQString2MB( const TQString& s, int uclen )
-{
- if ( uclen < 0 )
- uclen = s.length();
- if ( s.isNull() )
- return TQCString();
- if ( uclen == 0 )
- return TQCString("");
- BOOL used_def;
- TQCString mb(4096);
- int len;
- while ( !(len=WideCharToMultiByte(CP_ACP, 0, (const WCHAR*)s.tqunicode(), uclen,
- mb.data(), mb.size()-1, 0, &used_def)) )
- {
- int r = GetLastError();
- if ( r == ERROR_INSUFFICIENT_BUFFER ) {
- mb.resize(1+WideCharToMultiByte( CP_ACP, 0,
- (const WCHAR*)s.tqunicode(), uclen,
- 0, 0, 0, &used_def));
- // and try again...
- } else {
-#ifndef TQT_NO_DEBUG
- // Fail.
- qWarning("WideCharToMultiByte cannot convert multibyte text (error %d): %s (UTF8)",
- r, s.utf8().data());
-#endif
- break;
- }
- }
- mb[len]='\0';
- return mb;
-}
-
-// WATCH OUT: mblen must include the NUL (or just use -1)
-TQString qt_winMB2TQString( const char* mb, int mblen )
-{
- if ( !mb || !mblen )
- return TQString::null;
- const int wclen_auto = 4096;
- WCHAR wc_auto[wclen_auto];
- int wclen = wclen_auto;
- WCHAR *wc = wc_auto;
- int len;
- while ( !(len=MultiByteToWideChar( CP_ACP, MB_PRECOMPOSED,
- mb, mblen, wc, wclen )) )
- {
- int r = GetLastError();
- if ( r == ERROR_INSUFFICIENT_BUFFER ) {
- if ( wc != wc_auto ) {
- qWarning("Size changed in MultiByteToWideChar");
- break;
- } else {
- wclen = MultiByteToWideChar( CP_ACP, MB_PRECOMPOSED,
- mb, mblen, 0, 0 );
- wc = new WCHAR[wclen];
- // and try again...
- }
- } else {
- // Fail.
- qWarning("MultiByteToWideChar cannot convert multibyte text");
- break;
- }
- }
- if ( len <= 0 )
- return TQString::null;
- TQString s( (TQChar*)wc, len - 1 ); // len - 1: we don't want terminator
- if ( wc != wc_auto )
- delete [] wc;
- return s;
-}
-
-#endif // TQ_OS_WIN32
-
-#endif // USE_QT4