office-gobmx/sw/inc/hints.hxx
Rüdiger Timm a85c1a609c INTEGRATION: CWS swlists01 (1.8.192); FILE MERGED
2008/05/08 16:16:05 od 1.8.192.2: RESYNC: (1.8-1.9); FILE MERGED
2008/03/06 08:03:47 od 1.8.192.1: #i86732# refactoring: remove class <SwNumRuleInfo> and table <SwTxtNodeTable>
2008-06-13 08:27:20 +00:00

306 lines
8 KiB
C++

/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2008 by Sun Microsystems, Inc.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: hints.hxx,v $
* $Revision: 1.10 $
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org 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 version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#ifndef _HINTS_HXX
#define _HINTS_HXX
#ifndef _TABLE_HXX //autogen
#include <tools/table.hxx>
#endif
#include <swatrset.hxx>
class SwFmt;
class OutputDevice;
class SwTable;
class SwNode;
class SwNodes;
class SwCntntNode;
class SwPageFrm;
class SwFrm;
class SwTxtNode;
class SwHistory;
// Basis-Klasse fuer alle Message-Hints:
// "Overhead" vom SfxPoolItem wird hier behandelt
class SwMsgPoolItem : public SfxPoolItem
{
public:
SwMsgPoolItem( USHORT nWhich );
// "Overhead" vom SfxPoolItem
virtual int operator==( const SfxPoolItem& ) const;
virtual SfxPoolItem* Clone( SfxItemPool* pPool = 0 ) const;
};
// ---------------------------------------
// SwPtrMsgPoolItem (altes SwObjectDying!)
// ---------------------------------------
class SwPtrMsgPoolItem : public SwMsgPoolItem
{
public:
void * pObject;
SwPtrMsgPoolItem( USHORT nId, void * pObj )
: SwMsgPoolItem( nId ), pObject( pObj )
{}
};
/*
* SwFmtChg wird verschickt, wenn ein Format gegen ein anderes
* Format ausgewechselt worden ist. Es werden immer 2. Hints verschickt,
* das alte und neue Format.
*/
class SwFmtChg: public SwMsgPoolItem
{
public:
SwFmt *pChangedFmt;
SwFmtChg( SwFmt *pFmt );
};
class SwInsChr: public SwMsgPoolItem
{
public:
xub_StrLen nPos;
SwInsChr( USHORT nP );
};
class SwInsTxt: public SwMsgPoolItem
{
public:
xub_StrLen nPos;
xub_StrLen nLen;
SwInsTxt( xub_StrLen nP, xub_StrLen nL );
};
class SwDelChr: public SwMsgPoolItem
{
public:
xub_StrLen nPos;
SwDelChr( xub_StrLen nP );
};
class SwDelTxt: public SwMsgPoolItem
{
public:
xub_StrLen nStart;
xub_StrLen nLen;
SwDelTxt( xub_StrLen nS, xub_StrLen nL );
};
class SwUpdateAttr: public SwMsgPoolItem
{
public:
xub_StrLen nStart;
xub_StrLen nEnd;
USHORT nWhichAttr;
SwUpdateAttr( xub_StrLen nS, xub_StrLen nE, USHORT nW );
};
// SwRefMarkFldUpdate wird verschickt, wenn sich die ReferenzMarkierungen
// Updaten sollen. Um Seiten-/KapitelNummer feststellen zu koennen, muss
// der akt. Frame befragt werden. Dafuer wird das akt. OutputDevice benoetigt.
class SwRefMarkFldUpdate : public SwMsgPoolItem
{
public:
const OutputDevice* pOut; // Pointer auf das aktuelle Output-Device
SwRefMarkFldUpdate( const OutputDevice* );
};
// SwDocPosUpdate wird verschickt, um zu signalisieren, dass nur die
// Frames ab oder bis zu einer bestimmten dokument-globalen Position
// geupdated werden brauchen. Zur Zeit wird dies nur beim Updaten
// von Seitennummernfeldern benoetigt.
class SwDocPosUpdate : public SwMsgPoolItem
{
public:
const long nDocPos;
SwDocPosUpdate( const long nDocPos );
};
// SwTableFmlUpdate wird verschickt, wenn sich die Tabelle neu berechnen soll
// JP 16.02.99: oder wenn die Tabelle selbst gemergt oder gesplittet wird
enum TableFmlUpdtFlags { TBL_CALC = 0,
TBL_BOXNAME,
TBL_BOXPTR,
TBL_RELBOXNAME,
TBL_MERGETBL,
TBL_SPLITTBL
};
class SwTableFmlUpdate : public SwMsgPoolItem
{
public:
const SwTable* pTbl; // Pointer auf die zu aktuelle Tabelle
union {
const SwTable* pDelTbl; // Merge: Ptr auf die zu loeschende Tabelle
const String* pNewTblNm; // Split: der Name der neuen Tabelle
} DATA;
SwHistory* pHistory;
USHORT nSplitLine; // Split: ab dieser BaseLine wird gespl.
TableFmlUpdtFlags eFlags;
BOOL bModified : 1;
BOOL bBehindSplitLine : 1;
SwTableFmlUpdate( const SwTable* );
};
class SwAutoFmtGetDocNode: public SwMsgPoolItem
{
public:
const SwCntntNode* pCntntNode;
const SwNodes* pNodes;
SwAutoFmtGetDocNode( const SwNodes* pNds );
};
/*
* SwAttrSetChg wird verschicht, wenn sich in dem SwAttrSet rTheChgdSet
* etwas veraendert hat. Es werden immer 2. Hints
* verschickt, die alten und neuen Items in dem rTheChgdSet.
*/
class SwAttrSetChg: public SwMsgPoolItem
{
BOOL bDelSet;
SwAttrSet* pChgSet; // was sich veraendert hat
const SwAttrSet* pTheChgdSet; // wird nur zum Vergleichen gebraucht !!
public:
SwAttrSetChg( const SwAttrSet& rTheSet, SwAttrSet& rSet );
SwAttrSetChg( const SwAttrSetChg& );
~SwAttrSetChg();
// was sich veraendert hat
const SwAttrSet* GetChgSet() const { return pChgSet; }
SwAttrSet* GetChgSet() { return pChgSet; }
// wo es sich geaendert hat
const SwAttrSet* GetTheChgdSet() const { return pTheChgdSet; }
USHORT Count() const { return pChgSet->Count(); }
void ClearItem( USHORT nWhichL = 0 )
#ifdef PRODUCT
{ pChgSet->ClearItem( nWhichL ); }
#else
;
#endif
};
class SwCondCollCondChg: public SwMsgPoolItem
{
public:
SwFmt *pChangedFmt;
SwCondCollCondChg( SwFmt *pFmt );
};
class SwVirtPageNumInfo: public SwMsgPoolItem
{
const SwPageFrm *pPage;
const SwPageFrm *pOrigPage;
const SwFrm *pFrm; //An einem Absatz/Tabelle koennen mehrere
//Attribute sitzen. Der Frame muss dann
//muss dann letztlich bei bestimmen
//welches Attribut gilt und um welche physikalische
//Seite es sich handelt.
public:
SwVirtPageNumInfo( const SwPageFrm *pPg );
const SwPageFrm *GetPage() { return pPage; }
const SwPageFrm *GetOrigPage() { return pOrigPage;}
const SwFrm *GetFrm() { return pFrm; }
void SetInfo( const SwPageFrm *pPg,
const SwFrm *pF ) { pFrm = pF, pPage = pPg; }
};
// --> OD 2008-02-19 #refactorlists#
//DECLARE_TABLE( SwTxtNodeTable, SwTxtNode* )
//class SwNumRuleInfo : public SwMsgPoolItem
//{
// SwTxtNodeTable aList;
// const String& rName;
//public:
// SwNumRuleInfo( const String& rRuleName );
// const String& GetName() const { return rName; }
// void AddNode( SwTxtNode& rNd );
// // erzeuge die Liste aller Nodes der NumRule in dem angegebenem Doc
// // Der Code steht im docnum.cxx
// // #111955#
// void MakeList( SwDoc& rDoc, BOOL bOutline = FALSE );
// const SwTxtNodeTable& GetTxtNodeList() const { return aList; }
//};
// <--
class SwNRuleLowerLevel : public SwMsgPoolItem
{
const String& rName;
BYTE nLvl;
public:
SwNRuleLowerLevel( const String& rRuleName, BYTE nLevel );
const String& GetName() const { return rName; }
BYTE GetLevel() const { return nLvl; }
};
class SwFindNearestNode : public SwMsgPoolItem
{
const SwNode *pNd, *pFnd;
public:
SwFindNearestNode( const SwNode& rNd );
void CheckNode( const SwNode& rNd );
const SwNode* GetFoundNode() const { return pFnd; }
};
class SwStringMsgPoolItem : public SwMsgPoolItem
{
String sStr;
public:
const String& GetString() const { return sStr; }
SwStringMsgPoolItem( USHORT nId, const String& rStr )
: SwMsgPoolItem( nId ), sStr( rStr )
{}
};
#endif