1
0
Fork 0
libreoffice/sw/source/core/inc/mvsave.hxx
Daniel Baumann 8e63e14cf6
Adding upstream version 4:25.2.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 16:20:04 +02:00

201 lines
6.4 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 .
*/
#ifndef INCLUDED_SW_SOURCE_CORE_INC_MVSAVE_HXX
#define INCLUDED_SW_SOURCE_CORE_INC_MVSAVE_HXX
#include <vcl/keycod.hxx>
#include <IDocumentMarkAccess.hxx>
#include <ndindex.hxx>
#include <deque>
#include <optional>
#include <vector>
#include <o3tl/typed_flags_set.hxx>
namespace sfx2 {
class MetadatableUndo;
}
class SvNumberFormatter;
class SwDoc;
class SwFormatAnchor;
class SwFrameFormat;
class SwContentIndex;
class SwNodeRange;
class SwPaM;
class SwNode;
struct SwPosition;
namespace sw::mark
{
class MarkBase;
class SaveBookmark
{
public:
SaveBookmark(
const ::sw::mark::MarkBase& rBkmk,
const SwNode& rMvPos,
std::optional<sal_Int32> oContentIdx);
void SetInDoc(SwDoc* pDoc,
const SwNode&,
std::optional<sal_Int32> oContentIdx = std::nullopt);
private:
OUString m_aName;
OUString m_aShortName;
bool m_bHidden;
OUString m_aHideCondition;
vcl::KeyCode m_aCode;
IDocumentMarkAccess::MarkType m_eOrigBkmType;
SwNodeOffset m_nNode1;
SwNodeOffset m_nNode2;
sal_Int32 m_nContent1;
sal_Int32 m_nContent2;
std::shared_ptr< ::sfx2::MetadatableUndo > m_pMetadataUndo;
};
enum class RestoreMode { Flys = 1, NonFlys = 2, All = 3 };
/// Takes care of storing relevant attributes of an SwTextNode before split, then restore them on the new node.
class ContentIdxStore
{
public:
virtual bool Empty() =0;
virtual void Save(SwDoc& rDoc, SwNodeOffset nNode, sal_Int32 nContent, bool bSaveFlySplit=false) =0;
virtual void Restore(SwDoc& rDoc, SwNodeOffset nNode, sal_Int32 nOffset=0, bool bAuto = false, bool bAtStart = false, RestoreMode = RestoreMode::All) =0;
virtual void Restore(SwNode& rNd, sal_Int32 nLen, sal_Int32 nCorrLen, RestoreMode = RestoreMode::All) =0;
virtual ~ContentIdxStore() {};
static std::shared_ptr<ContentIdxStore> Create();
};
}
namespace o3tl {
template<> struct typed_flags<sw::mark::RestoreMode> : is_typed_flags<sw::mark::RestoreMode, 3> {};
}
void DelBookmarks(SwNode& rStt,
const SwNode& rEnd,
std::vector< ::sw::mark::SaveBookmark> * SaveBkmk =nullptr,
std::optional<sal_Int32> oStartContentIdx = std::nullopt,
std::optional<sal_Int32> oEndContentIdx = std::nullopt,
bool isReplace = false);
/** data structure to temporarily hold fly anchor positions relative to some
* location. */
struct SaveFly
{
SwFrameFormat* pFrameFormat; /// the fly's frame format
SwNodeOffset nNdDiff; /// relative node difference
sal_Int32 nContentIndex; ///< index in node
bool isAtInsertNode; ///< if true, anchor _at_ insert node index
SaveFly( SwNodeOffset nNodeDiff, sal_Int32 const nCntntIdx, SwFrameFormat* pFormat, bool bInsert )
: pFrameFormat(pFormat)
, nNdDiff(nNodeDiff)
, nContentIndex(nCntntIdx)
, isAtInsertNode(bInsert)
{ }
};
typedef std::deque< SaveFly > SaveFlyArr;
void RestFlyInRange( SaveFlyArr& rArr, const SwPosition& rSttIdx,
const SwNode* pInsPos, bool isForceToStartPos = false);
void SaveFlyInRange( const SwNodeRange& rRg, SaveFlyArr& rArr );
void SaveFlyInRange( const SwPaM& rPam, const SwPosition& rInsPos,
SaveFlyArr& rArr, bool bMoveAllFlys, SwHistory * pHistory = nullptr);
void DelFlyInRange( SwNode& rMkNd,
SwNode& rPtNd,
std::optional<sal_Int32> nMkContentIdx = std::nullopt,
std::optional<sal_Int32> pPtContentIdx = std::nullopt);
class SwDataChanged
{
const SwPaM* m_pPam;
const SwPosition* m_pPos;
SwDoc& m_rDoc;
sal_Int32 m_nContent;
public:
SwDataChanged( const SwPaM& rPam );
SwDataChanged( SwDoc& rDoc, const SwPosition& rPos );
~SwDataChanged();
sal_Int32 GetContent() const { return m_nContent; }
};
/**
* Function declarations so that everything below the CursorShell can
* move the Cursor once in a while.
* These functions do not call the SwDoc::Corr methods!
*/
void PaMCorrAbs( const SwPaM& rRange,
const SwPosition& rNewPos );
/// Sets all PaMs in OldNode to relative Pos
void PaMCorrRel( const SwNode &rOldNode,
const SwPosition &rNewPos,
const sal_Int32 nOffset = 0 );
/**
* Helper to copy paragraph-bound Flys.
* By sorting by order number, we try to retain the layout.
*/
class ZSortFly
{
const SwFrameFormat* m_pFormat;
const SwFormatAnchor* m_pAnchor;
sal_uInt32 m_nOrdNum;
public:
ZSortFly( const SwFrameFormat* pFrameFormat, const SwFormatAnchor* pFlyAnchor,
sal_uInt32 nArrOrdNum );
bool operator==( const ZSortFly& ) const { return false; }
bool operator<( const ZSortFly& rCmp ) const
{ return m_nOrdNum < rCmp.m_nOrdNum; }
const SwFrameFormat* GetFormat() const { return m_pFormat; }
const SwFormatAnchor* GetAnchor() const { return m_pAnchor; }
};
class SwTableNumFormatMerge
{
SvNumberFormatter* pNFormat;
public:
SwTableNumFormatMerge( const SwDoc& rSrc, SwDoc& rDest );
~SwTableNumFormatMerge();
};
class SaveRedlEndPosForRestore
{
std::vector<SwPosition*> mvSavArr;
std::optional<SwNodeIndex> moSaveIndex;
sal_Int32 mnSaveContent;
public:
SaveRedlEndPosForRestore( const SwNode& rInsIdx, sal_Int32 nContent );
~SaveRedlEndPosForRestore();
void Restore();
};
#endif // INCLUDED_SW_SOURCE_CORE_INC_MVSAVE_HXX
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */