Patches contributed by Oliver-Rainer Wittmann sw34bf06: #i117783# - Writer's implementation of XPagePrintable - apply print settings to new printing routines http://svn.apache.org/viewvc?view=revision&revision=1172115 sw34bf06: #o12311627# use <rtl_random> methods to create unique ids for list styles and list ids http://svn.apache.org/viewvc?view=revision&revision=1172112 sw34bf06 #i114725#,#i115828# - method <SwDoc::ClearDoc()> - clear list structures completely http://svn.apache.org/viewvc?view=revision&revision=1172122 i#118572 - remove ui string and help content regarding usage of Java Mail in Writer's Mail Merge as Java Mail is not used. http://svn.apache.org/viewvc?view=revision&revision=1197035 Patches contributed by Mathias Bauer cws mba34issues01: #i117718#: provide filter name in case storage of medium does not allow to detect one http://svn.apache.org/viewvc?view=revision&revision=1172350 cws mba34issues01: #i117721#: directly provide parameters retrieved from SfxMedium http://svn.apache.org/viewvc?view=revision&revision=1172353 gnumake4 work variously http://svn.apache.org/viewvc?view=revision&revision=1394707 http://svn.apache.org/viewvc?view=revision&revision=1394326 http://svn.apache.org/viewvc?view=revision&revision=1396797 http://svn.apache.org/viewvc?view=revision&revision=1397315 cws mba34issues01: #i117723#: convert assertion into trace http://svn.apache.org/viewvc?view=revision&revision=1172355 cws mba34issues01: #i117699#: keep layout alive until swdoc dies http://svn.apache.org/viewvc?view=revision&revision=1172362 cws mba34issues01: #i117943#: missing color attributes in RTF clipboard http://svn.apache.org/viewvc?view=revision&revision=1172363 Patch contributed by Henning Brinkmann imported patch i#103878 http://svn.apache.org/viewvc?view=revision&revision=1172109 Patches contributed by Michael Stahl sw34bf06: #i117955#: WW8 export: disable storing of section breaks in endnotes http://svn.apache.org/viewvc?view=revision&revision=1172119 Patch contributed by imacat Fixed the Asian language work count. http://svn.apache.org/viewvc?view=revision&revision=1241345 Patch contributed by Pedro Giffuni i#20878 - Add comment with BZ issue for reference. http://svn.apache.org/viewvc?view=revision&revision=1244517 Patch contributed by Andre Fischer Do not add targets for junit tests when junit is disabled. http://svn.apache.org/viewvc?view=revision&revision=1241508 add writerperfect dependency.
240 lines
8.9 KiB
C++
240 lines
8.9 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 _FLOWFRM_HXX
|
|
#define _FLOWFRM_HXX
|
|
|
|
class SwPageFrm;
|
|
class SwRect;
|
|
class SwBorderAttrs;
|
|
class SwDoc;
|
|
class SwNodeIndex;
|
|
// #i44049#
|
|
class SwObjectFormatterTxtFrm;
|
|
|
|
void MakeFrms( SwDoc *, const SwNodeIndex &, const SwNodeIndex & );
|
|
|
|
/** Base class that provides the general functionalities for frames that are
|
|
allowed at page breaks (flow) and shall continue on the next page (can be
|
|
split), e.g. paragraphs (CntntFrm) or tables (TabFrm).
|
|
|
|
Some parts of these functionalities are implemented in FlowFrm while the
|
|
specific ones are done in the corresponding Frm classes. The FlowFrm has to
|
|
be seen as a base class. As such it is no Frm by itself and thus no direct
|
|
instances of FlowFrm can exist.
|
|
|
|
Actually it is not even a real Frm. The obvious implementation would be a
|
|
FlowFrm that is virtually inherited from SwFrm and that works with its own
|
|
member data. Further classes would need to inherit from FlowFrm and (via
|
|
multiple base classes since the class tree splits exactly at the branch
|
|
from SwFrm to SwCntntFrm and SwLayoutFrm) also virtually from SwFrm as
|
|
well. Unfortunately, this leads - besides problems with compilers and
|
|
debugging programs - to high additional costs, that we IMHO are not able to
|
|
afford nowadays.
|
|
|
|
Hence, we use another technique: A FlowFrm keeps a reference to a SwFrm
|
|
- which it is actually itself - and they are friends. As a result, the
|
|
FlowFrm can work with the reference to the SwFrm instead of working with
|
|
its own this-pointer.
|
|
*/
|
|
class SwFlowFrm
|
|
{
|
|
// PrepareMake is allowed to lock/unlock (robustness)
|
|
friend inline void PrepareLock ( SwFlowFrm * );
|
|
friend inline void PrepareUnlock( SwFlowFrm * );
|
|
friend inline void TableSplitRecalcLock( SwFlowFrm * );
|
|
friend inline void TableSplitRecalcUnlock( SwFlowFrm * );
|
|
// #i44049#
|
|
friend class SwObjectFormatterTxtFrm;
|
|
|
|
// TblSel is allowed to reset the follow-bit
|
|
friend inline void UnsetFollow( SwFlowFrm *pFlow );
|
|
|
|
friend void MakeFrms( SwDoc *, const SwNodeIndex &, const SwNodeIndex & );
|
|
|
|
friend class SwNode2LayImpl;
|
|
|
|
SwFrm &rThis;
|
|
|
|
// helper methods for MoveSubTree()
|
|
static SwLayoutFrm *CutTree( SwFrm* );
|
|
static sal_Bool PasteTree( SwFrm *, SwLayoutFrm *, SwFrm *, SwFrm* );
|
|
|
|
/** indicates that a backward move was done over multiple pages
|
|
|
|
Needed for the interaction of _GetPrevxxx and MoveBwd so that multiple
|
|
pages can be skipped at the same time. In addition, it is evaluated by
|
|
the MoveBwd() method in TabFrm.
|
|
*/
|
|
static sal_Bool bMoveBwdJump;
|
|
|
|
/** helper method to determine previous frame for calculation of the
|
|
upper space
|
|
|
|
#i11860#
|
|
|
|
@param _pProposedPrevFrm
|
|
optional input parameter - pointer to frame, which should be used
|
|
instead of the direct previous frame.
|
|
*/
|
|
const SwFrm* _GetPrevFrmForUpperSpaceCalc( const SwFrm* _pProposedPrevFrm = 0L ) const;
|
|
|
|
/** method to detemine the upper space amount, which is considered for
|
|
the previous frame
|
|
|
|
#i11860#
|
|
*/
|
|
SwTwips _GetUpperSpaceAmountConsideredForPrevFrm() const;
|
|
|
|
/** method to detemine the upper space amount, which is considered for
|
|
the page grid
|
|
|
|
#i11860#
|
|
*/
|
|
SwTwips _GetUpperSpaceAmountConsideredForPageGrid(
|
|
const SwTwips _nUpperSpaceWithoutGrid ) const;
|
|
|
|
protected:
|
|
SwFlowFrm *m_pFollow;
|
|
SwFlowFrm *m_pPrecede;
|
|
|
|
sal_Bool bLockJoin :1; // if sal_True than joins (and thus deletes) are prohibited!
|
|
sal_Bool bUndersized:1; // I am smaller than needed
|
|
sal_Bool bFlyLock :1; // stop positioning of at-character flyframes
|
|
|
|
// checks if forward flow makes sense to prevent infinite moves
|
|
inline sal_Bool IsFwdMoveAllowed();
|
|
// #i44049# - method <CalcCntnt(..)> has to check this property.
|
|
friend void CalcCntnt( SwLayoutFrm *pLay, bool bNoColl, bool bNoCalcFollow );
|
|
sal_Bool IsKeepFwdMoveAllowed(); // like above, forward flow for Keep.
|
|
|
|
/** method to determine overlapping of an object that requests floating
|
|
|
|
0: no overlapping
|
|
1: objects that are anchored at the FlowFrm overlap
|
|
2: objects that are anchored somewhere else overlap
|
|
3: both types of objects overlap
|
|
*/
|
|
sal_uInt8 BwdMoveNecessary( const SwPageFrm *pPage, const SwRect &rRect );
|
|
|
|
void LockJoin() { bLockJoin = sal_True; }
|
|
void UnlockJoin() { bLockJoin = sal_False; }
|
|
|
|
sal_Bool CheckMoveFwd( bool& rbMakePage, sal_Bool bKeep, sal_Bool bMovedBwd );
|
|
sal_Bool MoveFwd( sal_Bool bMakePage, sal_Bool bPageBreak, sal_Bool bMoveAlways = sal_False );
|
|
sal_Bool MoveBwd( sal_Bool &rbReformat );
|
|
virtual sal_Bool ShouldBwdMoved( SwLayoutFrm *pNewUpper, sal_Bool bHead, sal_Bool &rReformat )=0;
|
|
|
|
public:
|
|
SwFlowFrm( SwFrm &rFrm );
|
|
virtual ~SwFlowFrm();
|
|
|
|
const SwFrm *GetFrm() const { return &rThis; }
|
|
SwFrm *GetFrm() { return &rThis; }
|
|
|
|
static sal_Bool IsMoveBwdJump() { return bMoveBwdJump; }
|
|
static void SetMoveBwdJump( sal_Bool bNew ){ bMoveBwdJump = bNew; }
|
|
|
|
inline void SetUndersized( const sal_Bool bNew ) { bUndersized = bNew; }
|
|
inline sal_Bool IsUndersized() const { return bUndersized; }
|
|
|
|
sal_Bool IsPrevObjMove() const;
|
|
|
|
/** hook tree onto new parent with minimal operations and notifications */
|
|
void MoveSubTree( SwLayoutFrm* pParent, SwFrm* pSibling = 0 );
|
|
|
|
sal_Bool HasFollow() const { return m_pFollow ? sal_True : sal_False; }
|
|
sal_Bool IsFollow() const { return 0 != m_pPrecede; }
|
|
sal_Bool IsAnFollow( const SwFlowFrm *pFlow ) const;
|
|
const SwFlowFrm *GetFollow() const { return m_pFollow; }
|
|
SwFlowFrm *GetFollow() { return m_pFollow; }
|
|
void SetFollow(SwFlowFrm *const pFollow);
|
|
|
|
const SwFlowFrm *GetPrecede() const { return m_pPrecede; }
|
|
SwFlowFrm *GetPrecede() { return m_pPrecede; }
|
|
|
|
sal_Bool IsJoinLocked() const { return bLockJoin; }
|
|
sal_Bool IsAnyJoinLocked() const { return bLockJoin || HasLockedFollow(); }
|
|
|
|
sal_Bool IsPageBreak( sal_Bool bAct ) const;
|
|
sal_Bool IsColBreak( sal_Bool bAct ) const;
|
|
|
|
/** method to determine if a Keep needs to be considered (Breaks!) */
|
|
sal_Bool IsKeep( const SwAttrSet& rAttrs, bool bBreakCheck = false ) const;
|
|
|
|
sal_Bool HasLockedFollow() const;
|
|
|
|
sal_Bool HasParaSpaceAtPages( sal_Bool bSct ) const;
|
|
|
|
/** method to determine the upper space hold by the frame
|
|
|
|
#i11860#
|
|
|
|
@param _bConsiderGrid
|
|
optional input parameter - consider the page grid while calculating?
|
|
*/
|
|
SwTwips CalcUpperSpace( const SwBorderAttrs *pAttrs = NULL,
|
|
const SwFrm* pPr = NULL,
|
|
const bool _bConsiderGrid = true ) const;
|
|
|
|
/** method to determine the upper space amount, which is considered for
|
|
the previous frame and the page grid, if option 'Use former object
|
|
positioning' is OFF
|
|
|
|
#i11860#
|
|
*/
|
|
SwTwips GetUpperSpaceAmountConsideredForPrevFrmAndPageGrid() const;
|
|
|
|
/** calculation of lower space */
|
|
SwTwips CalcLowerSpace( const SwBorderAttrs* _pAttrs = 0L ) const;
|
|
|
|
/** calculation of the additional space to be considered, if flow frame
|
|
is the last inside a table cell
|
|
|
|
#i26250
|
|
|
|
@param _pAttrs
|
|
optional input parameter - border attributes of the flow frame.
|
|
Used for optimization, if caller has already determined the border
|
|
attributes.
|
|
|
|
@return SwTwips
|
|
*/
|
|
SwTwips CalcAddLowerSpaceAsLastInTableCell(
|
|
const SwBorderAttrs* _pAttrs = 0L ) const;
|
|
|
|
void CheckKeep();
|
|
|
|
void SetFlyLock( sal_Bool bNew ){ bFlyLock = bNew; }
|
|
sal_Bool IsFlyLock() const { return bFlyLock; }
|
|
|
|
// Casting of a Frm into a FlowFrm (if it is one, otherwise 0)
|
|
// These methods need to be customized in subclasses!
|
|
static SwFlowFrm *CastFlowFrm( SwFrm *pFrm );
|
|
static const SwFlowFrm *CastFlowFrm( const SwFrm *pFrm );
|
|
};
|
|
|
|
inline sal_Bool SwFlowFrm::IsFwdMoveAllowed()
|
|
{
|
|
return rThis.GetIndPrev() != 0;
|
|
}
|
|
#endif
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|