|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** Filename : util
|
|
|
|
** Created on : 03 April, 2005
|
|
|
|
** Copyright : (c) 2005 Till Adam
|
|
|
|
** Email : <adam@kde.org>
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
**
|
|
|
|
** This program is free software; you can redistribute it and/or modify
|
|
|
|
** it under the terms of the GNU General Public License as published by
|
|
|
|
** the Free Software Foundation; either version 2 of the License, or
|
|
|
|
** (at your option) any later version.
|
|
|
|
**
|
|
|
|
** It is distributed in the hope that it will be useful, but
|
|
|
|
** WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
** General Public License for more details.
|
|
|
|
**
|
|
|
|
** You should have received a copy of the GNU General Public License
|
|
|
|
** along with this program; if not, write to the Free Software
|
|
|
|
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
**
|
|
|
|
** In addition, as a special exception, the copyright holders give
|
|
|
|
** permission to link the code of this program with any edition of
|
|
|
|
** the TQt library by Trolltech AS, Norway (or with modified versions
|
|
|
|
** of TQt that use the same license as TQt), and distribute linked
|
|
|
|
** combinations including the two. You must obey the GNU General
|
|
|
|
** Public License in all respects for all of the code used other than
|
|
|
|
** TQt. If you modify this file, you may extend this exception to
|
|
|
|
** your version of the file, but you are not obligated to do so. If
|
|
|
|
** you do not wish to do so, delete this exception statement from
|
|
|
|
** your version.
|
|
|
|
**
|
|
|
|
*******************************************************************************/
|
|
|
|
#include "util.h"
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <tqcstring.h>
|
|
|
|
#include <mimelib/string.h>
|
|
|
|
|
|
|
|
size_t KMail::Util::crlf2lf( char* str, const size_t strLen )
|
|
|
|
{
|
|
|
|
if ( !str || strLen == 0 )
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
const char* source = str;
|
|
|
|
const char* sourceEnd = source + strLen;
|
|
|
|
|
|
|
|
// search the first occurrence of "\r\n"
|
|
|
|
for ( ; source < sourceEnd - 1; ++source ) {
|
|
|
|
if ( *source == '\r' && *( source + 1 ) == '\n' )
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( source == sourceEnd - 1 ) {
|
|
|
|
// no "\r\n" found
|
|
|
|
return strLen;
|
|
|
|
}
|
|
|
|
|
|
|
|
// replace all occurrences of "\r\n" with "\n" (in place)
|
|
|
|
char* target = const_cast<char*>( source ); // target points to '\r'
|
|
|
|
++source; // source points to '\n'
|
|
|
|
for ( ; source < sourceEnd; ++source ) {
|
|
|
|
if ( *source != '\r' || *( source + 1 ) != '\n' )
|
|
|
|
* target++ = *source;
|
|
|
|
}
|
|
|
|
*target = '\0'; // terminate result
|
|
|
|
return target - str;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQCString KMail::Util::lf2crlf( const TQCString & src )
|
|
|
|
{
|
|
|
|
TQCString result( 1 + 2*src.size() ); // maximal possible length
|
|
|
|
|
|
|
|
TQCString::ConstIterator s = src.begin();
|
|
|
|
TQCString::Iterator d = result.begin();
|
|
|
|
// we use cPrev to make sure we insert '\r' only there where it is missing
|
|
|
|
char cPrev = '?';
|
|
|
|
while ( *s ) {
|
|
|
|
if ( ('\n' == *s) && ('\r' != cPrev) )
|
|
|
|
*d++ = '\r';
|
|
|
|
cPrev = *s;
|
|
|
|
*d++ = *s++;
|
|
|
|
}
|
|
|
|
result.truncate( d - result.begin() ); // adds trailing NUL
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQByteArray KMail::Util::lf2crlf( const TQByteArray & src )
|
|
|
|
{
|
|
|
|
const char* s = src.data();
|
|
|
|
if ( !s )
|
|
|
|
return TQByteArray();
|
|
|
|
|
|
|
|
TQByteArray result( 2 * src.size() ); // maximal possible length
|
|
|
|
TQByteArray::Iterator d = result.begin();
|
|
|
|
// we use cPrev to make sure we insert '\r' only there where it is missing
|
|
|
|
char cPrev = '?';
|
|
|
|
const char* end = src.end();
|
|
|
|
while ( s != end ) {
|
|
|
|
if ( ('\n' == *s) && ('\r' != cPrev) )
|
|
|
|
*d++ = '\r';
|
|
|
|
cPrev = *s;
|
|
|
|
*d++ = *s++;
|
|
|
|
}
|
|
|
|
result.truncate( d - result.begin() ); // does not add trailing NUL, as expected
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQCString KMail::Util::CString( const DwString& str )
|
|
|
|
{
|
|
|
|
const int strLen = str.size();
|
|
|
|
TQCString cstr( strLen + 1 );
|
|
|
|
memcpy( cstr.data(), str.data(), strLen );
|
|
|
|
cstr[ strLen ] = 0;
|
|
|
|
return cstr;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQByteArray KMail::Util::ByteArray( const DwString& str )
|
|
|
|
{
|
|
|
|
const int strLen = str.size();
|
|
|
|
TQByteArray arr( strLen );
|
|
|
|
memcpy( arr.data(), str.data(), strLen );
|
|
|
|
return arr;
|
|
|
|
}
|
|
|
|
|
|
|
|
DwString KMail::Util::dwString( const TQCString& str )
|
|
|
|
{
|
|
|
|
if ( !str.data() ) // DwString doesn't like char*=0
|
|
|
|
return DwString();
|
|
|
|
return DwString( str.data(), str.size() - 1 );
|
|
|
|
}
|
|
|
|
|
|
|
|
DwString KMail::Util::dwString( const TQByteArray& str )
|
|
|
|
{
|
|
|
|
if ( !str.data() ) // DwString doesn't like char*=0
|
|
|
|
return DwString();
|
|
|
|
return DwString( str.data(), str.size() );
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMail::Util::append( TQByteArray& that, const TQByteArray& str )
|
|
|
|
{
|
|
|
|
that.detach();
|
|
|
|
uint len1 = that.size();
|
|
|
|
uint len2 = str.size();
|
|
|
|
if ( that.tqresize( len1 + len2, TQGArray::SpeedOptim ) )
|
|
|
|
memcpy( that.data() + len1, str.data(), len2 );
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMail::Util::append( TQByteArray& that, const char* str )
|
|
|
|
{
|
|
|
|
if ( !str )
|
|
|
|
return; // nothing to append
|
|
|
|
that.detach();
|
|
|
|
uint len1 = that.size();
|
|
|
|
uint len2 = tqstrlen(str);
|
|
|
|
if ( that.tqresize( len1 + len2, TQGArray::SpeedOptim ) )
|
|
|
|
memcpy( that.data() + len1, str, len2 );
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMail::Util::append( TQByteArray& that, const TQCString& str )
|
|
|
|
{
|
|
|
|
that.detach();
|
|
|
|
uint len1 = that.size();
|
|
|
|
uint len2 = str.size() - 1;
|
|
|
|
if ( that.tqresize( len1 + len2, TQGArray::SpeedOptim ) )
|
|
|
|
memcpy( that.data() + len1, str.data(), len2 );
|
|
|
|
}
|
|
|
|
|
|
|
|
// Code taken from TQCString::insert, but trailing nul removed
|
|
|
|
void KMail::Util::insert( TQByteArray& that, uint index, const char* s )
|
|
|
|
{
|
|
|
|
int len = tqstrlen(s);
|
|
|
|
if ( len == 0 )
|
|
|
|
return;
|
|
|
|
uint olen = that.size();
|
|
|
|
int nlen = olen + len;
|
|
|
|
if ( index >= olen ) { // insert after end of string
|
|
|
|
that.detach();
|
|
|
|
if ( that.tqresize(nlen+index-olen, TQGArray::SpeedOptim ) ) {
|
|
|
|
memset( that.data()+olen, ' ', index-olen );
|
|
|
|
memcpy( that.data()+index, s, len );
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
that.detach();
|
|
|
|
if ( that.tqresize(nlen, TQGArray::SpeedOptim ) ) { // normal insert
|
|
|
|
memmove( that.data()+index+len, that.data()+index, olen-index );
|
|
|
|
memcpy( that.data()+index, s, len );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|