Files
libreoffice/sw/inc/hints.hxx

253 lines
6.8 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2000-09-18 16:15:01 +00:00
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2000-09-18 16:15:01 +00:00
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
2000-09-18 16:15:01 +00:00
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 16:15:01 +00:00
*
* This file is part of OpenOffice.org.
2000-09-18 16:15:01 +00:00
*
* 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.
2000-09-18 16:15:01 +00:00
*
* 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).
2000-09-18 16:15:01 +00:00
*
* 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.
2000-09-18 16:15:01 +00:00
*
************************************************************************/
#ifndef _HINTS_HXX
#define _HINTS_HXX
#include <swatrset.hxx>
class SwFmt;
class OutputDevice;
class SwTable;
class SwNode;
class SwNodes;
class SwCntntNode;
class SwPageFrm;
class SwFrm;
class SwTxtNode;
class SwHistory;
// Base class for all Message-Hints:
// "Overhead" of SfxPoolItem is handled here
2000-09-18 16:15:01 +00:00
class SwMsgPoolItem : public SfxPoolItem
{
public:
SwMsgPoolItem( sal_uInt16 nWhich );
2000-09-18 16:15:01 +00:00
// "Overhead" of SfxPoolItem
2000-09-18 16:15:01 +00:00
virtual int operator==( const SfxPoolItem& ) const;
virtual SfxPoolItem* Clone( SfxItemPool* pPool = 0 ) const;
};
// ---------------------------------------
// SwPtrMsgPoolItem (old SwObjectDying!)
2000-09-18 16:15:01 +00:00
// ---------------------------------------
class SwPtrMsgPoolItem : public SwMsgPoolItem
{
public:
void * pObject;
SwPtrMsgPoolItem( sal_uInt16 nId, void * pObj )
2000-09-18 16:15:01 +00:00
: SwMsgPoolItem( nId ), pObject( pObj )
{}
};
/*
* SwFmtChg is sent when a format has changed to another format. 2 Hints are always sent
* the old and the new format
2000-09-18 16:15:01 +00:00
*/
class SwFmtChg: public SwMsgPoolItem
{
public:
SwFmt *pChangedFmt;
SwFmtChg( SwFmt *pFmt );
};
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;
sal_uInt16 nWhichAttr;
SwUpdateAttr( xub_StrLen nS, xub_StrLen nE, sal_uInt16 nW );
2000-09-18 16:15:01 +00:00
};
/** SwRefMarkFldUpdate is sent when the referencemarks should be updated.
To determine Page- / chapternumbers the current frame has to be asked.
For this we need the current outputdevice */
2000-09-18 16:15:01 +00:00
class SwRefMarkFldUpdate : public SwMsgPoolItem
{
public:
const OutputDevice* pOut; ///< pointer to the current output device
2000-09-18 16:15:01 +00:00
SwRefMarkFldUpdate( const OutputDevice* );
};
/** SwDocPosUpdate is sent to signal that only the frames from or to a specified document-global position
have to be updated. At the moment this is only needed when updating pagenumber fields. */
2000-09-18 16:15:01 +00:00
class SwDocPosUpdate : public SwMsgPoolItem
{
public:
const long nDocPos;
SwDocPosUpdate( const long nDocPos );
};
/// SwTableFmlUpdate is sent when the table has to be newly calculated or when a table itself is merged or splitted
2000-09-18 16:15:01 +00:00
enum TableFmlUpdtFlags { TBL_CALC = 0,
TBL_BOXNAME,
TBL_BOXPTR,
TBL_RELBOXNAME,
TBL_MERGETBL,
TBL_SPLITTBL
};
class SwTableFmlUpdate : public SwMsgPoolItem
{
public:
const SwTable* pTbl; ///< Pointer to the current table
2000-09-18 16:15:01 +00:00
union {
const SwTable* pDelTbl; ///< Merge: Pointer to the table to be removed
const String* pNewTblNm; ///< Split: the name of the new table
2000-09-18 16:15:01 +00:00
} DATA;
SwHistory* pHistory;
sal_uInt16 nSplitLine; ///< Split: from this BaseLine on will be splitted
2000-09-18 16:15:01 +00:00
TableFmlUpdtFlags eFlags;
sal_Bool bModified : 1;
sal_Bool bBehindSplitLine : 1;
2000-09-18 16:15:01 +00:00
SwTableFmlUpdate( const SwTable* );
};
class SwAutoFmtGetDocNode: public SwMsgPoolItem
{
public:
const SwCntntNode* pCntntNode;
const SwNodes* pNodes;
SwAutoFmtGetDocNode( const SwNodes* pNds );
};
/*
* SwAttrSetChg is sent when something has changed in the SwAttrSet rTheChgdSet.
* 2 Hints are always sent, the old and the new items in the rTheChgdSet.
2000-09-18 16:15:01 +00:00
*/
class SwAttrSetChg: public SwMsgPoolItem
{
sal_Bool bDelSet;
SwAttrSet* pChgSet; ///< what has changed
const SwAttrSet* pTheChgdSet; ///< is only used to compare
2000-09-18 16:15:01 +00:00
public:
SwAttrSetChg( const SwAttrSet& rTheSet, SwAttrSet& rSet );
SwAttrSetChg( const SwAttrSetChg& );
~SwAttrSetChg();
/// What has changed
const SwAttrSet* GetChgSet() const { return pChgSet; }
SwAttrSet* GetChgSet() { return pChgSet; }
2000-09-18 16:15:01 +00:00
/// Where it has changed
const SwAttrSet* GetTheChgdSet() const { return pTheChgdSet; }
2000-09-18 16:15:01 +00:00
sal_uInt16 Count() const { return pChgSet->Count(); }
void ClearItem( sal_uInt16 nWhichL = 0 )
#ifdef DBG_UTIL
2000-09-18 16:15:01 +00:00
;
#else
{ pChgSet->ClearItem( nWhichL ); }
2000-09-18 16:15:01 +00:00
#endif
};
class SwCondCollCondChg: public SwMsgPoolItem
{
public:
SwFmt *pChangedFmt;
SwCondCollCondChg( SwFmt *pFmt );
};
class SwVirtPageNumInfo: public SwMsgPoolItem
{
const SwPageFrm *pPage;
const SwPageFrm *pOrigPage;
const SwFrm *pFrm;
/** Multiple attributes can be attached to a single paragraph / table
The frame, in the end, has to decide which attribute takes effect and which physical page it involves */
2000-09-18 16:15:01 +00:00
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; }
2000-09-18 16:15:01 +00:00
};
class SwFindNearestNode : public SwMsgPoolItem
{
const SwNode *pNd, *pFnd;
public:
SwFindNearestNode( const SwNode& rNd );
void CheckNode( const SwNode& rNd );
const SwNode* GetFoundNode() const { return pFnd; }
2000-09-18 16:15:01 +00:00
};
class SwStringMsgPoolItem : public SwMsgPoolItem
{
String sStr;
public:
const String& GetString() const { return sStr; }
SwStringMsgPoolItem( sal_uInt16 nId, const String& rStr )
: SwMsgPoolItem( nId ), sStr( rStr )
{}
};
2000-09-18 16:15:01 +00:00
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */