Files
libreoffice/sw/source/core/inc/mvsave.hxx
Nigel Hawkins 84d23d37ac Replace SvULongs with std::vector in mvsave.hxx
Also cascaded changes due to this. LGPLv3+/MPL
2011-06-15 13:38:45 +01:00

215 lines
6.5 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* 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 SW_MVSAVE_HXX
#define SW_MVSAVE_HXX
#include <tools/string.hxx>
#include <vcl/keycod.hxx>
#include <svl/svarray.hxx>
#include <IDocumentMarkAccess.hxx>
#include <vector>
namespace sfx2 {
class MetadatableUndo;
}
class SvNumberFormatter;
class SwDoc;
class SwFmtAnchor;
class SwFrmFmt;
class SwIndex;
class SwNodeIndex;
class SwNodeRange;
class SwPaM;
class SwNode;
struct SwPosition;
namespace sw { namespace mark
{
class IMark;
class SaveBookmark
{
public:
SaveBookmark(bool bSavePos,
bool bSaveOtherPos,
const ::sw::mark::IMark& rBkmk,
const SwNodeIndex& rMvPos,
const SwIndex* pIdx =0);
void SetInDoc(SwDoc* pDoc,
const SwNodeIndex&,
const SwIndex* pIdx =0);
IDocumentMarkAccess::MarkType GetOriginalBkmType() const
{ return m_eOrigBkmType; }
private:
::rtl::OUString m_aName;
::rtl::OUString m_aShortName;
KeyCode m_aCode;
bool m_bSavePos;
bool m_bSaveOtherPos;
IDocumentMarkAccess::MarkType m_eOrigBkmType;
sal_uLong m_nNode1;
sal_uLong m_nNode2;
xub_StrLen m_nCntnt1;
xub_StrLen m_nCntnt2;
::boost::shared_ptr< ::sfx2::MetadatableUndo > m_pMetadataUndo;
};
}}
#define SAVEFLY 1
#define SAVEFLY_SPLIT 2
void _DelBookmarks(const SwNodeIndex& rStt,
const SwNodeIndex& rEnd,
::std::vector< ::sw::mark::SaveBookmark> * SaveBkmk =0,
const SwIndex* pSttIdx =0,
const SwIndex* pEndIdx =0);
void _SaveCntntIdx( SwDoc* pDoc, sal_uLong nNode, xub_StrLen nCntnt,
std::vector<sal_uLong>& rSaveArr, sal_uInt8 nSaveFly = 0 );
void _RestoreCntntIdx( SwDoc* pDoc, std::vector<sal_uLong>& rSaveArr,
sal_uLong nNode, xub_StrLen nOffset = 0,
sal_Bool bAuto = sal_False );
void _RestoreCntntIdx( std::vector<sal_uLong>& rSaveArr, const SwNode& rNd,
xub_StrLen nLen, xub_StrLen nCorrLen );
/** data structure to temporarily hold fly anchor positions relative to some
* location. */
struct _SaveFly
{
sal_uLong nNdDiff; /// relative node difference
SwFrmFmt* pFrmFmt; /// the fly's frame format
sal_Bool bInsertPosition; /// if true, anchor _at_ insert position
_SaveFly( sal_uLong nNodeDiff, SwFrmFmt* pFmt, sal_Bool bInsert )
: nNdDiff( nNodeDiff ), pFrmFmt( pFmt ), bInsertPosition( bInsert )
{ }
};
SV_DECL_VARARR( _SaveFlyArr, _SaveFly, 0, 10 )
void _RestFlyInRange( _SaveFlyArr& rArr, const SwNodeIndex& rSttIdx,
const SwNodeIndex* pInsPos );
void _SaveFlyInRange( const SwNodeRange& rRg, _SaveFlyArr& rArr );
void _SaveFlyInRange( const SwPaM& rPam, const SwNodeIndex& rInsPos,
_SaveFlyArr& rArr, sal_Bool bMoveAllFlys );
void DelFlyInRange( const SwNodeIndex& rMkNdIdx,
const SwNodeIndex& rPtNdIdx );
class SwDataChanged
{
const SwPaM* pPam;
const SwPosition* pPos;
SwDoc* pDoc;
sal_uLong nNode;
xub_StrLen nCntnt;
sal_uInt16 nType; // Insert/Move/Delete/... (UndoIds)
public:
SwDataChanged( const SwPaM& rPam, sal_uInt16 nType );
SwDataChanged( SwDoc* pDoc, const SwPosition& rPos, sal_uInt16 nType );
~SwDataChanged();
sal_uLong GetNode() const { return nNode; }
xub_StrLen GetCntnt() const { return nCntnt; }
};
// Funktions-Deklaration damit auch alles unter der CrsrShell mal die
// Crsr verschieben kann
// die Funktionen rufen nicht die SwDoc::Corr - Methoden!
// Setzt alle PaMs im Bereich vom Range nach NewPos
void PaMCorrAbs( const SwPaM& rRange,
const SwPosition& rNewPos );
// Setzt alle PaMs in OldNode auf relative Pos
void PaMCorrRel( const SwNodeIndex &rOldNode,
const SwPosition &rNewPos,
const xub_StrLen nOffset = 0 );
// Hilfsklasse zum kopieren von absatzgebundenen Flys. Durch die Sortierung
// nach der Ordnungsnummer wird versucht die layout seitige Anordnung
// bei zu behalten
class _ZSortFly
{
const SwFrmFmt* pFmt;
const SwFmtAnchor* pAnchor;
sal_uInt32 nOrdNum;
public:
_ZSortFly( const SwFrmFmt* pFrmFmt, const SwFmtAnchor* pFlyAnchor,
sal_uInt32 nArrOrdNum );
_ZSortFly& operator=( const _ZSortFly& rCpy )
{
pFmt = rCpy.pFmt, pAnchor = rCpy.pAnchor, nOrdNum = rCpy.nOrdNum;
return *this;
}
int operator==( const _ZSortFly& ) const { return sal_False; }
int operator<( const _ZSortFly& rCmp ) const
{ return nOrdNum < rCmp.nOrdNum; }
const SwFrmFmt* GetFmt() const { return pFmt; }
const SwFmtAnchor* GetAnchor() const { return pAnchor; }
};
SV_DECL_VARARR_SORT( _ZSortFlys, _ZSortFly, 0, 10 )
class SwTblNumFmtMerge
{
SvNumberFormatter* pNFmt;
public:
SwTblNumFmtMerge( const SwDoc& rSrc, SwDoc& rDest );
~SwTblNumFmtMerge();
};
class _SaveRedlEndPosForRestore
{
SvPtrarr* pSavArr;
SwNodeIndex* pSavIdx;
xub_StrLen nSavCntnt;
void _Restore();
public:
_SaveRedlEndPosForRestore( const SwNodeIndex& rInsIdx, xub_StrLen nCntnt );
~_SaveRedlEndPosForRestore();
void Restore() { if( pSavArr ) _Restore(); }
};
#endif // SW_MVSAVE_HXX
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */