/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: index.hxx,v $ * * $Revision: 1.5 $ * * last change: $Author: rt $ $Date: 2005-09-09 01:58:34 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ #ifndef _INDEX_HXX #define _INDEX_HXX #include #ifndef _SOLAR_H #include #endif #ifndef _RTTI_HXX #include // for RTTI of SwIndexReg #endif #ifndef _STRING_HXX #include // for xub_StrLen #endif #define INVALID_INDEX STRING_NOTFOUND // Maximale Anzahl von Indizies im IndexArray (zum Abtesten auf Ueberlaeufe) class SwIndex; class SwIndexReg; #ifdef PRODUCT #define INLINE inline #else #define INLINE #endif class SwIndex { friend class SwIndexReg; #ifndef PRODUCT static int nSerial; int MySerial; #endif xub_StrLen nIndex; SwIndexReg* pArray; SwIndex *pNext, *pPrev; SwIndex& ChgValue( const SwIndex& rIdx, xub_StrLen nNewValue ); void Remove(); // Ausketten public: SwIndex( SwIndexReg * pReg, xub_StrLen nIdx = 0 ); SwIndex( const SwIndex & ); SwIndex( const SwIndex &, short nDiff ); ~SwIndex() { Remove(); } INLINE xub_StrLen operator++(); INLINE xub_StrLen operator--(); #ifndef CFRONT INLINE xub_StrLen operator++(int); INLINE xub_StrLen operator--(int); #endif INLINE xub_StrLen operator+=( xub_StrLen ); INLINE xub_StrLen operator-=( xub_StrLen ); INLINE xub_StrLen operator+=( const SwIndex& ); INLINE xub_StrLen operator-=( const SwIndex& ); INLINE BOOL operator<( const SwIndex& ) const; INLINE BOOL operator<=( const SwIndex& ) const; INLINE BOOL operator>( const SwIndex& ) const; INLINE BOOL operator>=( const SwIndex& ) const; BOOL operator==( const SwIndex& rSwIndex ) const { return (nIndex == rSwIndex.nIndex) && (pArray == rSwIndex.pArray); } BOOL operator!=( const SwIndex& rSwIndex ) const { return (nIndex != rSwIndex.nIndex) || (pArray != rSwIndex.pArray); } BOOL operator<( xub_StrLen nWert ) const { return nIndex < nWert; } BOOL operator<=( xub_StrLen nWert ) const { return nIndex <= nWert; } BOOL operator>( xub_StrLen nWert ) const { return nIndex > nWert; } BOOL operator>=( xub_StrLen nWert ) const { return nIndex >= nWert; } BOOL operator==( xub_StrLen nWert ) const { return nIndex == nWert; } BOOL operator!=( xub_StrLen nWert ) const { return nIndex != nWert; } INLINE SwIndex& operator=( xub_StrLen ); SwIndex& operator=( const SwIndex & ); // gebe den Wert vom Index als xub_StrLen zurueck xub_StrLen GetIndex() const { return nIndex; } // ermoeglicht Zuweisungen ohne Erzeugen eines temporaeren // Objektes SwIndex &Assign(SwIndexReg *,xub_StrLen); // Herausgabe des Pointers auf das IndexArray, // (fuers RTTI am SwIndexReg) const SwIndexReg* GetIdxReg() const { return pArray; } }; #undef INLINE class SwIndexReg { friend class SwIndex; const SwIndex *pFirst, *pLast, *pMiddle; // ein globales Array, in das Indizies verschoben werden, die mal // temporaer "ausgelagert" werden muessen; oder die zum Zeitpunkt des // anlegens kein gueltiges Array kennen (SwPaM/SwPosition!) friend void _InitCore(); friend void _FinitCore(); static SwIndexReg* pEmptyIndexArray; protected: virtual void Update( const SwIndex & aPos, xub_StrLen nLen, BOOL bNegativ = FALSE, BOOL bDelete = FALSE ); void ChkArr(); BOOL HasAnyIndex() const { return 0 != pFirst; } public: SwIndexReg(); #ifndef PRODUCT ~SwIndexReg(); #endif // rtti, abgeleitete moegens gleichtun oder nicht. Wenn sie es gleichtun // kann ueber das SwIndexReg typsicher gecastet werden. TYPEINFO(); void SetDefMiddle( const SwIndex* pIdx ) { pMiddle = pIdx; } void MoveTo( SwIndexReg& rArr ); }; #ifdef PRODUCT inline xub_StrLen SwIndex::operator++() { return ChgValue( *this, nIndex+1 ).nIndex; } inline xub_StrLen SwIndex::operator--() { return ChgValue( *this, nIndex-1 ).nIndex; } #ifndef CFRONT inline xub_StrLen SwIndex::operator++(int) { xub_StrLen nOldIndex = nIndex; ChgValue( *this, nIndex+1 ); return nOldIndex; } inline xub_StrLen SwIndex::operator--(int) { xub_StrLen nOldIndex = nIndex; ChgValue( *this, nIndex-1 ); return nOldIndex; } #endif inline xub_StrLen SwIndex::operator+=( xub_StrLen nWert ) { return ChgValue( *this, nIndex + nWert ).nIndex; } inline xub_StrLen SwIndex::operator-=( xub_StrLen nWert ) { return ChgValue( *this, nIndex - nWert ).nIndex; } inline xub_StrLen SwIndex::operator+=( const SwIndex& rIndex ) { return ChgValue( *this, nIndex + rIndex.nIndex ).nIndex; } inline xub_StrLen SwIndex::operator-=( const SwIndex& rIndex ) { return ChgValue( *this, nIndex - rIndex.nIndex ).nIndex; } inline BOOL SwIndex::operator<( const SwIndex& rIndex ) const { return nIndex < rIndex.nIndex; } inline BOOL SwIndex::operator<=( const SwIndex& rIndex ) const { return nIndex <= rIndex.nIndex; } inline BOOL SwIndex::operator>( const SwIndex& rIndex ) const { return nIndex > rIndex.nIndex; } inline BOOL SwIndex::operator>=( const SwIndex& rIndex ) const { return nIndex >= rIndex.nIndex; } inline SwIndex& SwIndex::operator=( xub_StrLen nWert ) { if( nIndex != nWert ) ChgValue( *this, nWert ); return *this; } // PRODUCT #endif #endif