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 // MARKER(update_precomp.py): autogen include statement, do not remove 29*cdf0e10cSrcweir #include "precompiled_sfx2.hxx" 30*cdf0e10cSrcweir 31*cdf0e10cSrcweir #ifndef GCC 32*cdf0e10cSrcweir #endif 33*cdf0e10cSrcweir 34*cdf0e10cSrcweir #include <sfx2/minarray.hxx> 35*cdf0e10cSrcweir 36*cdf0e10cSrcweir // ----------------------------------------------------------------------- 37*cdf0e10cSrcweir 38*cdf0e10cSrcweir SfxPtrArr::SfxPtrArr( sal_uInt8 nInitSize, sal_uInt8 nGrowSize ): 39*cdf0e10cSrcweir nUsed( 0 ), 40*cdf0e10cSrcweir nGrow( nGrowSize ? nGrowSize : 1 ), 41*cdf0e10cSrcweir nUnused( nInitSize ) 42*cdf0e10cSrcweir { 43*cdf0e10cSrcweir DBG_MEMTEST(); 44*cdf0e10cSrcweir sal_uInt16 nMSCBug = nInitSize; 45*cdf0e10cSrcweir 46*cdf0e10cSrcweir if ( nMSCBug > 0 ) 47*cdf0e10cSrcweir pData = new void*[nMSCBug]; 48*cdf0e10cSrcweir else 49*cdf0e10cSrcweir pData = 0; 50*cdf0e10cSrcweir } 51*cdf0e10cSrcweir 52*cdf0e10cSrcweir // ----------------------------------------------------------------------- 53*cdf0e10cSrcweir 54*cdf0e10cSrcweir SfxPtrArr::SfxPtrArr( const SfxPtrArr& rOrig ) 55*cdf0e10cSrcweir { 56*cdf0e10cSrcweir DBG_MEMTEST(); 57*cdf0e10cSrcweir nUsed = rOrig.nUsed; 58*cdf0e10cSrcweir nGrow = rOrig.nGrow; 59*cdf0e10cSrcweir nUnused = rOrig.nUnused; 60*cdf0e10cSrcweir 61*cdf0e10cSrcweir if ( rOrig.pData != 0 ) 62*cdf0e10cSrcweir { 63*cdf0e10cSrcweir pData = new void*[nUsed+nUnused]; 64*cdf0e10cSrcweir memcpy( pData, rOrig.pData, nUsed*sizeof(void*) ); 65*cdf0e10cSrcweir } 66*cdf0e10cSrcweir else 67*cdf0e10cSrcweir pData = 0; 68*cdf0e10cSrcweir } 69*cdf0e10cSrcweir 70*cdf0e10cSrcweir // ----------------------------------------------------------------------- 71*cdf0e10cSrcweir 72*cdf0e10cSrcweir SfxPtrArr::~SfxPtrArr() 73*cdf0e10cSrcweir { 74*cdf0e10cSrcweir DBG_MEMTEST(); 75*cdf0e10cSrcweir delete [] pData; 76*cdf0e10cSrcweir } 77*cdf0e10cSrcweir 78*cdf0e10cSrcweir // ----------------------------------------------------------------------- 79*cdf0e10cSrcweir 80*cdf0e10cSrcweir SfxPtrArr& SfxPtrArr::operator=( const SfxPtrArr& rOrig ) 81*cdf0e10cSrcweir { 82*cdf0e10cSrcweir DBG_MEMTEST(); 83*cdf0e10cSrcweir 84*cdf0e10cSrcweir delete [] pData; 85*cdf0e10cSrcweir 86*cdf0e10cSrcweir nUsed = rOrig.nUsed; 87*cdf0e10cSrcweir nGrow = rOrig.nGrow; 88*cdf0e10cSrcweir nUnused = rOrig.nUnused; 89*cdf0e10cSrcweir 90*cdf0e10cSrcweir if ( rOrig.pData != 0 ) 91*cdf0e10cSrcweir { 92*cdf0e10cSrcweir pData = new void*[nUsed+nUnused]; 93*cdf0e10cSrcweir memcpy( pData, rOrig.pData, nUsed*sizeof(void*) ); 94*cdf0e10cSrcweir } 95*cdf0e10cSrcweir else 96*cdf0e10cSrcweir pData = 0; 97*cdf0e10cSrcweir return *this; 98*cdf0e10cSrcweir } 99*cdf0e10cSrcweir 100*cdf0e10cSrcweir // ----------------------------------------------------------------------- 101*cdf0e10cSrcweir 102*cdf0e10cSrcweir void SfxPtrArr::Append( void* aElem ) 103*cdf0e10cSrcweir { 104*cdf0e10cSrcweir DBG_MEMTEST(); 105*cdf0e10cSrcweir DBG_ASSERT( sal::static_int_cast< unsigned >(nUsed+1) < ( USHRT_MAX / sizeof(void*) ), "array too large" ); 106*cdf0e10cSrcweir // musz das Array umkopiert werden? 107*cdf0e10cSrcweir if ( nUnused == 0 ) 108*cdf0e10cSrcweir { 109*cdf0e10cSrcweir sal_uInt16 nNewSize = (nUsed == 1) ? (nGrow==1 ? 2 : nGrow) : nUsed+nGrow; 110*cdf0e10cSrcweir void** pNewData = new void*[nNewSize]; 111*cdf0e10cSrcweir if ( pData ) 112*cdf0e10cSrcweir { 113*cdf0e10cSrcweir DBG_ASSERT( nUsed <= nNewSize, "" ); 114*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(void*)*nUsed ); 115*cdf0e10cSrcweir delete [] pData; 116*cdf0e10cSrcweir } 117*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize-nUsed); 118*cdf0e10cSrcweir pData = pNewData; 119*cdf0e10cSrcweir } 120*cdf0e10cSrcweir 121*cdf0e10cSrcweir // jetzt hinten in den freien Raum schreiben 122*cdf0e10cSrcweir pData[nUsed] = aElem; 123*cdf0e10cSrcweir ++nUsed; 124*cdf0e10cSrcweir --nUnused; 125*cdf0e10cSrcweir } 126*cdf0e10cSrcweir 127*cdf0e10cSrcweir // ----------------------------------------------------------------------- 128*cdf0e10cSrcweir 129*cdf0e10cSrcweir sal_uInt16 SfxPtrArr::Remove( sal_uInt16 nPos, sal_uInt16 nLen ) 130*cdf0e10cSrcweir { 131*cdf0e10cSrcweir DBG_MEMTEST(); 132*cdf0e10cSrcweir // nLen adjustieren, damit nicht ueber das Ende hinaus geloescht wird 133*cdf0e10cSrcweir nLen = Min( (sal_uInt16)(nUsed-nPos), nLen ); 134*cdf0e10cSrcweir 135*cdf0e10cSrcweir // einfache Aufgaben erfordern einfache Loesungen! 136*cdf0e10cSrcweir if ( nLen == 0 ) 137*cdf0e10cSrcweir return 0; 138*cdf0e10cSrcweir 139*cdf0e10cSrcweir // bleibt vielleicht keiner uebrig 140*cdf0e10cSrcweir if ( (nUsed-nLen) == 0 ) 141*cdf0e10cSrcweir { 142*cdf0e10cSrcweir delete [] pData; 143*cdf0e10cSrcweir pData = 0; 144*cdf0e10cSrcweir nUsed = 0; 145*cdf0e10cSrcweir nUnused = 0; 146*cdf0e10cSrcweir return nLen; 147*cdf0e10cSrcweir } 148*cdf0e10cSrcweir 149*cdf0e10cSrcweir // feststellen, ob das Array dadurch physikalisch schrumpft... 150*cdf0e10cSrcweir if ( (nUnused+nLen) >= nGrow ) 151*cdf0e10cSrcweir { 152*cdf0e10cSrcweir // auf die naechste Grow-Grenze aufgerundet verkleinern 153*cdf0e10cSrcweir sal_uInt16 nNewUsed = nUsed-nLen; 154*cdf0e10cSrcweir sal_uInt16 nNewSize = ((nNewUsed+nGrow-1)/nGrow) * nGrow; 155*cdf0e10cSrcweir DBG_ASSERT( nNewUsed <= nNewSize && nNewUsed+nGrow > nNewSize, 156*cdf0e10cSrcweir "shrink size computation failed" ); 157*cdf0e10cSrcweir void** pNewData = new void*[nNewSize]; 158*cdf0e10cSrcweir if ( nPos > 0 ) 159*cdf0e10cSrcweir { 160*cdf0e10cSrcweir DBG_ASSERT( nPos <= nNewSize, "" ); 161*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(void*)*nPos ); 162*cdf0e10cSrcweir } 163*cdf0e10cSrcweir if ( nNewUsed != nPos ) 164*cdf0e10cSrcweir memmove( pNewData+nPos, pData+nPos+nLen, 165*cdf0e10cSrcweir sizeof(void*)*(nNewUsed-nPos) ); 166*cdf0e10cSrcweir delete [] pData; 167*cdf0e10cSrcweir pData = pNewData; 168*cdf0e10cSrcweir nUsed = nNewUsed; 169*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize - nNewUsed); 170*cdf0e10cSrcweir return nLen; 171*cdf0e10cSrcweir } 172*cdf0e10cSrcweir 173*cdf0e10cSrcweir // in allen anderen Faellen nur zusammenschieben 174*cdf0e10cSrcweir if ( nUsed-nPos-nLen > 0 ) 175*cdf0e10cSrcweir memmove( pData+nPos, pData+nPos+nLen, (nUsed-nPos-nLen)*sizeof(void*) ); 176*cdf0e10cSrcweir nUsed = nUsed - nLen; 177*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nUnused + nLen); 178*cdf0e10cSrcweir return nLen; 179*cdf0e10cSrcweir } 180*cdf0e10cSrcweir 181*cdf0e10cSrcweir // ----------------------------------------------------------------------- 182*cdf0e10cSrcweir 183*cdf0e10cSrcweir sal_Bool SfxPtrArr::Remove( void* aElem ) 184*cdf0e10cSrcweir { 185*cdf0e10cSrcweir DBG_MEMTEST(); 186*cdf0e10cSrcweir // einfache Aufgaben ... 187*cdf0e10cSrcweir if ( nUsed == 0 ) 188*cdf0e10cSrcweir return sal_False; 189*cdf0e10cSrcweir 190*cdf0e10cSrcweir // rueckwaerts, da meist der letzte zuerst wieder entfernt wird 191*cdf0e10cSrcweir void* *pIter = pData + nUsed - 1; 192*cdf0e10cSrcweir for ( sal_uInt16 n = 0; n < nUsed; ++n, --pIter ) 193*cdf0e10cSrcweir if ( *pIter == aElem ) 194*cdf0e10cSrcweir { 195*cdf0e10cSrcweir Remove(nUsed-n-1, 1); 196*cdf0e10cSrcweir return sal_True; 197*cdf0e10cSrcweir } 198*cdf0e10cSrcweir return sal_False; 199*cdf0e10cSrcweir } 200*cdf0e10cSrcweir 201*cdf0e10cSrcweir // ----------------------------------------------------------------------- 202*cdf0e10cSrcweir 203*cdf0e10cSrcweir sal_Bool SfxPtrArr::Replace( void* aOldElem, void* aNewElem ) 204*cdf0e10cSrcweir { 205*cdf0e10cSrcweir DBG_MEMTEST(); 206*cdf0e10cSrcweir // einfache Aufgaben ... 207*cdf0e10cSrcweir if ( nUsed == 0 ) 208*cdf0e10cSrcweir return sal_False; 209*cdf0e10cSrcweir 210*cdf0e10cSrcweir // rueckwaerts, da meist der letzte zuerst wieder entfernt wird 211*cdf0e10cSrcweir void* *pIter = pData + nUsed - 1; 212*cdf0e10cSrcweir for ( sal_uInt16 n = 0; n < nUsed; ++n, --pIter ) 213*cdf0e10cSrcweir if ( *pIter == aOldElem ) 214*cdf0e10cSrcweir { 215*cdf0e10cSrcweir pData[nUsed-n-1] = aNewElem; 216*cdf0e10cSrcweir return sal_True; 217*cdf0e10cSrcweir } 218*cdf0e10cSrcweir return sal_False; 219*cdf0e10cSrcweir } 220*cdf0e10cSrcweir 221*cdf0e10cSrcweir // ----------------------------------------------------------------------- 222*cdf0e10cSrcweir 223*cdf0e10cSrcweir sal_Bool SfxPtrArr::Contains( const void* rItem ) const 224*cdf0e10cSrcweir { 225*cdf0e10cSrcweir DBG_MEMTEST(); 226*cdf0e10cSrcweir if ( !nUsed ) 227*cdf0e10cSrcweir return sal_False; 228*cdf0e10cSrcweir 229*cdf0e10cSrcweir for ( sal_uInt16 n = 0; n < nUsed; ++n ) 230*cdf0e10cSrcweir { 231*cdf0e10cSrcweir void* p = GetObject(n); 232*cdf0e10cSrcweir if ( p == rItem ) 233*cdf0e10cSrcweir return sal_True; 234*cdf0e10cSrcweir } 235*cdf0e10cSrcweir 236*cdf0e10cSrcweir return sal_False; 237*cdf0e10cSrcweir } 238*cdf0e10cSrcweir 239*cdf0e10cSrcweir // ----------------------------------------------------------------------- 240*cdf0e10cSrcweir 241*cdf0e10cSrcweir void SfxPtrArr::Insert( sal_uInt16 nPos, void* rElem ) 242*cdf0e10cSrcweir { 243*cdf0e10cSrcweir DBG_MEMTEST(); 244*cdf0e10cSrcweir DBG_ASSERT( sal::static_int_cast< unsigned >(nUsed+1) < ( USHRT_MAX / sizeof(void*) ), "array too large" ); 245*cdf0e10cSrcweir // musz das Array umkopiert werden? 246*cdf0e10cSrcweir if ( nUnused == 0 ) 247*cdf0e10cSrcweir { 248*cdf0e10cSrcweir // auf die naechste Grow-Grenze aufgerundet vergroeszern 249*cdf0e10cSrcweir sal_uInt16 nNewSize = nUsed+nGrow; 250*cdf0e10cSrcweir void** pNewData = new void*[nNewSize]; 251*cdf0e10cSrcweir 252*cdf0e10cSrcweir if ( pData ) 253*cdf0e10cSrcweir { 254*cdf0e10cSrcweir DBG_ASSERT( nUsed < nNewSize, "" ); 255*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(void*)*nUsed ); 256*cdf0e10cSrcweir delete [] pData; 257*cdf0e10cSrcweir } 258*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize-nUsed); 259*cdf0e10cSrcweir pData = pNewData; 260*cdf0e10cSrcweir } 261*cdf0e10cSrcweir 262*cdf0e10cSrcweir // jetzt den hinteren Teil verschieben 263*cdf0e10cSrcweir if ( nPos < nUsed ) 264*cdf0e10cSrcweir memmove( pData+nPos+1, pData+nPos, (nUsed-nPos)*sizeof(void*) ); 265*cdf0e10cSrcweir 266*cdf0e10cSrcweir // jetzt in den freien Raum schreiben 267*cdf0e10cSrcweir memmove( pData+nPos, &rElem, sizeof(void*) ); 268*cdf0e10cSrcweir nUsed += 1; 269*cdf0e10cSrcweir nUnused -= 1; 270*cdf0e10cSrcweir } 271*cdf0e10cSrcweir 272*cdf0e10cSrcweir // class ByteArr --------------------------------------------------------- 273*cdf0e10cSrcweir 274*cdf0e10cSrcweir ByteArr::ByteArr( sal_uInt8 nInitSize, sal_uInt8 nGrowSize ): 275*cdf0e10cSrcweir nUsed( 0 ), 276*cdf0e10cSrcweir nGrow( nGrowSize ? nGrowSize : 1 ), 277*cdf0e10cSrcweir nUnused( nInitSize ) 278*cdf0e10cSrcweir { 279*cdf0e10cSrcweir DBG_MEMTEST(); 280*cdf0e10cSrcweir sal_uInt16 nMSCBug = nInitSize; 281*cdf0e10cSrcweir 282*cdf0e10cSrcweir if ( nInitSize > 0 ) 283*cdf0e10cSrcweir pData = new char[nMSCBug]; 284*cdf0e10cSrcweir else 285*cdf0e10cSrcweir pData = 0; 286*cdf0e10cSrcweir } 287*cdf0e10cSrcweir 288*cdf0e10cSrcweir // ----------------------------------------------------------------------- 289*cdf0e10cSrcweir 290*cdf0e10cSrcweir ByteArr::ByteArr( const ByteArr& rOrig ) 291*cdf0e10cSrcweir { 292*cdf0e10cSrcweir DBG_MEMTEST(); 293*cdf0e10cSrcweir nUsed = rOrig.nUsed; 294*cdf0e10cSrcweir nGrow = rOrig.nGrow; 295*cdf0e10cSrcweir nUnused = rOrig.nUnused; 296*cdf0e10cSrcweir 297*cdf0e10cSrcweir if ( rOrig.pData != 0 ) 298*cdf0e10cSrcweir { 299*cdf0e10cSrcweir pData = new char[nUsed+nUnused]; 300*cdf0e10cSrcweir memcpy( pData, rOrig.pData, nUsed*sizeof(char) ); 301*cdf0e10cSrcweir } 302*cdf0e10cSrcweir else 303*cdf0e10cSrcweir pData = 0; 304*cdf0e10cSrcweir } 305*cdf0e10cSrcweir 306*cdf0e10cSrcweir // ----------------------------------------------------------------------- 307*cdf0e10cSrcweir 308*cdf0e10cSrcweir ByteArr::~ByteArr() 309*cdf0e10cSrcweir { 310*cdf0e10cSrcweir DBG_MEMTEST(); 311*cdf0e10cSrcweir delete [] pData; 312*cdf0e10cSrcweir } 313*cdf0e10cSrcweir 314*cdf0e10cSrcweir // ----------------------------------------------------------------------- 315*cdf0e10cSrcweir 316*cdf0e10cSrcweir ByteArr& ByteArr::operator=( const ByteArr& rOrig ) 317*cdf0e10cSrcweir { 318*cdf0e10cSrcweir DBG_MEMTEST(); 319*cdf0e10cSrcweir 320*cdf0e10cSrcweir delete [] pData; 321*cdf0e10cSrcweir 322*cdf0e10cSrcweir nUsed = rOrig.nUsed; 323*cdf0e10cSrcweir nGrow = rOrig.nGrow; 324*cdf0e10cSrcweir nUnused = rOrig.nUnused; 325*cdf0e10cSrcweir 326*cdf0e10cSrcweir if ( rOrig.pData != 0 ) 327*cdf0e10cSrcweir { 328*cdf0e10cSrcweir pData = new char[nUsed+nUnused]; 329*cdf0e10cSrcweir memcpy( pData, rOrig.pData, nUsed*sizeof(char) ); 330*cdf0e10cSrcweir } 331*cdf0e10cSrcweir else 332*cdf0e10cSrcweir pData = 0; 333*cdf0e10cSrcweir return *this; 334*cdf0e10cSrcweir } 335*cdf0e10cSrcweir 336*cdf0e10cSrcweir // ----------------------------------------------------------------------- 337*cdf0e10cSrcweir 338*cdf0e10cSrcweir void ByteArr::Append( char aElem ) 339*cdf0e10cSrcweir { 340*cdf0e10cSrcweir DBG_MEMTEST(); 341*cdf0e10cSrcweir // musz das Array umkopiert werden? 342*cdf0e10cSrcweir if ( nUnused == 0 ) 343*cdf0e10cSrcweir { 344*cdf0e10cSrcweir sal_uInt16 nNewSize = (nUsed == 1) ? (nGrow==1 ? 2 : nGrow) : nUsed+nGrow; 345*cdf0e10cSrcweir char* pNewData = new char[nNewSize]; 346*cdf0e10cSrcweir if ( pData ) 347*cdf0e10cSrcweir { 348*cdf0e10cSrcweir DBG_ASSERT( nUsed <= nNewSize, "" ); 349*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(char)*nUsed ); 350*cdf0e10cSrcweir delete [] pData; 351*cdf0e10cSrcweir } 352*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize-nUsed); 353*cdf0e10cSrcweir pData = pNewData; 354*cdf0e10cSrcweir } 355*cdf0e10cSrcweir 356*cdf0e10cSrcweir // jetzt hinten in den freien Raum schreiben 357*cdf0e10cSrcweir pData[nUsed] = aElem; 358*cdf0e10cSrcweir ++nUsed; 359*cdf0e10cSrcweir --nUnused; 360*cdf0e10cSrcweir } 361*cdf0e10cSrcweir 362*cdf0e10cSrcweir // ----------------------------------------------------------------------- 363*cdf0e10cSrcweir 364*cdf0e10cSrcweir sal_uInt16 ByteArr::Remove( sal_uInt16 nPos, sal_uInt16 nLen ) 365*cdf0e10cSrcweir { 366*cdf0e10cSrcweir DBG_MEMTEST(); 367*cdf0e10cSrcweir // nLen adjustieren, damit nicht ueber das Ende hinaus geloescht wird 368*cdf0e10cSrcweir nLen = Min( (sal_uInt16)(nUsed-nPos), nLen ); 369*cdf0e10cSrcweir 370*cdf0e10cSrcweir // einfache Aufgaben erfordern einfache Loesungen! 371*cdf0e10cSrcweir if ( nLen == 0 ) 372*cdf0e10cSrcweir return 0; 373*cdf0e10cSrcweir 374*cdf0e10cSrcweir // bleibt vielleicht keiner uebrig 375*cdf0e10cSrcweir if ( (nUsed-nLen) == 0 ) 376*cdf0e10cSrcweir { 377*cdf0e10cSrcweir delete [] pData; 378*cdf0e10cSrcweir pData = 0; 379*cdf0e10cSrcweir nUsed = 0; 380*cdf0e10cSrcweir nUnused = 0; 381*cdf0e10cSrcweir return nLen; 382*cdf0e10cSrcweir } 383*cdf0e10cSrcweir 384*cdf0e10cSrcweir // feststellen, ob das Array dadurch physikalisch schrumpft... 385*cdf0e10cSrcweir if ( (nUnused+nLen) >= nGrow ) 386*cdf0e10cSrcweir { 387*cdf0e10cSrcweir // auf die naechste Grow-Grenze aufgerundet verkleinern 388*cdf0e10cSrcweir sal_uInt16 nNewUsed = nUsed-nLen; 389*cdf0e10cSrcweir sal_uInt16 nNewSize = ((nNewUsed+nGrow-1)/nGrow) * nGrow; 390*cdf0e10cSrcweir DBG_ASSERT( nNewUsed <= nNewSize && nNewUsed+nGrow > nNewSize, 391*cdf0e10cSrcweir "shrink size computation failed" ); 392*cdf0e10cSrcweir char* pNewData = new char[nNewSize]; 393*cdf0e10cSrcweir if ( nPos > 0 ) 394*cdf0e10cSrcweir { 395*cdf0e10cSrcweir DBG_ASSERT( nPos <= nNewSize, "" ); 396*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(char)*nPos ); 397*cdf0e10cSrcweir } 398*cdf0e10cSrcweir if ( nNewUsed != nPos ) 399*cdf0e10cSrcweir memmove( pNewData+nPos, pData+nPos+nLen, 400*cdf0e10cSrcweir sizeof(char)*(nNewUsed-nPos) ); 401*cdf0e10cSrcweir delete [] pData; 402*cdf0e10cSrcweir pData = pNewData; 403*cdf0e10cSrcweir nUsed = nNewUsed; 404*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize - nNewUsed); 405*cdf0e10cSrcweir return nLen; 406*cdf0e10cSrcweir } 407*cdf0e10cSrcweir 408*cdf0e10cSrcweir // in allen anderen Faellen nur zusammenschieben 409*cdf0e10cSrcweir if ( nUsed-nPos-nLen > 0 ) 410*cdf0e10cSrcweir memmove( pData+nPos, pData+nPos+nLen, (nUsed-nPos-nLen)*sizeof(char) ); 411*cdf0e10cSrcweir nUsed = nUsed - nLen; 412*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nUnused + nLen); 413*cdf0e10cSrcweir return nLen; 414*cdf0e10cSrcweir } 415*cdf0e10cSrcweir 416*cdf0e10cSrcweir // ----------------------------------------------------------------------- 417*cdf0e10cSrcweir 418*cdf0e10cSrcweir sal_Bool ByteArr::Remove( char aElem ) 419*cdf0e10cSrcweir { 420*cdf0e10cSrcweir DBG_MEMTEST(); 421*cdf0e10cSrcweir // einfache Aufgaben ... 422*cdf0e10cSrcweir if ( nUsed == 0 ) 423*cdf0e10cSrcweir return sal_False; 424*cdf0e10cSrcweir 425*cdf0e10cSrcweir // rueckwaerts, da meist der letzte zuerst wieder entfernt wird 426*cdf0e10cSrcweir char *pIter = pData + nUsed - 1; 427*cdf0e10cSrcweir for ( sal_uInt16 n = 0; n < nUsed; ++n, --pIter ) 428*cdf0e10cSrcweir if ( *pIter == aElem ) 429*cdf0e10cSrcweir { 430*cdf0e10cSrcweir Remove(nUsed-n-1, 1); 431*cdf0e10cSrcweir return sal_True; 432*cdf0e10cSrcweir } 433*cdf0e10cSrcweir return sal_False; 434*cdf0e10cSrcweir } 435*cdf0e10cSrcweir 436*cdf0e10cSrcweir // ----------------------------------------------------------------------- 437*cdf0e10cSrcweir 438*cdf0e10cSrcweir sal_Bool ByteArr::Contains( const char rItem ) const 439*cdf0e10cSrcweir { 440*cdf0e10cSrcweir DBG_MEMTEST(); 441*cdf0e10cSrcweir if ( !nUsed ) 442*cdf0e10cSrcweir return sal_False; 443*cdf0e10cSrcweir 444*cdf0e10cSrcweir for ( sal_uInt16 n = 0; n < nUsed; ++n ) 445*cdf0e10cSrcweir { 446*cdf0e10cSrcweir char p = GetObject(n); 447*cdf0e10cSrcweir if ( p == rItem ) 448*cdf0e10cSrcweir return sal_True; 449*cdf0e10cSrcweir } 450*cdf0e10cSrcweir 451*cdf0e10cSrcweir return sal_False; 452*cdf0e10cSrcweir } 453*cdf0e10cSrcweir 454*cdf0e10cSrcweir // ----------------------------------------------------------------------- 455*cdf0e10cSrcweir 456*cdf0e10cSrcweir void ByteArr::Insert( sal_uInt16 nPos, char rElem ) 457*cdf0e10cSrcweir { 458*cdf0e10cSrcweir DBG_MEMTEST(); 459*cdf0e10cSrcweir // musz das Array umkopiert werden? 460*cdf0e10cSrcweir if ( nUnused == 0 ) 461*cdf0e10cSrcweir { 462*cdf0e10cSrcweir // auf die naechste Grow-Grenze aufgerundet vergroeszern 463*cdf0e10cSrcweir sal_uInt16 nNewSize = nUsed+nGrow; 464*cdf0e10cSrcweir char* pNewData = new char[nNewSize]; 465*cdf0e10cSrcweir 466*cdf0e10cSrcweir if ( pData ) 467*cdf0e10cSrcweir { 468*cdf0e10cSrcweir DBG_ASSERT( nUsed < nNewSize, "" ); 469*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(char)*nUsed ); 470*cdf0e10cSrcweir delete [] pData; 471*cdf0e10cSrcweir } 472*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize-nUsed); 473*cdf0e10cSrcweir pData = pNewData; 474*cdf0e10cSrcweir } 475*cdf0e10cSrcweir 476*cdf0e10cSrcweir // jetzt den hinteren Teil verschieben 477*cdf0e10cSrcweir if ( nPos < nUsed ) 478*cdf0e10cSrcweir memmove( pData+nPos+1, pData+nPos, (nUsed-nPos)*sizeof(char) ); 479*cdf0e10cSrcweir 480*cdf0e10cSrcweir // jetzt in den freien Raum schreiben 481*cdf0e10cSrcweir memmove( pData+nPos, &rElem, sizeof(char) ); 482*cdf0e10cSrcweir nUsed += 1; 483*cdf0e10cSrcweir nUnused -= 1; 484*cdf0e10cSrcweir } 485*cdf0e10cSrcweir 486*cdf0e10cSrcweir // ----------------------------------------------------------------------- 487*cdf0e10cSrcweir 488*cdf0e10cSrcweir char ByteArr::operator[]( sal_uInt16 nPos ) const 489*cdf0e10cSrcweir { 490*cdf0e10cSrcweir DBG_MEMTEST(); 491*cdf0e10cSrcweir DBG_ASSERT( nPos < nUsed, "" ); 492*cdf0e10cSrcweir return *(pData+nPos); 493*cdf0e10cSrcweir } 494*cdf0e10cSrcweir 495*cdf0e10cSrcweir // ----------------------------------------------------------------------- 496*cdf0e10cSrcweir 497*cdf0e10cSrcweir char& ByteArr::operator [] (sal_uInt16 nPos) 498*cdf0e10cSrcweir { 499*cdf0e10cSrcweir DBG_MEMTEST(); 500*cdf0e10cSrcweir DBG_ASSERT( nPos < nUsed, "" ); 501*cdf0e10cSrcweir return *(pData+nPos); 502*cdf0e10cSrcweir } 503*cdf0e10cSrcweir 504*cdf0e10cSrcweir // class WordArr --------------------------------------------------------- 505*cdf0e10cSrcweir 506*cdf0e10cSrcweir WordArr::WordArr( sal_uInt8 nInitSize, sal_uInt8 nGrowSize ): 507*cdf0e10cSrcweir nUsed( 0 ), 508*cdf0e10cSrcweir nGrow( nGrowSize ? nGrowSize : 1 ), 509*cdf0e10cSrcweir nUnused( nInitSize ) 510*cdf0e10cSrcweir { 511*cdf0e10cSrcweir DBG_MEMTEST(); 512*cdf0e10cSrcweir sal_uInt16 nMSCBug = nInitSize; 513*cdf0e10cSrcweir 514*cdf0e10cSrcweir if ( nInitSize > 0 ) 515*cdf0e10cSrcweir pData = new short[nMSCBug]; 516*cdf0e10cSrcweir else 517*cdf0e10cSrcweir pData = 0; 518*cdf0e10cSrcweir } 519*cdf0e10cSrcweir 520*cdf0e10cSrcweir // ----------------------------------------------------------------------- 521*cdf0e10cSrcweir 522*cdf0e10cSrcweir WordArr::WordArr( const WordArr& rOrig ) 523*cdf0e10cSrcweir { 524*cdf0e10cSrcweir DBG_MEMTEST(); 525*cdf0e10cSrcweir nUsed = rOrig.nUsed; 526*cdf0e10cSrcweir nGrow = rOrig.nGrow; 527*cdf0e10cSrcweir nUnused = rOrig.nUnused; 528*cdf0e10cSrcweir 529*cdf0e10cSrcweir if ( rOrig.pData != 0 ) 530*cdf0e10cSrcweir { 531*cdf0e10cSrcweir pData = new short[nUsed+nUnused]; 532*cdf0e10cSrcweir memcpy( pData, rOrig.pData, nUsed*sizeof(short) ); 533*cdf0e10cSrcweir } 534*cdf0e10cSrcweir else 535*cdf0e10cSrcweir pData = 0; 536*cdf0e10cSrcweir } 537*cdf0e10cSrcweir 538*cdf0e10cSrcweir // ----------------------------------------------------------------------- 539*cdf0e10cSrcweir 540*cdf0e10cSrcweir WordArr::~WordArr() 541*cdf0e10cSrcweir { 542*cdf0e10cSrcweir DBG_MEMTEST(); 543*cdf0e10cSrcweir delete [] pData; 544*cdf0e10cSrcweir } 545*cdf0e10cSrcweir 546*cdf0e10cSrcweir // ----------------------------------------------------------------------- 547*cdf0e10cSrcweir 548*cdf0e10cSrcweir WordArr& WordArr::operator=( const WordArr& rOrig ) 549*cdf0e10cSrcweir { 550*cdf0e10cSrcweir DBG_MEMTEST(); 551*cdf0e10cSrcweir 552*cdf0e10cSrcweir delete [] pData; 553*cdf0e10cSrcweir 554*cdf0e10cSrcweir nUsed = rOrig.nUsed; 555*cdf0e10cSrcweir nGrow = rOrig.nGrow; 556*cdf0e10cSrcweir nUnused = rOrig.nUnused; 557*cdf0e10cSrcweir 558*cdf0e10cSrcweir if ( rOrig.pData != 0 ) 559*cdf0e10cSrcweir { 560*cdf0e10cSrcweir pData = new short[nUsed+nUnused]; 561*cdf0e10cSrcweir memcpy( pData, rOrig.pData, nUsed*sizeof(short) ); 562*cdf0e10cSrcweir } 563*cdf0e10cSrcweir else 564*cdf0e10cSrcweir pData = 0; 565*cdf0e10cSrcweir return *this; 566*cdf0e10cSrcweir } 567*cdf0e10cSrcweir 568*cdf0e10cSrcweir // ----------------------------------------------------------------------- 569*cdf0e10cSrcweir 570*cdf0e10cSrcweir void WordArr::Append( short aElem ) 571*cdf0e10cSrcweir { 572*cdf0e10cSrcweir DBG_MEMTEST(); 573*cdf0e10cSrcweir // musz das Array umkopiert werden? 574*cdf0e10cSrcweir if ( nUnused == 0 ) 575*cdf0e10cSrcweir { 576*cdf0e10cSrcweir sal_uInt16 nNewSize = (nUsed == 1) ? (nGrow==1 ? 2 : nGrow) : nUsed+nGrow; 577*cdf0e10cSrcweir short* pNewData = new short[nNewSize]; 578*cdf0e10cSrcweir if ( pData ) 579*cdf0e10cSrcweir { 580*cdf0e10cSrcweir DBG_ASSERT( nUsed <= nNewSize, " " ); 581*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(short)*nUsed ); 582*cdf0e10cSrcweir delete [] pData; 583*cdf0e10cSrcweir } 584*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize-nUsed); 585*cdf0e10cSrcweir pData = pNewData; 586*cdf0e10cSrcweir } 587*cdf0e10cSrcweir 588*cdf0e10cSrcweir // jetzt hinten in den freien Raum schreiben 589*cdf0e10cSrcweir pData[nUsed] = aElem; 590*cdf0e10cSrcweir ++nUsed; 591*cdf0e10cSrcweir --nUnused; 592*cdf0e10cSrcweir } 593*cdf0e10cSrcweir 594*cdf0e10cSrcweir // ----------------------------------------------------------------------- 595*cdf0e10cSrcweir 596*cdf0e10cSrcweir sal_uInt16 WordArr::Remove( sal_uInt16 nPos, sal_uInt16 nLen ) 597*cdf0e10cSrcweir { 598*cdf0e10cSrcweir DBG_MEMTEST(); 599*cdf0e10cSrcweir // nLen adjustieren, damit nicht ueber das Ende hinaus geloescht wird 600*cdf0e10cSrcweir nLen = Min( (sal_uInt16)(nUsed-nPos), nLen ); 601*cdf0e10cSrcweir 602*cdf0e10cSrcweir // einfache Aufgaben erfordern einfache Loesungen! 603*cdf0e10cSrcweir if ( nLen == 0 ) 604*cdf0e10cSrcweir return 0; 605*cdf0e10cSrcweir 606*cdf0e10cSrcweir // bleibt vielleicht keiner uebrig 607*cdf0e10cSrcweir if ( (nUsed-nLen) == 0 ) 608*cdf0e10cSrcweir { 609*cdf0e10cSrcweir delete [] pData; 610*cdf0e10cSrcweir pData = 0; 611*cdf0e10cSrcweir nUsed = 0; 612*cdf0e10cSrcweir nUnused = 0; 613*cdf0e10cSrcweir return nLen; 614*cdf0e10cSrcweir } 615*cdf0e10cSrcweir 616*cdf0e10cSrcweir // feststellen, ob das Array dadurch physikalisch schrumpft... 617*cdf0e10cSrcweir if ( (nUnused+nLen) >= nGrow ) 618*cdf0e10cSrcweir { 619*cdf0e10cSrcweir // auf die naechste Grow-Grenze aufgerundet verkleinern 620*cdf0e10cSrcweir sal_uInt16 nNewUsed = nUsed-nLen; 621*cdf0e10cSrcweir sal_uInt16 nNewSize = ((nNewUsed+nGrow-1)/nGrow) * nGrow; 622*cdf0e10cSrcweir DBG_ASSERT( nNewUsed <= nNewSize && nNewUsed+nGrow > nNewSize, 623*cdf0e10cSrcweir "shrink size computation failed" ); 624*cdf0e10cSrcweir short* pNewData = new short[nNewSize]; 625*cdf0e10cSrcweir if ( nPos > 0 ) 626*cdf0e10cSrcweir { 627*cdf0e10cSrcweir DBG_ASSERT( nPos <= nNewSize, "" ); 628*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(short)*nPos ); 629*cdf0e10cSrcweir } 630*cdf0e10cSrcweir if ( nNewUsed != nPos ) 631*cdf0e10cSrcweir memmove( pNewData+nPos, pData+nPos+nLen, 632*cdf0e10cSrcweir sizeof(short)*(nNewUsed-nPos) ); 633*cdf0e10cSrcweir delete [] pData; 634*cdf0e10cSrcweir pData = pNewData; 635*cdf0e10cSrcweir nUsed = nNewUsed; 636*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize - nNewUsed); 637*cdf0e10cSrcweir return nLen; 638*cdf0e10cSrcweir } 639*cdf0e10cSrcweir 640*cdf0e10cSrcweir // in allen anderen Faellen nur zusammenschieben 641*cdf0e10cSrcweir if ( nUsed-nPos-nLen > 0 ) 642*cdf0e10cSrcweir memmove( pData+nPos, pData+nPos+nLen, (nUsed-nPos-nLen)*sizeof(short) ); 643*cdf0e10cSrcweir nUsed = nUsed - nLen; 644*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nUnused + nLen); 645*cdf0e10cSrcweir return nLen; 646*cdf0e10cSrcweir } 647*cdf0e10cSrcweir 648*cdf0e10cSrcweir // ----------------------------------------------------------------------- 649*cdf0e10cSrcweir 650*cdf0e10cSrcweir sal_Bool WordArr::Remove( short aElem ) 651*cdf0e10cSrcweir { 652*cdf0e10cSrcweir DBG_MEMTEST(); 653*cdf0e10cSrcweir // einfache Aufgaben ... 654*cdf0e10cSrcweir if ( nUsed == 0 ) 655*cdf0e10cSrcweir return sal_False; 656*cdf0e10cSrcweir 657*cdf0e10cSrcweir // rueckwaerts, da meist der letzte zuerst wieder entfernt wird 658*cdf0e10cSrcweir short *pIter = pData + nUsed - 1; 659*cdf0e10cSrcweir for ( sal_uInt16 n = 0; n < nUsed; ++n, --pIter ) 660*cdf0e10cSrcweir if ( *pIter == aElem ) 661*cdf0e10cSrcweir { 662*cdf0e10cSrcweir Remove(nUsed-n-1, 1); 663*cdf0e10cSrcweir return sal_True; 664*cdf0e10cSrcweir } 665*cdf0e10cSrcweir return sal_False; 666*cdf0e10cSrcweir } 667*cdf0e10cSrcweir 668*cdf0e10cSrcweir // ----------------------------------------------------------------------- 669*cdf0e10cSrcweir 670*cdf0e10cSrcweir sal_Bool WordArr::Contains( const short rItem ) const 671*cdf0e10cSrcweir { 672*cdf0e10cSrcweir DBG_MEMTEST(); 673*cdf0e10cSrcweir if ( !nUsed ) 674*cdf0e10cSrcweir return sal_False; 675*cdf0e10cSrcweir 676*cdf0e10cSrcweir for ( sal_uInt16 n = 0; n < nUsed; ++n ) 677*cdf0e10cSrcweir { 678*cdf0e10cSrcweir short p = GetObject(n); 679*cdf0e10cSrcweir if ( p == rItem ) 680*cdf0e10cSrcweir return sal_True; 681*cdf0e10cSrcweir } 682*cdf0e10cSrcweir 683*cdf0e10cSrcweir return sal_False; 684*cdf0e10cSrcweir } 685*cdf0e10cSrcweir 686*cdf0e10cSrcweir // ----------------------------------------------------------------------- 687*cdf0e10cSrcweir 688*cdf0e10cSrcweir void WordArr::Insert( sal_uInt16 nPos, short rElem ) 689*cdf0e10cSrcweir { 690*cdf0e10cSrcweir DBG_MEMTEST(); 691*cdf0e10cSrcweir // musz das Array umkopiert werden? 692*cdf0e10cSrcweir if ( nUnused == 0 ) 693*cdf0e10cSrcweir { 694*cdf0e10cSrcweir // auf die naechste Grow-Grenze aufgerundet vergroeszern 695*cdf0e10cSrcweir sal_uInt16 nNewSize = nUsed+nGrow; 696*cdf0e10cSrcweir short* pNewData = new short[nNewSize]; 697*cdf0e10cSrcweir 698*cdf0e10cSrcweir if ( pData ) 699*cdf0e10cSrcweir { 700*cdf0e10cSrcweir DBG_ASSERT( nUsed < nNewSize, "" ); 701*cdf0e10cSrcweir memmove( pNewData, pData, sizeof(short)*nUsed ); 702*cdf0e10cSrcweir delete [] pData; 703*cdf0e10cSrcweir } 704*cdf0e10cSrcweir nUnused = sal::static_int_cast< sal_uInt8 >(nNewSize-nUsed); 705*cdf0e10cSrcweir pData = pNewData; 706*cdf0e10cSrcweir } 707*cdf0e10cSrcweir 708*cdf0e10cSrcweir // jetzt den hinteren Teil verschieben 709*cdf0e10cSrcweir if ( nPos < nUsed ) 710*cdf0e10cSrcweir memmove( pData+nPos+1, pData+nPos, (nUsed-nPos)*sizeof(short) ); 711*cdf0e10cSrcweir 712*cdf0e10cSrcweir // jetzt in den freien Raum schreiben 713*cdf0e10cSrcweir memmove( pData+nPos, &rElem, sizeof(short) ); 714*cdf0e10cSrcweir nUsed += 1; 715*cdf0e10cSrcweir nUnused -= 1; 716*cdf0e10cSrcweir } 717*cdf0e10cSrcweir 718*cdf0e10cSrcweir // ----------------------------------------------------------------------- 719*cdf0e10cSrcweir 720*cdf0e10cSrcweir short WordArr::operator[]( sal_uInt16 nPos ) const 721*cdf0e10cSrcweir { 722*cdf0e10cSrcweir DBG_MEMTEST(); 723*cdf0e10cSrcweir DBG_ASSERT( nPos < nUsed, "" ); 724*cdf0e10cSrcweir return *(pData+nPos); 725*cdf0e10cSrcweir } 726*cdf0e10cSrcweir 727*cdf0e10cSrcweir // ----------------------------------------------------------------------- 728*cdf0e10cSrcweir 729*cdf0e10cSrcweir short& WordArr::operator [] (sal_uInt16 nPos) 730*cdf0e10cSrcweir { 731*cdf0e10cSrcweir DBG_MEMTEST(); 732*cdf0e10cSrcweir DBG_ASSERT( nPos < nUsed, "" ); 733*cdf0e10cSrcweir return *(pData+nPos); 734*cdf0e10cSrcweir } 735*cdf0e10cSrcweir 736*cdf0e10cSrcweir 737