/************************************************************************* * * $RCSfile: fmtcol.hxx,v $ * * $Revision: 1.2 $ * * last change: $Author: jp $ $Date: 2000-11-20 09:31:55 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses * * - GNU Lesser General Public License Version 2.1 * - Sun Industry Standards Source License Version 1.1 * * Sun Microsystems Inc., October, 2000 * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2000 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 * * * Sun Industry Standards Source License Version 1.1 * ================================================= * The contents of this file are subject to the Sun Industry Standards * Source License Version 1.1 (the "License"); You may not use this file * except in compliance with the License. You may obtain a copy of the * License at http://www.openoffice.org/license.html. * * Software provided under this License is provided on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. * See the License for the specific provisions governing your rights and * obligations concerning the Software. * * The Initial Developer of the Original Code is: Sun Microsystems, Inc. * * Copyright: 2000 by Sun Microsystems, Inc. * * All Rights Reserved. * * Contributor(s): _______________________________________ * * ************************************************************************/ #ifndef _FMTCOL_HXX #define _FMTCOL_HXX #ifndef _SVARRAY_HXX //autogen #include #endif #ifndef _FORMAT_HXX #include #endif #ifndef _SWTYPES_HXX #include // fuer MAXLEVEL #endif class SwDoc; // fuer friend class SwFmtColl : public SwFmt { protected: SwFmtColl( SwAttrPool& rPool, const sal_Char* pFmtName, const USHORT* pWhichRanges, SwFmtColl* pDerFrom, USHORT nFmtWhich ) : SwFmt( rPool, pFmtName, pWhichRanges, pDerFrom, nFmtWhich ) { SetAuto( FALSE ); } SwFmtColl( SwAttrPool& rPool, const String &rFmtName, const USHORT* pWhichRanges, SwFmtColl* pDerFrom, USHORT nFmtWhich ) : SwFmt( rPool, rFmtName, pWhichRanges, pDerFrom, nFmtWhich ) { SetAuto( FALSE ); } private: // erstmal wird nicht kopiert und nicht zugewiesen SwFmtColl(const SwFmtColl & ); const SwFmtColl &operator=(const SwFmtColl &); }; class SwTxtFmtColl: public SwFmtColl { friend class SwDoc; protected: BYTE nOutlineLevel; SwTxtFmtColl *pNextTxtFmtColl; SwTxtFmtColl( SwAttrPool& rPool, const sal_Char* pFmtCollName, SwTxtFmtColl* pDerFrom = 0, USHORT nFmtWh = RES_TXTFMTCOLL ) : SwFmtColl( rPool, pFmtCollName, aTxtFmtCollSetRange, pDerFrom, nFmtWh ), nOutlineLevel( NO_NUMBERING ) { pNextTxtFmtColl = this; } SwTxtFmtColl( SwAttrPool& rPool, const String &rFmtCollName, SwTxtFmtColl* pDerFrom = 0, USHORT nFmtWh = RES_TXTFMTCOLL ) : SwFmtColl( rPool, rFmtCollName, aTxtFmtCollSetRange, pDerFrom, nFmtWh ), nOutlineLevel( NO_NUMBERING ) { pNextTxtFmtColl = this; } public: // zum "abfischen" von UL-/LR-/FontHeight Aenderungen virtual void Modify( SfxPoolItem*, SfxPoolItem* ); TYPEINFO(); //Bereits in Basisklasse Client drin. inline void SetOutlineLevel( BYTE ); inline BYTE GetOutlineLevel() const { return nOutlineLevel; } inline void SetNextTxtFmtColl(SwTxtFmtColl& rNext); SwTxtFmtColl& GetNextTxtFmtColl() const { return *pNextTxtFmtColl; } BOOL IsAtDocNodeSet() const; /*----------------- JP 09.08.94 17:36 ------------------- wird die Funktionalitaet von Zeichenvorlagen an Absatzvorlagen ueberhaupt benoetigt ?? Wenn, ja dann muessen im TextNode und hier in der TxtCollection ein 2. Attset fuer die Char-Attribute angelegt werden; damit die Vererbung und der Zugriff auf die gesetzen Attribute richtig funktioniert!! virtual BOOL SetDerivedFrom( SwFmtColl* pDerFrom = 0 ); inline SwCharFmt* GetCharFmt() const; inline BOOL IsCharFmtSet() const; void SetCharFmt(SwCharFmt *); void ResetCharFmt(); inline BOOL SwTxtFmtColl::IsCharFmtSet() const { return aCharDepend.GetRegisteredIn() ? TRUE : FALSE; } inline SwCharFmt* SwTxtFmtColl::GetCharFmt() const { return (SwCharFmt*)aCharDepend.GetRegisteredIn(); } --------------------------------------------------*/ }; typedef SwTxtFmtColl* SwTxtFmtCollPtr; SV_DECL_PTRARR(SwTxtFmtColls,SwTxtFmtCollPtr,2,4) class SwGrfFmtColl: public SwFmtColl { friend class SwDoc; protected: SwGrfFmtColl( SwAttrPool& rPool, const sal_Char* pFmtCollName, SwGrfFmtColl* pDerFrom = 0 ) : SwFmtColl( rPool, pFmtCollName, aGrfFmtCollSetRange, pDerFrom, RES_GRFFMTCOLL ) {} SwGrfFmtColl( SwAttrPool& rPool, const String &rFmtCollName, SwGrfFmtColl* pDerFrom = 0 ) : SwFmtColl( rPool, rFmtCollName, aGrfFmtCollSetRange, pDerFrom, RES_GRFFMTCOLL ) {} public: TYPEINFO(); //Bereits in Basisklasse Client drin. }; typedef SwGrfFmtColl* SwGrfFmtCollPtr; SV_DECL_PTRARR(SwGrfFmtColls,SwGrfFmtCollPtr,2,4) //FEATURE::CONDCOLL // --------- Bedingte Vorlagen ------------------------------- enum Master_CollConditions { PARA_IN_LIST = 0x0001, PARA_IN_OUTLINE = 0x0002, PARA_IN_FRAME = 0x0004, PARA_IN_TABLEHEAD = 0x0008, PARA_IN_TABLEBODY = 0x0010, PARA_IN_SECTION = 0x0020, PARA_IN_FOOTENOTE = 0x0040, PARA_IN_FOOTER = 0x0080, PARA_IN_HEADER = 0x0100, PARA_IN_ENDNOTE = 0x0200, // ... USRFLD_EXPRESSION = (int)0x8000 }; class SwCollCondition : public SwClient { ULONG nCondition; union { ULONG nSubCondition; String* pFldExpression; } aSubCondition; public: TYPEINFO(); //Bereits in Basisklasse Client drin. SwCollCondition( SwTxtFmtColl* pColl, ULONG nMasterCond, ULONG nSubCond = 0 ); SwCollCondition( SwTxtFmtColl* pColl, ULONG nMasterCond, const String& rSubExp ); SwCollCondition( const SwCollCondition& rCpy ); virtual ~SwCollCondition(); int operator==( const SwCollCondition& rCmp ) const; int operator!=( const SwCollCondition& rCmp ) const { return ! (*this == rCmp); } ULONG GetCondition() const { return nCondition; } ULONG GetSubCondition() const { return aSubCondition.nSubCondition; } const String* GetFldExpression() const { return aSubCondition.pFldExpression; } void SetCondition( ULONG nCond, ULONG nSubCond ); SwTxtFmtColl* GetTxtFmtColl() const { return (SwTxtFmtColl*)GetRegisteredIn(); } }; typedef SwCollCondition* SwCollConditionPtr; SV_DECL_PTRARR_DEL( SwFmtCollConditions, SwCollConditionPtr, 0, 5 ); class SwConditionTxtFmtColl : public SwTxtFmtColl { friend class SwDoc; protected: SwFmtCollConditions aCondColls; SwConditionTxtFmtColl( SwAttrPool& rPool, const sal_Char* pFmtCollName, SwTxtFmtColl* pDerFrom = 0 ) : SwTxtFmtColl( rPool, pFmtCollName, pDerFrom, RES_CONDTXTFMTCOLL ) {} SwConditionTxtFmtColl( SwAttrPool& rPool, const String &rFmtCollName, SwTxtFmtColl* pDerFrom = 0 ) : SwTxtFmtColl( rPool, rFmtCollName, pDerFrom, RES_CONDTXTFMTCOLL ) {} public: TYPEINFO(); //Bereits in Basisklasse Client drin. virtual ~SwConditionTxtFmtColl(); // zum "abfischen" von Aenderungen // virtual void Modify( SfxPoolItem*, SfxPoolItem* ); const SwCollCondition* HasCondition( const SwCollCondition& rCond ) const; const SwFmtCollConditions& GetCondColls() const { return aCondColls; } void InsertCondition( const SwCollCondition& rCond ); BOOL RemoveCondition( const SwCollCondition& rCond ); void SetConditions( const SwFmtCollConditions& ); }; //FEATURE::CONDCOLL // ------------- Inline Implementierungen -------------------- inline void SwTxtFmtColl::SetNextTxtFmtColl( SwTxtFmtColl& rNext ) { pNextTxtFmtColl = &rNext; } inline void SwTxtFmtColl::SetOutlineLevel( BYTE nLevel ) { ASSERT( nLevel < MAXLEVEL || nLevel == NO_NUMBERING , "SwTxtFmtColl: Level too low" ); nOutlineLevel = nLevel; } #endif