1*cdf0e10cSrcweir #/************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir // no include "precompiled_tools.hxx" because this is included in other cxx files. 29*cdf0e10cSrcweir 30*cdf0e10cSrcweir // ======================================================================= 31*cdf0e10cSrcweir 32*cdf0e10cSrcweir #ifdef DBG_UTIL 33*cdf0e10cSrcweir 34*cdf0e10cSrcweir static sal_Bool ImplDbgCheckAsciiStr( const sal_Char* pAsciiStr, sal_Int32 nLen ) 35*cdf0e10cSrcweir { 36*cdf0e10cSrcweir while ( nLen && *pAsciiStr ) 37*cdf0e10cSrcweir { 38*cdf0e10cSrcweir if ( ((unsigned char)*pAsciiStr) > 127 ) 39*cdf0e10cSrcweir return sal_False; 40*cdf0e10cSrcweir ++pAsciiStr, 41*cdf0e10cSrcweir --nLen; 42*cdf0e10cSrcweir } 43*cdf0e10cSrcweir 44*cdf0e10cSrcweir return sal_True; 45*cdf0e10cSrcweir } 46*cdf0e10cSrcweir 47*cdf0e10cSrcweir #endif 48*cdf0e10cSrcweir 49*cdf0e10cSrcweir // ======================================================================= 50*cdf0e10cSrcweir 51*cdf0e10cSrcweir static void ImplCopyAsciiStr( sal_Unicode* pDest, const sal_Char* pSrc, 52*cdf0e10cSrcweir sal_Int32 nLen ) 53*cdf0e10cSrcweir { 54*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pSrc, nLen ), 55*cdf0e10cSrcweir "UniString::CopyAsciiStr() - pAsciiStr include characters > 127" ); 56*cdf0e10cSrcweir 57*cdf0e10cSrcweir while ( nLen ) 58*cdf0e10cSrcweir { 59*cdf0e10cSrcweir *pDest = (unsigned char)*pSrc; 60*cdf0e10cSrcweir ++pDest, 61*cdf0e10cSrcweir ++pSrc, 62*cdf0e10cSrcweir --nLen; 63*cdf0e10cSrcweir } 64*cdf0e10cSrcweir } 65*cdf0e10cSrcweir 66*cdf0e10cSrcweir // ======================================================================= 67*cdf0e10cSrcweir 68*cdf0e10cSrcweir static sal_Int32 ImplStringCompareAscii( const sal_Unicode* pStr1, const sal_Char* pStr2 ) 69*cdf0e10cSrcweir { 70*cdf0e10cSrcweir sal_Int32 nRet; 71*cdf0e10cSrcweir while ( ((nRet = ((sal_Int32)*pStr1)-((sal_Int32)((unsigned char)*pStr2))) == 0) && 72*cdf0e10cSrcweir *pStr2 ) 73*cdf0e10cSrcweir { 74*cdf0e10cSrcweir ++pStr1, 75*cdf0e10cSrcweir ++pStr2; 76*cdf0e10cSrcweir } 77*cdf0e10cSrcweir 78*cdf0e10cSrcweir return nRet; 79*cdf0e10cSrcweir } 80*cdf0e10cSrcweir 81*cdf0e10cSrcweir // ----------------------------------------------------------------------- 82*cdf0e10cSrcweir 83*cdf0e10cSrcweir static sal_Int32 ImplStringCompareAscii( const sal_Unicode* pStr1, const sal_Char* pStr2, 84*cdf0e10cSrcweir xub_StrLen nCount ) 85*cdf0e10cSrcweir { 86*cdf0e10cSrcweir sal_Int32 nRet = 0; 87*cdf0e10cSrcweir while ( nCount && 88*cdf0e10cSrcweir ((nRet = ((sal_Int32)*pStr1)-((sal_Int32)((unsigned char)*pStr2))) == 0) && 89*cdf0e10cSrcweir *pStr2 ) 90*cdf0e10cSrcweir { 91*cdf0e10cSrcweir ++pStr1, 92*cdf0e10cSrcweir ++pStr2, 93*cdf0e10cSrcweir --nCount; 94*cdf0e10cSrcweir } 95*cdf0e10cSrcweir 96*cdf0e10cSrcweir return nRet; 97*cdf0e10cSrcweir } 98*cdf0e10cSrcweir 99*cdf0e10cSrcweir // ----------------------------------------------------------------------- 100*cdf0e10cSrcweir 101*cdf0e10cSrcweir static sal_Int32 ImplStringCompareWithoutZeroAscii( const sal_Unicode* pStr1, const sal_Char* pStr2, 102*cdf0e10cSrcweir xub_StrLen nCount ) 103*cdf0e10cSrcweir { 104*cdf0e10cSrcweir sal_Int32 nRet = 0; 105*cdf0e10cSrcweir while ( nCount && 106*cdf0e10cSrcweir ((nRet = ((sal_Int32)*pStr1)-((sal_Int32)((unsigned char)*pStr2))) == 0) ) 107*cdf0e10cSrcweir { 108*cdf0e10cSrcweir ++pStr1, 109*cdf0e10cSrcweir ++pStr2, 110*cdf0e10cSrcweir --nCount; 111*cdf0e10cSrcweir } 112*cdf0e10cSrcweir 113*cdf0e10cSrcweir return nRet; 114*cdf0e10cSrcweir } 115*cdf0e10cSrcweir 116*cdf0e10cSrcweir // ----------------------------------------------------------------------- 117*cdf0e10cSrcweir 118*cdf0e10cSrcweir static sal_Int32 ImplStringICompareAscii( const sal_Unicode* pStr1, const sal_Char* pStr2 ) 119*cdf0e10cSrcweir { 120*cdf0e10cSrcweir sal_Int32 nRet; 121*cdf0e10cSrcweir sal_Unicode c1; 122*cdf0e10cSrcweir sal_Char c2; 123*cdf0e10cSrcweir do 124*cdf0e10cSrcweir { 125*cdf0e10cSrcweir // Ist das Zeichen zwischen 'A' und 'Z' dann umwandeln 126*cdf0e10cSrcweir c1 = *pStr1; 127*cdf0e10cSrcweir c2 = *pStr2; 128*cdf0e10cSrcweir if ( (c1 >= 65) && (c1 <= 90) ) 129*cdf0e10cSrcweir c1 += 32; 130*cdf0e10cSrcweir if ( (c2 >= 65) && (c2 <= 90) ) 131*cdf0e10cSrcweir c2 += 32; 132*cdf0e10cSrcweir nRet = ((sal_Int32)c1)-((sal_Int32)((unsigned char)c2)); 133*cdf0e10cSrcweir if ( nRet != 0 ) 134*cdf0e10cSrcweir break; 135*cdf0e10cSrcweir 136*cdf0e10cSrcweir ++pStr1, 137*cdf0e10cSrcweir ++pStr2; 138*cdf0e10cSrcweir } 139*cdf0e10cSrcweir while ( c2 ); 140*cdf0e10cSrcweir 141*cdf0e10cSrcweir return nRet; 142*cdf0e10cSrcweir } 143*cdf0e10cSrcweir 144*cdf0e10cSrcweir // ----------------------------------------------------------------------- 145*cdf0e10cSrcweir 146*cdf0e10cSrcweir static sal_Int32 ImplStringICompareAscii( const sal_Unicode* pStr1, const sal_Char* pStr2, 147*cdf0e10cSrcweir xub_StrLen nCount ) 148*cdf0e10cSrcweir { 149*cdf0e10cSrcweir sal_Int32 nRet = 0; 150*cdf0e10cSrcweir sal_Unicode c1; 151*cdf0e10cSrcweir sal_Char c2; 152*cdf0e10cSrcweir do 153*cdf0e10cSrcweir { 154*cdf0e10cSrcweir if ( !nCount ) 155*cdf0e10cSrcweir break; 156*cdf0e10cSrcweir 157*cdf0e10cSrcweir // Ist das Zeichen zwischen 'A' und 'Z' dann umwandeln 158*cdf0e10cSrcweir c1 = *pStr1; 159*cdf0e10cSrcweir c2 = *pStr2; 160*cdf0e10cSrcweir if ( (c1 >= 65) && (c1 <= 90) ) 161*cdf0e10cSrcweir c1 += 32; 162*cdf0e10cSrcweir if ( (c2 >= 65) && (c2 <= 90) ) 163*cdf0e10cSrcweir c2 += 32; 164*cdf0e10cSrcweir nRet = ((sal_Int32)c1)-((sal_Int32)((unsigned char)c2)); 165*cdf0e10cSrcweir if ( nRet != 0 ) 166*cdf0e10cSrcweir break; 167*cdf0e10cSrcweir 168*cdf0e10cSrcweir ++pStr1, 169*cdf0e10cSrcweir ++pStr2, 170*cdf0e10cSrcweir --nCount; 171*cdf0e10cSrcweir } 172*cdf0e10cSrcweir while ( c2 ); 173*cdf0e10cSrcweir 174*cdf0e10cSrcweir return nRet; 175*cdf0e10cSrcweir } 176*cdf0e10cSrcweir 177*cdf0e10cSrcweir // ======================================================================= 178*cdf0e10cSrcweir 179*cdf0e10cSrcweir UniString UniString::CreateFromAscii( const sal_Char* pAsciiStr ) 180*cdf0e10cSrcweir { 181*cdf0e10cSrcweir DBG_ASSERT( pAsciiStr, "UniString::CreateFromAscii() - pAsciiStr is NULL" ); 182*cdf0e10cSrcweir 183*cdf0e10cSrcweir // Stringlaenge ermitteln 184*cdf0e10cSrcweir xub_StrLen nLen = ImplStringLen( pAsciiStr ); 185*cdf0e10cSrcweir 186*cdf0e10cSrcweir UniString aTempStr; 187*cdf0e10cSrcweir if ( nLen ) 188*cdf0e10cSrcweir { 189*cdf0e10cSrcweir ImplCopyAsciiStr( aTempStr.AllocBuffer( nLen ), pAsciiStr, nLen ); 190*cdf0e10cSrcweir } 191*cdf0e10cSrcweir return aTempStr; 192*cdf0e10cSrcweir } 193*cdf0e10cSrcweir 194*cdf0e10cSrcweir // ----------------------------------------------------------------------- 195*cdf0e10cSrcweir 196*cdf0e10cSrcweir UniString UniString::CreateFromAscii( const sal_Char* pAsciiStr, xub_StrLen nLen ) 197*cdf0e10cSrcweir { 198*cdf0e10cSrcweir DBG_ASSERT( pAsciiStr, "UniString::CreateFromAscii() - pAsciiStr is NULL" ); 199*cdf0e10cSrcweir 200*cdf0e10cSrcweir // Stringlaenge ermitteln 201*cdf0e10cSrcweir if ( nLen == STRING_LEN ) 202*cdf0e10cSrcweir nLen = ImplStringLen( pAsciiStr ); 203*cdf0e10cSrcweir 204*cdf0e10cSrcweir UniString aTempStr; 205*cdf0e10cSrcweir 206*cdf0e10cSrcweir if ( nLen ) 207*cdf0e10cSrcweir { 208*cdf0e10cSrcweir ImplCopyAsciiStr( aTempStr.AllocBuffer( nLen ), pAsciiStr, nLen ); 209*cdf0e10cSrcweir } 210*cdf0e10cSrcweir return aTempStr; 211*cdf0e10cSrcweir } 212*cdf0e10cSrcweir 213*cdf0e10cSrcweir // ----------------------------------------------------------------------- 214*cdf0e10cSrcweir 215*cdf0e10cSrcweir UniString& UniString::AssignAscii( const sal_Char* pAsciiStr ) 216*cdf0e10cSrcweir { 217*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 218*cdf0e10cSrcweir DBG_ASSERT( pAsciiStr, "UniString::AssignAscii() - pAsciiStr is NULL" ); 219*cdf0e10cSrcweir 220*cdf0e10cSrcweir // Stringlaenge ermitteln 221*cdf0e10cSrcweir xub_StrLen nLen = ImplStringLen( pAsciiStr ); 222*cdf0e10cSrcweir 223*cdf0e10cSrcweir if ( !nLen ) 224*cdf0e10cSrcweir { 225*cdf0e10cSrcweir STRING_NEW((STRING_TYPE **)&mpData); 226*cdf0e10cSrcweir } 227*cdf0e10cSrcweir else 228*cdf0e10cSrcweir { 229*cdf0e10cSrcweir // Wenn String genauso lang ist, wie der String, dann direkt kopieren 230*cdf0e10cSrcweir if ( (nLen == mpData->mnLen) && (mpData->mnRefCount == 1) ) 231*cdf0e10cSrcweir ImplCopyAsciiStr( mpData->maStr, pAsciiStr, nLen ); 232*cdf0e10cSrcweir else 233*cdf0e10cSrcweir { 234*cdf0e10cSrcweir // Alte Daten loeschen 235*cdf0e10cSrcweir STRING_RELEASE((STRING_TYPE *)mpData); 236*cdf0e10cSrcweir 237*cdf0e10cSrcweir // Daten initialisieren und String kopieren 238*cdf0e10cSrcweir mpData = ImplAllocData( nLen ); 239*cdf0e10cSrcweir ImplCopyAsciiStr( mpData->maStr, pAsciiStr, nLen ); 240*cdf0e10cSrcweir } 241*cdf0e10cSrcweir } 242*cdf0e10cSrcweir 243*cdf0e10cSrcweir return *this; 244*cdf0e10cSrcweir } 245*cdf0e10cSrcweir 246*cdf0e10cSrcweir // ----------------------------------------------------------------------- 247*cdf0e10cSrcweir 248*cdf0e10cSrcweir UniString& UniString::AssignAscii( const sal_Char* pAsciiStr, xub_StrLen nLen ) 249*cdf0e10cSrcweir { 250*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 251*cdf0e10cSrcweir DBG_ASSERT( pAsciiStr, "UniString::AssignAscii() - pAsciiStr is NULL" ); 252*cdf0e10cSrcweir 253*cdf0e10cSrcweir if ( nLen == STRING_LEN ) 254*cdf0e10cSrcweir nLen = ImplStringLen( pAsciiStr ); 255*cdf0e10cSrcweir 256*cdf0e10cSrcweir #ifdef DBG_UTIL 257*cdf0e10cSrcweir if ( DbgIsAssert() ) 258*cdf0e10cSrcweir { 259*cdf0e10cSrcweir for ( xub_StrLen i = 0; i < nLen; ++i ) 260*cdf0e10cSrcweir { 261*cdf0e10cSrcweir if ( !pAsciiStr[i] ) 262*cdf0e10cSrcweir { 263*cdf0e10cSrcweir DBG_ERROR( "UniString::AssignAscii() : nLen is wrong" ); 264*cdf0e10cSrcweir } 265*cdf0e10cSrcweir } 266*cdf0e10cSrcweir } 267*cdf0e10cSrcweir #endif 268*cdf0e10cSrcweir 269*cdf0e10cSrcweir if ( !nLen ) 270*cdf0e10cSrcweir { 271*cdf0e10cSrcweir STRING_NEW((STRING_TYPE **)&mpData); 272*cdf0e10cSrcweir } 273*cdf0e10cSrcweir else 274*cdf0e10cSrcweir { 275*cdf0e10cSrcweir // Wenn String genauso lang ist, wie der String, dann direkt kopieren 276*cdf0e10cSrcweir if ( (nLen == mpData->mnLen) && (mpData->mnRefCount == 1) ) 277*cdf0e10cSrcweir ImplCopyAsciiStr( mpData->maStr, pAsciiStr, nLen ); 278*cdf0e10cSrcweir else 279*cdf0e10cSrcweir { 280*cdf0e10cSrcweir // Alte Daten loeschen 281*cdf0e10cSrcweir STRING_RELEASE((STRING_TYPE *)mpData); 282*cdf0e10cSrcweir 283*cdf0e10cSrcweir // Daten initialisieren und String kopieren 284*cdf0e10cSrcweir mpData = ImplAllocData( nLen ); 285*cdf0e10cSrcweir ImplCopyAsciiStr( mpData->maStr, pAsciiStr, nLen ); 286*cdf0e10cSrcweir } 287*cdf0e10cSrcweir } 288*cdf0e10cSrcweir 289*cdf0e10cSrcweir return *this; 290*cdf0e10cSrcweir } 291*cdf0e10cSrcweir 292*cdf0e10cSrcweir // ----------------------------------------------------------------------- 293*cdf0e10cSrcweir 294*cdf0e10cSrcweir UniString& UniString::AppendAscii( const sal_Char* pAsciiStr ) 295*cdf0e10cSrcweir { 296*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 297*cdf0e10cSrcweir DBG_ASSERT( pAsciiStr, "UniString::AppendAscii() - pAsciiStr is NULL" ); 298*cdf0e10cSrcweir 299*cdf0e10cSrcweir // Stringlaenge ermitteln 300*cdf0e10cSrcweir sal_Int32 nCopyLen = ImplStringLen( pAsciiStr ); 301*cdf0e10cSrcweir 302*cdf0e10cSrcweir // Ueberlauf abfangen 303*cdf0e10cSrcweir nCopyLen = ImplGetCopyLen( mpData->mnLen, nCopyLen ); 304*cdf0e10cSrcweir 305*cdf0e10cSrcweir // Ist es kein leerer String 306*cdf0e10cSrcweir if ( nCopyLen ) 307*cdf0e10cSrcweir { 308*cdf0e10cSrcweir // Neue Datenstruktur und neuen String erzeugen 309*cdf0e10cSrcweir UniStringData* pNewData = ImplAllocData( mpData->mnLen+nCopyLen ); 310*cdf0e10cSrcweir 311*cdf0e10cSrcweir // String kopieren 312*cdf0e10cSrcweir memcpy( pNewData->maStr, mpData->maStr, mpData->mnLen*sizeof( sal_Unicode ) ); 313*cdf0e10cSrcweir ImplCopyAsciiStr( pNewData->maStr+mpData->mnLen, pAsciiStr, nCopyLen ); 314*cdf0e10cSrcweir 315*cdf0e10cSrcweir // Alte Daten loeschen und Neue zuweisen 316*cdf0e10cSrcweir STRING_RELEASE((STRING_TYPE *)mpData); 317*cdf0e10cSrcweir mpData = pNewData; 318*cdf0e10cSrcweir } 319*cdf0e10cSrcweir 320*cdf0e10cSrcweir return *this; 321*cdf0e10cSrcweir } 322*cdf0e10cSrcweir 323*cdf0e10cSrcweir // ----------------------------------------------------------------------- 324*cdf0e10cSrcweir 325*cdf0e10cSrcweir UniString& UniString::AppendAscii( const sal_Char* pAsciiStr, xub_StrLen nLen ) 326*cdf0e10cSrcweir { 327*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 328*cdf0e10cSrcweir DBG_ASSERT( pAsciiStr, "UniString::AppendAscii() - pAsciiStr is NULL" ); 329*cdf0e10cSrcweir 330*cdf0e10cSrcweir if ( nLen == STRING_LEN ) 331*cdf0e10cSrcweir nLen = ImplStringLen( pAsciiStr ); 332*cdf0e10cSrcweir 333*cdf0e10cSrcweir #ifdef DBG_UTIL 334*cdf0e10cSrcweir if ( DbgIsAssert() ) 335*cdf0e10cSrcweir { 336*cdf0e10cSrcweir for ( xub_StrLen i = 0; i < nLen; ++i ) 337*cdf0e10cSrcweir { 338*cdf0e10cSrcweir if ( !pAsciiStr[i] ) 339*cdf0e10cSrcweir { 340*cdf0e10cSrcweir DBG_ERROR( "UniString::AppendAscii() : nLen is wrong" ); 341*cdf0e10cSrcweir } 342*cdf0e10cSrcweir } 343*cdf0e10cSrcweir } 344*cdf0e10cSrcweir #endif 345*cdf0e10cSrcweir 346*cdf0e10cSrcweir // Ueberlauf abfangen 347*cdf0e10cSrcweir sal_Int32 nCopyLen = ImplGetCopyLen( mpData->mnLen, nLen ); 348*cdf0e10cSrcweir 349*cdf0e10cSrcweir // Ist es kein leerer String 350*cdf0e10cSrcweir if ( nCopyLen ) 351*cdf0e10cSrcweir { 352*cdf0e10cSrcweir // Neue Datenstruktur und neuen String erzeugen 353*cdf0e10cSrcweir UniStringData* pNewData = ImplAllocData( mpData->mnLen+nCopyLen ); 354*cdf0e10cSrcweir 355*cdf0e10cSrcweir // String kopieren 356*cdf0e10cSrcweir memcpy( pNewData->maStr, mpData->maStr, mpData->mnLen*sizeof( sal_Unicode ) ); 357*cdf0e10cSrcweir ImplCopyAsciiStr( pNewData->maStr+mpData->mnLen, pAsciiStr, nCopyLen ); 358*cdf0e10cSrcweir 359*cdf0e10cSrcweir // Alte Daten loeschen und Neue zuweisen 360*cdf0e10cSrcweir STRING_RELEASE((STRING_TYPE *)mpData); 361*cdf0e10cSrcweir mpData = pNewData; 362*cdf0e10cSrcweir } 363*cdf0e10cSrcweir 364*cdf0e10cSrcweir return *this; 365*cdf0e10cSrcweir } 366*cdf0e10cSrcweir 367*cdf0e10cSrcweir // ----------------------------------------------------------------------- 368*cdf0e10cSrcweir 369*cdf0e10cSrcweir UniString& UniString::InsertAscii( const char* pAsciiStr, xub_StrLen nIndex ) 370*cdf0e10cSrcweir { 371*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 372*cdf0e10cSrcweir DBG_ASSERT( pAsciiStr, "UniString::InsertAscii() - pAsciiStr is NULL" ); 373*cdf0e10cSrcweir 374*cdf0e10cSrcweir // Stringlaenge ermitteln 375*cdf0e10cSrcweir sal_Int32 nCopyLen = ImplStringLen( pAsciiStr ); 376*cdf0e10cSrcweir 377*cdf0e10cSrcweir // Ueberlauf abfangen 378*cdf0e10cSrcweir nCopyLen = ImplGetCopyLen( mpData->mnLen, nCopyLen ); 379*cdf0e10cSrcweir 380*cdf0e10cSrcweir // Ist der einzufuegende String ein Leerstring 381*cdf0e10cSrcweir if ( !nCopyLen ) 382*cdf0e10cSrcweir return *this; 383*cdf0e10cSrcweir 384*cdf0e10cSrcweir // Index groesser als Laenge 385*cdf0e10cSrcweir if ( nIndex > mpData->mnLen ) 386*cdf0e10cSrcweir nIndex = static_cast< xub_StrLen >(mpData->mnLen); 387*cdf0e10cSrcweir 388*cdf0e10cSrcweir // Neue Laenge ermitteln und neuen String anlegen 389*cdf0e10cSrcweir UniStringData* pNewData = ImplAllocData( mpData->mnLen+nCopyLen ); 390*cdf0e10cSrcweir 391*cdf0e10cSrcweir // String kopieren 392*cdf0e10cSrcweir memcpy( pNewData->maStr, mpData->maStr, nIndex*sizeof( sal_Unicode ) ); 393*cdf0e10cSrcweir ImplCopyAsciiStr( pNewData->maStr+nIndex, pAsciiStr, nCopyLen ); 394*cdf0e10cSrcweir memcpy( pNewData->maStr+nIndex+nCopyLen, mpData->maStr+nIndex, 395*cdf0e10cSrcweir (mpData->mnLen-nIndex)*sizeof( sal_Unicode ) ); 396*cdf0e10cSrcweir 397*cdf0e10cSrcweir // Alte Daten loeschen und Neue zuweisen 398*cdf0e10cSrcweir STRING_RELEASE((STRING_TYPE *)mpData); 399*cdf0e10cSrcweir mpData = pNewData; 400*cdf0e10cSrcweir 401*cdf0e10cSrcweir return *this; 402*cdf0e10cSrcweir } 403*cdf0e10cSrcweir 404*cdf0e10cSrcweir // ----------------------------------------------------------------------- 405*cdf0e10cSrcweir 406*cdf0e10cSrcweir UniString& UniString::ReplaceAscii( xub_StrLen nIndex, xub_StrLen nCount, 407*cdf0e10cSrcweir const sal_Char* pAsciiStr, xub_StrLen nStrLen ) 408*cdf0e10cSrcweir { 409*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 410*cdf0e10cSrcweir DBG_ASSERT( pAsciiStr, "UniString::ReplaceAscii() - pAsciiStr is NULL" ); 411*cdf0e10cSrcweir 412*cdf0e10cSrcweir // Wenn Index groessergleich Laenge ist, dann ist es ein Append 413*cdf0e10cSrcweir if ( nIndex >= mpData->mnLen ) 414*cdf0e10cSrcweir { 415*cdf0e10cSrcweir AppendAscii( pAsciiStr, nStrLen ); 416*cdf0e10cSrcweir return *this; 417*cdf0e10cSrcweir } 418*cdf0e10cSrcweir 419*cdf0e10cSrcweir // Ist es eine Zuweisung 420*cdf0e10cSrcweir if ( (nIndex == 0) && (nCount >= mpData->mnLen) ) 421*cdf0e10cSrcweir { 422*cdf0e10cSrcweir AssignAscii( pAsciiStr, nStrLen ); 423*cdf0e10cSrcweir return *this; 424*cdf0e10cSrcweir } 425*cdf0e10cSrcweir 426*cdf0e10cSrcweir // Reicht ein Erase 427*cdf0e10cSrcweir if ( nStrLen == STRING_LEN ) 428*cdf0e10cSrcweir nStrLen = ImplStringLen( pAsciiStr ); 429*cdf0e10cSrcweir if ( !nStrLen ) 430*cdf0e10cSrcweir return Erase( nIndex, nCount ); 431*cdf0e10cSrcweir 432*cdf0e10cSrcweir // nCount darf nicht ueber das Stringende hinnausgehen 433*cdf0e10cSrcweir if ( nCount > mpData->mnLen - nIndex ) 434*cdf0e10cSrcweir nCount = static_cast< xub_StrLen >(mpData->mnLen-nIndex); 435*cdf0e10cSrcweir 436*cdf0e10cSrcweir // Reicht eine zeichenweise Zuweisung 437*cdf0e10cSrcweir if ( nCount == nStrLen ) 438*cdf0e10cSrcweir { 439*cdf0e10cSrcweir ImplCopyData(); 440*cdf0e10cSrcweir ImplCopyAsciiStr( mpData->maStr+nIndex, pAsciiStr, nStrLen ); 441*cdf0e10cSrcweir return *this; 442*cdf0e10cSrcweir } 443*cdf0e10cSrcweir 444*cdf0e10cSrcweir // Ueberlauf abfangen 445*cdf0e10cSrcweir sal_Int32 n = ImplGetCopyLen( mpData->mnLen-nCount, nStrLen ); 446*cdf0e10cSrcweir 447*cdf0e10cSrcweir // Neue Daten anlegen 448*cdf0e10cSrcweir STRINGDATA* pNewData = ImplAllocData( mpData->mnLen-nCount+n ); 449*cdf0e10cSrcweir 450*cdf0e10cSrcweir // String kopieren 451*cdf0e10cSrcweir memcpy( pNewData->maStr, mpData->maStr, nIndex*sizeof( STRCODE ) ); 452*cdf0e10cSrcweir ImplCopyAsciiStr( pNewData->maStr+nIndex, pAsciiStr, n ); 453*cdf0e10cSrcweir memcpy( pNewData->maStr+nIndex+n, mpData->maStr+nIndex+nCount, 454*cdf0e10cSrcweir (mpData->mnLen-nIndex-nCount+1)*sizeof( STRCODE ) ); 455*cdf0e10cSrcweir 456*cdf0e10cSrcweir // Alte Daten loeschen und Neue zuweisen 457*cdf0e10cSrcweir STRING_RELEASE((STRING_TYPE *)mpData); 458*cdf0e10cSrcweir mpData = pNewData; 459*cdf0e10cSrcweir 460*cdf0e10cSrcweir return *this; 461*cdf0e10cSrcweir } 462*cdf0e10cSrcweir 463*cdf0e10cSrcweir // ----------------------------------------------------------------------- 464*cdf0e10cSrcweir 465*cdf0e10cSrcweir StringCompare UniString::CompareToAscii( const sal_Char* pAsciiStr, 466*cdf0e10cSrcweir xub_StrLen nLen ) const 467*cdf0e10cSrcweir { 468*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 469*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, nLen ), 470*cdf0e10cSrcweir "UniString::CompareToAscii() - pAsciiStr include characters > 127" ); 471*cdf0e10cSrcweir 472*cdf0e10cSrcweir // String vergleichen 473*cdf0e10cSrcweir sal_Int32 nCompare = ImplStringCompareAscii( mpData->maStr, pAsciiStr, nLen ); 474*cdf0e10cSrcweir 475*cdf0e10cSrcweir // Rueckgabewert anpassen 476*cdf0e10cSrcweir if ( nCompare == 0 ) 477*cdf0e10cSrcweir return COMPARE_EQUAL; 478*cdf0e10cSrcweir else if ( nCompare < 0 ) 479*cdf0e10cSrcweir return COMPARE_LESS; 480*cdf0e10cSrcweir else 481*cdf0e10cSrcweir return COMPARE_GREATER; 482*cdf0e10cSrcweir } 483*cdf0e10cSrcweir 484*cdf0e10cSrcweir // ----------------------------------------------------------------------- 485*cdf0e10cSrcweir 486*cdf0e10cSrcweir StringCompare UniString::CompareIgnoreCaseToAscii( const sal_Char* pAsciiStr, 487*cdf0e10cSrcweir xub_StrLen nLen ) const 488*cdf0e10cSrcweir { 489*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 490*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, nLen ), 491*cdf0e10cSrcweir "UniString::CompareIgnoreCaseToAscii() - pAsciiStr include characters > 127" ); 492*cdf0e10cSrcweir 493*cdf0e10cSrcweir // String vergleichen 494*cdf0e10cSrcweir sal_Int32 nCompare = ImplStringICompareAscii( mpData->maStr, pAsciiStr, nLen ); 495*cdf0e10cSrcweir 496*cdf0e10cSrcweir // Rueckgabewert anpassen 497*cdf0e10cSrcweir if ( nCompare == 0 ) 498*cdf0e10cSrcweir return COMPARE_EQUAL; 499*cdf0e10cSrcweir else if ( nCompare < 0 ) 500*cdf0e10cSrcweir return COMPARE_LESS; 501*cdf0e10cSrcweir else 502*cdf0e10cSrcweir return COMPARE_GREATER; 503*cdf0e10cSrcweir } 504*cdf0e10cSrcweir 505*cdf0e10cSrcweir // ----------------------------------------------------------------------- 506*cdf0e10cSrcweir 507*cdf0e10cSrcweir sal_Bool UniString::EqualsAscii( const sal_Char* pAsciiStr ) const 508*cdf0e10cSrcweir { 509*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 510*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, STRING_LEN ), 511*cdf0e10cSrcweir "UniString::EqualsAscii() - pAsciiStr include characters > 127" ); 512*cdf0e10cSrcweir 513*cdf0e10cSrcweir return (ImplStringCompareAscii( mpData->maStr, pAsciiStr ) == 0); 514*cdf0e10cSrcweir } 515*cdf0e10cSrcweir 516*cdf0e10cSrcweir // ----------------------------------------------------------------------- 517*cdf0e10cSrcweir 518*cdf0e10cSrcweir sal_Bool UniString::EqualsIgnoreCaseAscii( const sal_Char* pAsciiStr ) const 519*cdf0e10cSrcweir { 520*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 521*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, STRING_LEN ), 522*cdf0e10cSrcweir "UniString::EqualsIgnoreCaseAscii() - pAsciiStr include characters > 127" ); 523*cdf0e10cSrcweir 524*cdf0e10cSrcweir return (ImplStringICompareAscii( mpData->maStr, pAsciiStr ) == 0); 525*cdf0e10cSrcweir } 526*cdf0e10cSrcweir 527*cdf0e10cSrcweir // ----------------------------------------------------------------------- 528*cdf0e10cSrcweir 529*cdf0e10cSrcweir sal_Bool UniString::EqualsAscii( const sal_Char* pAsciiStr, 530*cdf0e10cSrcweir xub_StrLen nIndex, xub_StrLen nLen ) const 531*cdf0e10cSrcweir { 532*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 533*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, nLen ), 534*cdf0e10cSrcweir "UniString::EqualsAscii() - pAsciiStr include characters > 127" ); 535*cdf0e10cSrcweir 536*cdf0e10cSrcweir // Are there enough codes for comparing? 537*cdf0e10cSrcweir if ( nIndex > mpData->mnLen ) 538*cdf0e10cSrcweir return (*pAsciiStr == 0); 539*cdf0e10cSrcweir 540*cdf0e10cSrcweir return (ImplStringCompareAscii( mpData->maStr+nIndex, pAsciiStr, nLen ) == 0); 541*cdf0e10cSrcweir } 542*cdf0e10cSrcweir 543*cdf0e10cSrcweir // ----------------------------------------------------------------------- 544*cdf0e10cSrcweir 545*cdf0e10cSrcweir sal_Bool UniString::EqualsIgnoreCaseAscii( const sal_Char* pAsciiStr, 546*cdf0e10cSrcweir xub_StrLen nIndex, xub_StrLen nLen ) const 547*cdf0e10cSrcweir { 548*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 549*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, nLen ), 550*cdf0e10cSrcweir "UniString::EqualsIgnoreCaseAscii() - pAsciiStr include characters > 127" ); 551*cdf0e10cSrcweir 552*cdf0e10cSrcweir // Are there enough codes for comparing? 553*cdf0e10cSrcweir if ( nIndex > mpData->mnLen ) 554*cdf0e10cSrcweir return (*pAsciiStr == 0); 555*cdf0e10cSrcweir 556*cdf0e10cSrcweir return (ImplStringICompareAscii( mpData->maStr+nIndex, pAsciiStr, nLen ) == 0); 557*cdf0e10cSrcweir } 558*cdf0e10cSrcweir 559*cdf0e10cSrcweir // ----------------------------------------------------------------------- 560*cdf0e10cSrcweir 561*cdf0e10cSrcweir xub_StrLen UniString::SearchAscii( const sal_Char* pAsciiStr, xub_StrLen nIndex ) const 562*cdf0e10cSrcweir { 563*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 564*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, STRING_LEN ), 565*cdf0e10cSrcweir "UniString::SearchAscii() - pAsciiStr include characters > 127" ); 566*cdf0e10cSrcweir 567*cdf0e10cSrcweir sal_Int32 nLen = mpData->mnLen; 568*cdf0e10cSrcweir xub_StrLen nStrLen = ImplStringLen( pAsciiStr ); 569*cdf0e10cSrcweir 570*cdf0e10cSrcweir // Falls die Laenge des uebergebenen Strings 0 ist oder der Index 571*cdf0e10cSrcweir // hinter dem String liegt, dann wurde der String nicht gefunden 572*cdf0e10cSrcweir if ( !nStrLen || (nIndex >= nLen) ) 573*cdf0e10cSrcweir return STRING_NOTFOUND; 574*cdf0e10cSrcweir 575*cdf0e10cSrcweir const sal_Unicode* pStr = mpData->maStr; 576*cdf0e10cSrcweir pStr += nIndex; 577*cdf0e10cSrcweir 578*cdf0e10cSrcweir if ( nStrLen == 1 ) 579*cdf0e10cSrcweir { 580*cdf0e10cSrcweir sal_Unicode cSearch = (unsigned char)*pAsciiStr; 581*cdf0e10cSrcweir while ( nIndex < nLen ) 582*cdf0e10cSrcweir { 583*cdf0e10cSrcweir if ( *pStr == cSearch ) 584*cdf0e10cSrcweir return nIndex; 585*cdf0e10cSrcweir ++pStr, 586*cdf0e10cSrcweir ++nIndex; 587*cdf0e10cSrcweir } 588*cdf0e10cSrcweir } 589*cdf0e10cSrcweir else 590*cdf0e10cSrcweir { 591*cdf0e10cSrcweir // Nur innerhalb des Strings suchen 592*cdf0e10cSrcweir while ( nLen - nIndex >= nStrLen ) 593*cdf0e10cSrcweir { 594*cdf0e10cSrcweir // Stimmt der String ueberein 595*cdf0e10cSrcweir if ( ImplStringCompareWithoutZeroAscii( pStr, pAsciiStr, nStrLen ) == 0 ) 596*cdf0e10cSrcweir return nIndex; 597*cdf0e10cSrcweir ++pStr, 598*cdf0e10cSrcweir ++nIndex; 599*cdf0e10cSrcweir } 600*cdf0e10cSrcweir } 601*cdf0e10cSrcweir 602*cdf0e10cSrcweir return STRING_NOTFOUND; 603*cdf0e10cSrcweir } 604*cdf0e10cSrcweir 605*cdf0e10cSrcweir // ----------------------------------------------------------------------- 606*cdf0e10cSrcweir 607*cdf0e10cSrcweir xub_StrLen UniString::SearchAndReplaceAscii( const sal_Char* pAsciiStr, const UniString& rRepStr, 608*cdf0e10cSrcweir xub_StrLen nIndex ) 609*cdf0e10cSrcweir { 610*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 611*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, STRING_LEN ), 612*cdf0e10cSrcweir "UniString::SearchAndReplaceAscii() - pAsciiStr include characters > 127" ); 613*cdf0e10cSrcweir 614*cdf0e10cSrcweir xub_StrLen nSPos = SearchAscii( pAsciiStr, nIndex ); 615*cdf0e10cSrcweir if ( nSPos != STRING_NOTFOUND ) 616*cdf0e10cSrcweir Replace( nSPos, ImplStringLen( pAsciiStr ), rRepStr ); 617*cdf0e10cSrcweir 618*cdf0e10cSrcweir return nSPos; 619*cdf0e10cSrcweir } 620*cdf0e10cSrcweir 621*cdf0e10cSrcweir // ----------------------------------------------------------------------- 622*cdf0e10cSrcweir 623*cdf0e10cSrcweir void UniString::SearchAndReplaceAllAscii( const sal_Char* pAsciiStr, const UniString& rRepStr ) 624*cdf0e10cSrcweir { 625*cdf0e10cSrcweir DBG_CHKTHIS( UniString, DbgCheckUniString ); 626*cdf0e10cSrcweir DBG_ASSERT( ImplDbgCheckAsciiStr( pAsciiStr, STRING_LEN ), 627*cdf0e10cSrcweir "UniString::SearchAndReplaceAllAscii() - pAsciiStr include characters > 127" ); 628*cdf0e10cSrcweir 629*cdf0e10cSrcweir xub_StrLen nCharLen = ImplStringLen( pAsciiStr ); 630*cdf0e10cSrcweir xub_StrLen nSPos = SearchAscii( pAsciiStr, 0 ); 631*cdf0e10cSrcweir while ( nSPos != STRING_NOTFOUND ) 632*cdf0e10cSrcweir { 633*cdf0e10cSrcweir Replace( nSPos, nCharLen, rRepStr ); 634*cdf0e10cSrcweir nSPos = nSPos + rRepStr.Len(); 635*cdf0e10cSrcweir nSPos = SearchAscii( pAsciiStr, nSPos ); 636*cdf0e10cSrcweir } 637*cdf0e10cSrcweir } 638