Files
libreoffice/sw/source/core/docnode/node.cxx

1948 lines
64 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
re-base on ALv2 code. Includes: 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.
2011-03-31 10:05:04 +02:00
/*
* 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 .
*/
2000-09-18 23:08:29 +00:00
#include <hintids.hxx>
#include <editeng/frmdiritem.hxx>
#include <editeng/protitem.hxx>
#include <tools/gen.hxx>
#include <com/sun/star/i18n/CharacterIteratorMode.hpp>
2000-09-18 23:08:29 +00:00
#include <fmtcntnt.hxx>
#include <fmtanchr.hxx>
#include <frmfmt.hxx>
#include <txtftn.hxx>
#include <ftnfrm.hxx>
#include <doc.hxx>
#include <docary.hxx>
#include <node.hxx>
#include <ndindex.hxx>
#include <numrule.hxx>
#include <swtable.hxx>
#include <ndtxt.hxx>
#include <pam.hxx>
#include <swcache.hxx>
#include <section.hxx>
#include <cntfrm.hxx>
#include <flyfrm.hxx>
#include <txtfrm.hxx>
#include <tabfrm.hxx>
2000-09-18 23:08:29 +00:00
#include <viewsh.hxx>
#include <paratr.hxx>
#include <ftnidx.hxx>
#include <fmtftn.hxx>
#include <fmthdft.hxx>
#include <frmatr.hxx>
#include <fmtautofmt.hxx>
2000-09-18 23:08:29 +00:00
#include <frmtool.hxx>
#include <pagefrm.hxx>
#include <node2lay.hxx>
#include <pagedesc.hxx>
#include <fmtpdsc.hxx>
#include <breakit.hxx>
#include <crsskip.hxx>
#include <SwStyleNameMapper.hxx>
#include <scriptinfo.hxx>
#include <rootfrm.hxx>
#include <istyleaccess.hxx>
#include <IDocumentListItems.hxx>
#include <switerator.hxx>
#include "ndole.hxx"
2000-11-20 15:40:58 +00:00
using namespace ::com::sun::star::i18n;
2000-09-18 23:08:29 +00:00
TYPEINIT2( SwCntntNode, SwModify, SwIndexReg )
/*
* Some local helper functions for the attribute set handle of a content node.
* Since the attribute set of a content node may not be modified directly,
* we always have to create a new SwAttrSet, do the modifications, and get
* a new handle from the style access
*/
namespace AttrSetHandleHelper
{
void GetNewAutoStyle( boost::shared_ptr<const SfxItemSet>& mrpAttrSet,
const SwCntntNode& rNode,
SwAttrSet& rNewAttrSet )
{
const SwAttrSet* pAttrSet = static_cast<const SwAttrSet*>(mrpAttrSet.get());
if( rNode.GetModifyAtAttr() )
const_cast<SwAttrSet*>(pAttrSet)->SetModifyAtAttr( 0 );
IStyleAccess& rSA = pAttrSet->GetPool()->GetDoc()->GetIStyleAccess();
mrpAttrSet = rSA.getAutomaticStyle( rNewAttrSet, rNode.IsTxtNode() ?
IStyleAccess::AUTO_STYLE_PARA :
IStyleAccess::AUTO_STYLE_NOTXT );
const bool bSetModifyAtAttr = ((SwAttrSet*)mrpAttrSet.get())->SetModifyAtAttr( &rNode );
rNode.SetModifyAtAttr( bSetModifyAtAttr );
}
void SetParent( boost::shared_ptr<const SfxItemSet>& mrpAttrSet,
const SwCntntNode& rNode,
const SwFmt* pParentFmt,
const SwFmt* pConditionalFmt )
{
const SwAttrSet* pAttrSet = static_cast<const SwAttrSet*>(mrpAttrSet.get());
OSL_ENSURE( pAttrSet, "no SwAttrSet" );
OSL_ENSURE( pParentFmt || !pConditionalFmt, "ConditionalFmt without ParentFmt?" );
const SwAttrSet* pParentSet = pParentFmt ? &pParentFmt->GetAttrSet() : 0;
if ( pParentSet != pAttrSet->GetParent() )
{
SwAttrSet aNewSet( *pAttrSet );
aNewSet.SetParent( pParentSet );
aNewSet.ClearItem( RES_FRMATR_STYLE_NAME );
aNewSet.ClearItem( RES_FRMATR_CONDITIONAL_STYLE_NAME );
OUString sVal;
if ( pParentFmt )
{
SwStyleNameMapper::FillProgName( pParentFmt->GetName(), sVal, nsSwGetPoolIdFromName::GET_POOLID_TXTCOLL, true );
const SfxStringItem aAnyFmtColl( RES_FRMATR_STYLE_NAME, sVal );
aNewSet.Put( aAnyFmtColl );
if ( pConditionalFmt != pParentFmt )
SwStyleNameMapper::FillProgName( pConditionalFmt->GetName(), sVal, nsSwGetPoolIdFromName::GET_POOLID_TXTCOLL, true );
const SfxStringItem aFmtColl( RES_FRMATR_CONDITIONAL_STYLE_NAME, sVal );
aNewSet.Put( aFmtColl );
}
GetNewAutoStyle( mrpAttrSet, rNode, aNewSet );
}
}
const SfxPoolItem* Put( boost::shared_ptr<const SfxItemSet>& mrpAttrSet,
const SwCntntNode& rNode,
const SfxPoolItem& rAttr )
{
SwAttrSet aNewSet( (SwAttrSet&)*mrpAttrSet );
const SfxPoolItem* pRet = aNewSet.Put( rAttr );
if ( pRet )
GetNewAutoStyle( mrpAttrSet, rNode, aNewSet );
return pRet;
}
bool Put( boost::shared_ptr<const SfxItemSet>& mrpAttrSet, const SwCntntNode& rNode,
const SfxItemSet& rSet )
{
SwAttrSet aNewSet( (SwAttrSet&)*mrpAttrSet );
// #i76273# Robust
SfxItemSet* pStyleNames = 0;
if ( SFX_ITEM_SET == rSet.GetItemState( RES_FRMATR_STYLE_NAME, sal_False ) )
{
pStyleNames = new SfxItemSet( *aNewSet.GetPool(), RES_FRMATR_STYLE_NAME, RES_FRMATR_CONDITIONAL_STYLE_NAME );
pStyleNames->Put( aNewSet );
}
const bool nRet = aNewSet.Put( rSet );
// #i76273# Robust
if ( pStyleNames )
{
aNewSet.Put( *pStyleNames );
delete pStyleNames;
}
if ( nRet )
GetNewAutoStyle( mrpAttrSet, rNode, aNewSet );
return nRet;
}
bool Put_BC( boost::shared_ptr<const SfxItemSet>& mrpAttrSet,
const SwCntntNode& rNode, const SfxPoolItem& rAttr,
SwAttrSet* pOld, SwAttrSet* pNew )
{
SwAttrSet aNewSet( (SwAttrSet&)*mrpAttrSet );
// for a correct broadcast, we need to do a SetModifyAtAttr with the items
// from aNewSet. The 'regular' SetModifyAtAttr is done in GetNewAutoStyle
if( rNode.GetModifyAtAttr() )
aNewSet.SetModifyAtAttr( &rNode );
const bool nRet = aNewSet.Put_BC( rAttr, pOld, pNew );
if ( nRet )
GetNewAutoStyle( mrpAttrSet, rNode, aNewSet );
return nRet;
}
bool Put_BC( boost::shared_ptr<const SfxItemSet>& mrpAttrSet,
const SwCntntNode& rNode, const SfxItemSet& rSet,
SwAttrSet* pOld, SwAttrSet* pNew )
{
SwAttrSet aNewSet( (SwAttrSet&)*mrpAttrSet );
// #i76273# Robust
SfxItemSet* pStyleNames = 0;
if ( SFX_ITEM_SET == rSet.GetItemState( RES_FRMATR_STYLE_NAME, sal_False ) )
{
pStyleNames = new SfxItemSet( *aNewSet.GetPool(), RES_FRMATR_STYLE_NAME, RES_FRMATR_CONDITIONAL_STYLE_NAME );
pStyleNames->Put( aNewSet );
}
// for a correct broadcast, we need to do a SetModifyAtAttr with the items
// from aNewSet. The 'regular' SetModifyAtAttr is done in GetNewAutoStyle
if( rNode.GetModifyAtAttr() )
aNewSet.SetModifyAtAttr( &rNode );
const bool nRet = aNewSet.Put_BC( rSet, pOld, pNew );
// #i76273# Robust
if ( pStyleNames )
{
aNewSet.Put( *pStyleNames );
delete pStyleNames;
}
if ( nRet )
GetNewAutoStyle( mrpAttrSet, rNode, aNewSet );
return nRet;
}
sal_uInt16 ClearItem_BC( boost::shared_ptr<const SfxItemSet>& mrpAttrSet,
const SwCntntNode& rNode, sal_uInt16 nWhich,
SwAttrSet* pOld, SwAttrSet* pNew )
{
SwAttrSet aNewSet( (SwAttrSet&)*mrpAttrSet );
if( rNode.GetModifyAtAttr() )
aNewSet.SetModifyAtAttr( &rNode );
const sal_uInt16 nRet = aNewSet.ClearItem_BC( nWhich, pOld, pNew );
if ( nRet )
GetNewAutoStyle( mrpAttrSet, rNode, aNewSet );
return nRet;
}
sal_uInt16 ClearItem_BC( boost::shared_ptr<const SfxItemSet>& mrpAttrSet,
const SwCntntNode& rNode,
sal_uInt16 nWhich1, sal_uInt16 nWhich2,
SwAttrSet* pOld, SwAttrSet* pNew )
{
SwAttrSet aNewSet( (SwAttrSet&)*mrpAttrSet );
if( rNode.GetModifyAtAttr() )
aNewSet.SetModifyAtAttr( &rNode );
const sal_uInt16 nRet = aNewSet.ClearItem_BC( nWhich1, nWhich2, pOld, pNew );
if ( nRet )
GetNewAutoStyle( mrpAttrSet, rNode, aNewSet );
return nRet;
}
}
/** Returns the section level at the position given by aIndex.
*
* We use the following logic:
* S = Start, E = End, C = CntntNode
* Level 0 = E
* 1 = S E
* 2 = SC
*
* All EndNodes of the BaseSection have level 0
* All StartNodes of the BaseSection have level 1
*/
sal_uInt16 SwNode::GetSectionLevel() const
2000-09-18 23:08:29 +00:00
{
// EndNode of a BaseSection? They are always 0!
2000-09-18 23:08:29 +00:00
if( IsEndNode() && 0 == pStartOfSection->StartOfSectionIndex() )
return 0;
sal_uInt16 nLevel;
2000-09-18 23:08:29 +00:00
const SwNode* pNode = IsStartNode() ? this : pStartOfSection;
for( nLevel = 1; 0 != pNode->StartOfSectionIndex(); ++nLevel )
pNode = pNode->pStartOfSection;
return IsEndNode() ? nLevel-1 : nLevel;
}
#ifdef DBG_UTIL
long SwNode::s_nSerial = 0;
#endif
2000-09-18 23:08:29 +00:00
SwNode::SwNode( const SwNodeIndex &rWhere, const sal_uInt8 nNdType )
: nNodeType( nNdType )
, nAFmtNumLvl( 0 )
, bSetNumLSpace( false )
, bIgnoreDontExpand( false)
#ifdef DBG_UTIL
, m_nSerial( s_nSerial++)
#endif
, pStartOfSection( 0 )
2000-09-18 23:08:29 +00:00
{
SwNodes& rNodes = const_cast<SwNodes&> (rWhere.GetNodes());
2000-09-18 23:08:29 +00:00
if( rWhere.GetIndex() )
{
SwNode* pNd = rNodes[ rWhere.GetIndex() -1 ];
rNodes.InsertNode( this, rWhere );
2000-09-18 23:08:29 +00:00
if( 0 == ( pStartOfSection = pNd->GetStartNode()) )
{
pStartOfSection = pNd->pStartOfSection;
if( pNd->GetEndNode() ) // Skip EndNode ? Section
2000-09-18 23:08:29 +00:00
{
pNd = pStartOfSection;
pStartOfSection = pNd->pStartOfSection;
}
}
}
else
{
rNodes.InsertNode( this, rWhere );
2000-09-18 23:08:29 +00:00
pStartOfSection = (SwStartNode*)this;
}
}
/** Inserts a node into the rNodes array at the rWhere position
*
* @param rNodes the variable array in that the node will be inserted
* @param nPos position within the array where the node will be inserted
* @param nNdType the type of node to insert
*/
SwNode::SwNode( SwNodes& rNodes, sal_uLong nPos, const sal_uInt8 nNdType )
: nNodeType( nNdType )
, nAFmtNumLvl( 0 )
, bSetNumLSpace( false )
, bIgnoreDontExpand( false)
#ifdef DBG_UTIL
, m_nSerial( s_nSerial++)
#endif
, pStartOfSection( 0 )
2000-09-18 23:08:29 +00:00
{
if( nPos )
{
SwNode* pNd = rNodes[ nPos - 1 ];
rNodes.InsertNode( this, nPos );
2000-09-18 23:08:29 +00:00
if( 0 == ( pStartOfSection = pNd->GetStartNode()) )
{
pStartOfSection = pNd->pStartOfSection;
if( pNd->GetEndNode() ) // Skip EndNode ? Section!
2000-09-18 23:08:29 +00:00
{
pNd = pStartOfSection;
pStartOfSection = pNd->pStartOfSection;
}
}
}
else
{
rNodes.InsertNode( this, nPos );
2000-09-18 23:08:29 +00:00
pStartOfSection = (SwStartNode*)this;
}
}
2000-11-06 09:46:12 +00:00
SwNode::~SwNode()
{
}
2000-09-18 23:08:29 +00:00
/// Find the TableNode in which it is located.
/// If we're not in a table: return 0
2000-09-18 23:08:29 +00:00
SwTableNode* SwNode::FindTableNode()
{
if( IsTableNode() )
return GetTableNode();
SwStartNode* pTmp = pStartOfSection;
while( !pTmp->IsTableNode() && pTmp->GetIndex() )
pTmp = pTmp->pStartOfSection;
return pTmp->GetTableNode();
}
/// Is the node located in the visible area of the Shell?
sal_Bool SwNode::IsInVisibleArea( SwViewShell* pSh ) const
2000-09-18 23:08:29 +00:00
{
sal_Bool bRet = sal_False;
2000-09-18 23:08:29 +00:00
const SwCntntNode* pNd;
if( ND_STARTNODE & nNodeType )
{
SwNodeIndex aIdx( *this );
pNd = GetNodes().GoNext( &aIdx );
}
else if( ND_ENDNODE & nNodeType )
{
SwNodeIndex aIdx( *EndOfSectionNode() );
pNd = GetNodes().GoPrevious( &aIdx );
}
else
pNd = GetCntntNode();
if( !pSh )
// Get the Shell from the Doc
GetDoc()->GetEditShell( &pSh );
2000-09-18 23:08:29 +00:00
if( pSh )
{
const SwFrm* pFrm;
if( pNd && 0 != ( pFrm = pNd->getLayoutFrm( pSh->GetLayout(), 0, 0, sal_False ) ) )
2000-09-18 23:08:29 +00:00
{
2000-09-18 23:08:29 +00:00
if ( pFrm->IsInTab() )
pFrm = pFrm->FindTabFrm();
if( !pFrm->IsValid() )
do
{ pFrm = pFrm->FindPrev();
} while ( pFrm && !pFrm->IsValid() );
if( !pFrm || pSh->VisArea().IsOver( pFrm->Frm() ) )
bRet = sal_True;
2000-09-18 23:08:29 +00:00
}
}
return bRet;
}
bool SwNode::IsInProtectSect() const
2000-09-18 23:08:29 +00:00
{
const SwNode* pNd = ND_SECTIONNODE == nNodeType ? pStartOfSection : this;
const SwSectionNode* pSectNd = pNd->FindSectionNode();
return pSectNd && pSectNd->GetSection().IsProtectFlag();
}
/// Does the node contain anything protected?
/// I.e.: Area/Frame/Table rows/... including the Anchor for
/// Frames/Footnotes/...
sal_Bool SwNode::IsProtect() const
2000-09-18 23:08:29 +00:00
{
const SwNode* pNd = ND_SECTIONNODE == nNodeType ? pStartOfSection : this;
const SwStartNode* pSttNd = pNd->FindSectionNode();
if( pSttNd && ((SwSectionNode*)pSttNd)->GetSection().IsProtectFlag() )
return sal_True;
2000-09-18 23:08:29 +00:00
if( 0 != ( pSttNd = FindTableBoxStartNode() ) )
{
SwCntntFrm* pCFrm;
if( IsCntntNode() && 0 != (pCFrm = ((SwCntntNode*)this)->getLayoutFrm( GetDoc()->GetCurrentLayout() ) ))
2000-09-18 23:08:29 +00:00
return pCFrm->IsProtected();
const SwTableBox* pBox = pSttNd->FindTableNode()->GetTable().
GetTblBox( pSttNd->GetIndex() );
//Robust #149568
if( pBox && pBox->GetFrmFmt()->GetProtect().IsCntntProtected() )
return sal_True;
2000-09-18 23:08:29 +00:00
}
SwFrmFmt* pFlyFmt = GetFlyFmt();
if( pFlyFmt )
{
if( pFlyFmt->GetProtect().IsCntntProtected() )
return sal_True;
2000-09-18 23:08:29 +00:00
const SwFmtAnchor& rAnchor = pFlyFmt->GetAnchor();
return rAnchor.GetCntntAnchor()
? rAnchor.GetCntntAnchor()->nNode.GetNode().IsProtect()
: sal_False;
2000-09-18 23:08:29 +00:00
}
if( 0 != ( pSttNd = FindFootnoteStartNode() ) )
{
const SwTxtFtn* pTFtn = GetDoc()->GetFtnIdxs().SeekEntry(
SwNodeIndex( *pSttNd ) );
if( pTFtn )
return pTFtn->GetTxtNode().IsProtect();
}
return sal_False;
2000-09-18 23:08:29 +00:00
}
/// Find the PageDesc that is used to format this node. If the Layout is available,
/// we search through that. Else we can only do it the hard way by searching onwards through the nodes.
const SwPageDesc* SwNode::FindPageDesc( sal_Bool bCalcLay,
sal_uInt32* pPgDescNdIdx ) const
2000-09-18 23:08:29 +00:00
{
if ( !GetNodes().IsDocNodes() )
{
return 0;
}
2000-09-18 23:08:29 +00:00
const SwPageDesc* pPgDesc = 0;
const SwCntntNode* pNode;
if( ND_STARTNODE & nNodeType )
2000-09-18 23:08:29 +00:00
{
SwNodeIndex aIdx( *this );
pNode = GetNodes().GoNext( &aIdx );
}
else if( ND_ENDNODE & nNodeType )
{
SwNodeIndex aIdx( *EndOfSectionNode() );
pNode = GetNodes().GoPrevious( &aIdx );
}
else
{
pNode = GetCntntNode();
if( pNode )
pPgDesc = ((SwFmtPageDesc&)pNode->GetAttr( RES_PAGEDESC )).GetPageDesc();
}
2000-09-18 23:08:29 +00:00
// Are we going through the layout?
if( !pPgDesc )
{
const SwFrm* pFrm;
const SwPageFrm* pPage;
if( pNode && 0 != ( pFrm = pNode->getLayoutFrm( pNode->GetDoc()->GetCurrentLayout(), 0, 0, bCalcLay ) ) &&
0 != ( pPage = pFrm->FindPageFrm() ) )
2000-09-18 23:08:29 +00:00
{
pPgDesc = pPage->GetPageDesc();
if ( pPgDescNdIdx )
2000-09-18 23:08:29 +00:00
{
*pPgDescNdIdx = pNode->GetIndex();
2000-09-18 23:08:29 +00:00
}
}
}
2000-09-18 23:08:29 +00:00
if( !pPgDesc )
{
// Thus via the nodes array
const SwDoc* pDoc = GetDoc();
const SwNode* pNd = this;
const SwStartNode* pSttNd;
if( pNd->GetIndex() < GetNodes().GetEndOfExtras().GetIndex() &&
0 != ( pSttNd = pNd->FindFlyStartNode() ) )
2000-09-18 23:08:29 +00:00
{
// Find the right Anchor first
const SwFrmFmt* pFmt = 0;
const SwFrmFmts& rFmts = *pDoc->GetSpzFrmFmts();
sal_uInt16 n;
for( n = 0; n < rFmts.size(); ++n )
2000-09-18 23:08:29 +00:00
{
SwFrmFmt* pFrmFmt = rFmts[ n ];
const SwFmtCntnt& rCntnt = pFrmFmt->GetCntnt();
if( rCntnt.GetCntntIdx() &&
&rCntnt.GetCntntIdx()->GetNode() == (SwNode*)pSttNd )
2000-09-18 23:08:29 +00:00
{
pFmt = pFrmFmt;
break;
2000-09-18 23:08:29 +00:00
}
}
2000-09-18 23:08:29 +00:00
if( pFmt )
{
const SwFmtAnchor* pAnchor = &pFmt->GetAnchor();
if ((FLY_AT_PAGE != pAnchor->GetAnchorId()) &&
pAnchor->GetCntntAnchor() )
2000-09-18 23:08:29 +00:00
{
pNd = &pAnchor->GetCntntAnchor()->nNode.GetNode();
const SwNode* pFlyNd = pNd->FindFlyStartNode();
while( pFlyNd )
2000-09-18 23:08:29 +00:00
{
// Get up through the Anchor
for( n = 0; n < rFmts.size(); ++n )
2000-09-18 23:08:29 +00:00
{
const SwFrmFmt* pFrmFmt = rFmts[ n ];
const SwNodeIndex* pIdx = pFrmFmt->GetCntnt().
GetCntntIdx();
if( pIdx && pFlyNd == &pIdx->GetNode() )
2000-09-18 23:08:29 +00:00
{
if( pFmt == pFrmFmt )
2000-09-18 23:08:29 +00:00
{
pNd = pFlyNd;
pFlyNd = 0;
2000-09-18 23:08:29 +00:00
break;
}
pAnchor = &pFrmFmt->GetAnchor();
if ((FLY_AT_PAGE == pAnchor->GetAnchorId()) ||
!pAnchor->GetCntntAnchor() )
{
pFlyNd = 0;
break;
}
pFlyNd = pAnchor->GetCntntAnchor()->nNode.
GetNode().FindFlyStartNode();
break;
2000-09-18 23:08:29 +00:00
}
}
if( n >= rFmts.size() )
{
OSL_ENSURE( !this, "FlySection, but no Format found" );
return 0;
2000-09-18 23:08:29 +00:00
}
}
}
}
// pNd should now contain the correct Anchor or it's still this
}
2000-09-18 23:08:29 +00:00
if( pNd->GetIndex() < GetNodes().GetEndOfExtras().GetIndex() )
{
if( pNd->GetIndex() > GetNodes().GetEndOfAutotext().GetIndex() )
2000-09-18 23:08:29 +00:00
{
pPgDesc = &pDoc->GetPageDesc( 0 );
pNd = 0;
}
else
{
// Find the Body text node
if( 0 != ( pSttNd = pNd->FindHeaderStartNode() ) ||
0 != ( pSttNd = pNd->FindFooterStartNode() ))
2000-09-18 23:08:29 +00:00
{
// Then find this StartNode in the PageDescs
sal_uInt16 nId;
UseOnPage eAskUse;
if( SwHeaderStartNode == pSttNd->GetStartNodeType())
2000-09-18 23:08:29 +00:00
{
nId = RES_HEADER;
eAskUse = nsUseOnPage::PD_HEADERSHARE;
}
else
{
nId = RES_FOOTER;
eAskUse = nsUseOnPage::PD_FOOTERSHARE;
}
2000-09-18 23:08:29 +00:00
for( sal_uInt16 n = pDoc->GetPageDescCnt(); n && !pPgDesc; )
{
const SwPageDesc& rPgDsc = pDoc->GetPageDesc( --n );
const SwFrmFmt* pFmt = &rPgDsc.GetMaster();
int nStt = 0, nLast = 1;
if( !( eAskUse & rPgDsc.ReadUseOn() )) ++nLast;
2000-09-18 23:08:29 +00:00
for( ; nStt < nLast; ++nStt, pFmt = &rPgDsc.GetLeft() )
{
const SwFmtHeader& rHdFt = (SwFmtHeader&)
pFmt->GetFmtAttr( nId );
if( rHdFt.GetHeaderFmt() )
2000-09-18 23:08:29 +00:00
{
const SwFmtCntnt& rCntnt =
rHdFt.GetHeaderFmt()->GetCntnt();
if( rCntnt.GetCntntIdx() &&
&rCntnt.GetCntntIdx()->GetNode() ==
(SwNode*)pSttNd )
2000-09-18 23:08:29 +00:00
{
pPgDesc = &rPgDsc;
break;
2000-09-18 23:08:29 +00:00
}
}
}
}
if( !pPgDesc )
2000-09-18 23:08:29 +00:00
pPgDesc = &pDoc->GetPageDesc( 0 );
pNd = 0;
}
else if( 0 != ( pSttNd = pNd->FindFootnoteStartNode() ))
{
// the Anchor can only be in the Body text
const SwTxtFtn* pTxtFtn;
const SwFtnIdxs& rFtnArr = pDoc->GetFtnIdxs();
for( sal_uInt16 n = 0; n < rFtnArr.size(); ++n )
if( 0 != ( pTxtFtn = rFtnArr[ n ])->GetStartNode() &&
(SwNode*)pSttNd ==
&pTxtFtn->GetStartNode()->GetNode() )
{
pNd = &pTxtFtn->GetTxtNode();
break;
}
}
else
{
// Can only be a page-bound Fly (or something newer).
// we can only return the standard here
OSL_ENSURE( pNd->FindFlyStartNode(),
"Where is this Node?" );
pPgDesc = &pDoc->GetPageDesc( 0 );
pNd = 0;
2000-09-18 23:08:29 +00:00
}
}
}
2000-09-18 23:08:29 +00:00
if( pNd )
{
SwFindNearestNode aInfo( *pNd );
// Over all Nodes of all PageDescs
const SfxPoolItem* pItem;
sal_uInt32 i, nMaxItems = pDoc->GetAttrPool().GetItemCount2( RES_PAGEDESC );
for( i = 0; i < nMaxItems; ++i )
if( 0 != (pItem = pDoc->GetAttrPool().GetItem2( RES_PAGEDESC, i ) ) &&
((SwFmtPageDesc*)pItem)->GetDefinedIn() )
{
const SwModify* pMod = ((SwFmtPageDesc*)pItem)->GetDefinedIn();
if( pMod->ISA( SwCntntNode ) )
aInfo.CheckNode( *(SwCntntNode*)pMod );
else if( pMod->ISA( SwFmt ))
((SwFmt*)pMod)->GetInfo( aInfo );
}
2000-09-18 23:08:29 +00:00
if( 0 != ( pNd = aInfo.GetFoundNode() ))
{
if( pNd->IsCntntNode() )
pPgDesc = ((SwFmtPageDesc&)pNd->GetCntntNode()->
GetAttr( RES_PAGEDESC )).GetPageDesc();
else if( pNd->IsTableNode() )
pPgDesc = pNd->GetTableNode()->GetTable().
GetFrmFmt()->GetPageDesc().GetPageDesc();
else if( pNd->IsSectionNode() )
pPgDesc = pNd->GetSectionNode()->GetSection().
GetFmt()->GetPageDesc().GetPageDesc();
if ( pPgDescNdIdx )
2000-09-18 23:08:29 +00:00
{
*pPgDescNdIdx = pNd->GetIndex();
2000-09-18 23:08:29 +00:00
}
}
if( !pPgDesc )
pPgDesc = &pDoc->GetPageDesc( 0 );
2000-09-18 23:08:29 +00:00
}
}
return pPgDesc;
}
/// If the node is located in a Fly, we return it formatted accordingly
2000-09-18 23:08:29 +00:00
SwFrmFmt* SwNode::GetFlyFmt() const
{
SwFrmFmt* pRet = 0;
const SwNode* pSttNd = FindFlyStartNode();
if( pSttNd )
{
if( IsCntntNode() )
{
SwCntntFrm* pFrm = SwIterator<SwCntntFrm,SwCntntNode>::FirstElement( *(SwCntntNode*)this );
if( pFrm )
pRet = pFrm->FindFlyFrm()->GetFmt();
2000-09-18 23:08:29 +00:00
}
if( !pRet )
{
// The hard way through the Doc is our last way out
const SwFrmFmts& rFrmFmtTbl = *GetDoc()->GetSpzFrmFmts();
for( sal_uInt16 n = 0; n < rFrmFmtTbl.size(); ++n )
2000-09-18 23:08:29 +00:00
{
SwFrmFmt* pFmt = rFrmFmtTbl[n];
const SwFmtCntnt& rCntnt = pFmt->GetCntnt();
if( rCntnt.GetCntntIdx() &&
&rCntnt.GetCntntIdx()->GetNode() == pSttNd )
{
pRet = pFmt;
break;
}
}
}
}
return pRet;
}
SwTableBox* SwNode::GetTblBox() const
{
SwTableBox* pBox = 0;
const SwNode* pSttNd = FindTableBoxStartNode();
if( pSttNd )
pBox = (SwTableBox*)pSttNd->FindTableNode()->GetTable().GetTblBox(
pSttNd->GetIndex() );
return pBox;
}
SwStartNode* SwNode::FindSttNodeByType( SwStartNodeType eTyp )
{
SwStartNode* pTmp = IsStartNode() ? (SwStartNode*)this : pStartOfSection;
while( eTyp != pTmp->GetStartNodeType() && pTmp->GetIndex() )
pTmp = pTmp->pStartOfSection;
return eTyp == pTmp->GetStartNodeType() ? pTmp : 0;
}
const SwTxtNode* SwNode::FindOutlineNodeOfLevel( sal_uInt8 nLvl ) const
2000-09-18 23:08:29 +00:00
{
const SwTxtNode* pRet = 0;
const SwOutlineNodes& rONds = GetNodes().GetOutLineNds();
if( MAXLEVEL > nLvl && !rONds.empty() )
2000-09-18 23:08:29 +00:00
{
sal_uInt16 nPos;
2000-09-18 23:08:29 +00:00
SwNode* pNd = (SwNode*)this;
bool bCheckFirst = false;
2000-09-18 23:08:29 +00:00
if( !rONds.Seek_Entry( pNd, &nPos ))
{
if( nPos )
nPos = nPos-1;
else
bCheckFirst = true;
2000-09-18 23:08:29 +00:00
}
if( bCheckFirst )
{
// The first OutlineNode comes after the one asking. Test if it points to the same node.
// If not it's invalid.
2000-09-18 23:08:29 +00:00
pRet = rONds[0]->GetTxtNode();
const SwCntntNode* pCNd = GetCntntNode();
Point aPt( 0, 0 );
const SwFrm* pFrm = pRet->getLayoutFrm( pRet->GetDoc()->GetCurrentLayout(), &aPt, 0, sal_False ),
* pMyFrm = pCNd ? pCNd->getLayoutFrm( pCNd->GetDoc()->GetCurrentLayout(), &aPt, 0, sal_False ) : 0;
2000-09-18 23:08:29 +00:00
const SwPageFrm* pPgFrm = pFrm ? pFrm->FindPageFrm() : 0;
if( pPgFrm && pMyFrm &&
pPgFrm->Frm().Top() > pMyFrm->Frm().Top() )
{
// The one asking precedes the Page, thus its invalid
2000-09-18 23:08:29 +00:00
pRet = 0;
}
}
else
{
// Or at the Field and get it from there!
CWS-TOOLING: integrate CWS outlinelevel 2008-12-19 10:32:51 +0100 od r265718 : #i70748# method <SwWW8Writer::StartTOX(..)> - correction for custom to outline style assigned paragraph styles 2008-12-19 09:24:41 +0100 od r265715 : #i70748# method <HandleModifyAtTxtNode(..)> - retrieve former applied list style before potential reset of empty list style due to set outline level 2008-12-17 15:33:57 +0100 hde r265608 : #i97013# 2008-12-17 14:43:42 +0100 od r265603 : #i70748# adjust fix i44177 - adjustment of to outline style assigned paragraph styles only for OOo-Templates. 2008-12-17 12:59:42 +0100 od r265598 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - special handling of OOo 2.x document regarding outline numbering of headings. 2008-12-17 12:45:53 +0100 od r265597 : #i70748# method <HandleModifyAtTxtNode(..)> - correct determination of new and former applied list style 2008-12-17 10:18:41 +0100 od r265581 : #i97312# method <XMLTextNumRuleInfo::Set(..)> - check, if numbering rules instance contains any numbering rule. 2008-12-16 14:34:22 +0100 hde r265542 : #i97013 2008-12-16 14:20:24 +0100 od r265541 : #i70748# adjust documentation of "Which"-ID numbers 2008-12-16 14:19:49 +0100 od r265539 : #i70748# Adjust Attribute-Function-Mapping table due to new attribute 2008-12-16 14:06:24 +0100 od r265538 : #i70748# - Correct handling of to outline style assigned paragraph styles on reset of all paragraph style attributes - WW8 import: Consider refactoring of paragraph style's outline level attribute - NO_NUMBERING define no longer exsits. 2008-12-16 10:37:19 +0100 od r265530 : #i70478# Correction on moving outline paragraph up respectively down in its outline level: - Check also outline paragraph, which are not an outline via a to outline style assigned paragraph style, if action is applicable. 2008-12-16 09:10:13 +0100 hde r265523 : #i97277 2008-12-16 09:09:30 +0100 hde r265522 : #i97277 2008-12-16 09:07:40 +0100 hde r265521 : Added control and purged obsolete id's 2008-12-10 13:09:36 +0100 od r265174 : #i70748# correction of previous fix due to warning-free code 2008-12-10 13:03:30 +0100 od r265172 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - Due to performance issues avoid retrieving outline level value from paragraph's paragraph style for each paragraph. Instead retrieve current outline level value from paragraph, which is the inherited value from its paragraph style, and only when it is needed. 2008-12-09 16:50:36 +0100 ufi r265117 : help 2008-12-09 16:49:50 +0100 ufi r265116 : help 2008-12-09 15:45:05 +0100 od r265107 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - some minor rework and check access to paragraph styles 2008-12-09 15:42:04 +0100 od r265106 : #i70748# adjust name of local variable to avoid hiding of class variable 2008-12-09 15:40:51 +0100 od r265105 : #i70748# correct initialization order 2008-12-09 15:35:07 +0100 od r265101 : #i70748# remove duplicate entry in certain property map 2008-12-09 15:33:39 +0100 od r265100 : #i70748# add end of file token 2008-12-07 15:11:54 +0100 zhaojianwei r264952 : conflicts left not to be resolved when cws rebase 2008-12-04 14:52:21 +0100 zhaojianwei r264846 : CWS-TOOLING: rebase CWS outlinelevel to trunk@264325 (milestone: DEV300:m36) 2008-11-28 03:42:09 +0100 zhaojianwei r264525 : #i70748#: migrate CWS outlinelevel to SVN 2008-11-28 03:41:39 +0100 zhaojianwei r264524 : #i70748#: migrate CWS outlinelevel to SVN 2008-11-28 03:41:11 +0100 zhaojianwei r264523 : #i70748#: migrate CWS outlinelevel to SVN
2009-01-07 11:57:24 +00:00
while( nPos &&
nLvl < ( pRet = rONds[nPos]->GetTxtNode() )
->GetAttrOutlineLevel() - 1 )
2000-09-18 23:08:29 +00:00
--nPos;
if( !nPos ) // Get separately when 0
2000-09-18 23:08:29 +00:00
pRet = rONds[0]->GetTxtNode();
}
}
return pRet;
}
inline bool IsValidNextPrevNd( const SwNode& rNd )
2000-09-18 23:08:29 +00:00
{
return ND_TABLENODE == rNd.GetNodeType() ||
( ND_CONTENTNODE & rNd.GetNodeType() ) ||
( ND_ENDNODE == rNd.GetNodeType() && rNd.StartOfSectionNode() &&
ND_TABLENODE == rNd.StartOfSectionNode()->GetNodeType() );
}
sal_uInt8 SwNode::HasPrevNextLayNode() const
2000-09-18 23:08:29 +00:00
{
// assumption: <this> node is a node inside the document nodes array section.
sal_uInt8 nRet = 0;
2000-09-18 23:08:29 +00:00
if( IsValidNextPrevNd( *this ))
{
SwNodeIndex aIdx( *this, -1 );
2011-02-02 20:41:40 +09:00
// #i77805# - skip section start and end nodes
while ( aIdx.GetNode().IsSectionNode() ||
( aIdx.GetNode().IsEndNode() &&
aIdx.GetNode().StartOfSectionNode()->IsSectionNode() ) )
{
--aIdx;
}
2000-09-18 23:08:29 +00:00
if( IsValidNextPrevNd( aIdx.GetNode() ))
nRet |= ND_HAS_PREV_LAYNODE;
2010-11-19 12:33:24 +01:00
// #i77805# - skip section start and end nodes
aIdx = SwNodeIndex( *this, +1 );
while ( aIdx.GetNode().IsSectionNode() ||
( aIdx.GetNode().IsEndNode() &&
aIdx.GetNode().StartOfSectionNode()->IsSectionNode() ) )
{
++aIdx;
}
2000-09-18 23:08:29 +00:00
if( IsValidNextPrevNd( aIdx.GetNode() ))
nRet |= ND_HAS_NEXT_LAYNODE;
}
return nRet;
}
SwStartNode::SwStartNode( const SwNodeIndex &rWhere, const sal_uInt8 nNdType,
2000-09-18 23:08:29 +00:00
SwStartNodeType eSttNd )
: SwNode( rWhere, nNdType ), eSttNdTyp( eSttNd )
{
// Just do this temporarily until the EndNode is inserted
2000-09-18 23:08:29 +00:00
pEndOfSection = (SwEndNode*)this;
}
SwStartNode::SwStartNode( SwNodes& rNodes, sal_uLong nPos )
2000-09-18 23:08:29 +00:00
: SwNode( rNodes, nPos, ND_STARTNODE ), eSttNdTyp( SwNormalStartNode )
{
// Just do this temporarily until the EndNode is inserted
2000-09-18 23:08:29 +00:00
pEndOfSection = (SwEndNode*)this;
}
void SwStartNode::CheckSectionCondColl() const
{
//FEATURE::CONDCOLL
SwNodeIndex aIdx( *this );
sal_uLong nEndIdx = EndOfSectionIndex();
2000-09-18 23:08:29 +00:00
const SwNodes& rNds = GetNodes();
SwCntntNode* pCNd;
while( 0 != ( pCNd = rNds.GoNext( &aIdx )) && pCNd->GetIndex() < nEndIdx )
pCNd->ChkCondColl();
//FEATURE::CONDCOLL
}
/** Insert a node into the array
*
* The StartOfSection pointer is set to the given node.
*
* The EndOfSection pointer of the corresponding start node is set to this node.
*
* @param rWhere position where the node shoul be inserted
* @param rSttNd the start note of the section
*/
2000-09-18 23:08:29 +00:00
SwEndNode::SwEndNode( const SwNodeIndex &rWhere, SwStartNode& rSttNd )
: SwNode( rWhere, ND_ENDNODE )
{
pStartOfSection = &rSttNd;
pStartOfSection->pEndOfSection = this;
}
SwEndNode::SwEndNode( SwNodes& rNds, sal_uLong nPos, SwStartNode& rSttNd )
2000-09-18 23:08:29 +00:00
: SwNode( rNds, nPos, ND_ENDNODE )
{
pStartOfSection = &rSttNd;
pStartOfSection->pEndOfSection = this;
}
// SwCntntNode
SwCntntNode::SwCntntNode( const SwNodeIndex &rWhere, const sal_uInt8 nNdType,
2000-09-18 23:08:29 +00:00
SwFmtColl *pColl )
: SwModify( pColl ), // CrsrsShell, FrameFmt,
SwNode( rWhere, nNdType ),
2000-09-18 23:08:29 +00:00
pCondColl( 0 ),
mbSetModifyAtAttr( false )
2000-09-18 23:08:29 +00:00
{
}
SwCntntNode::~SwCntntNode()
{
// The base class SwClient of SwFrm excludes itself from the dependency list!
// Thus, we need to delete all Frames in the dependency list.
2000-09-18 23:08:29 +00:00
if( GetDepends() )
DelFrms(sal_True, sal_False);
2000-09-18 23:08:29 +00:00
2011-11-17 22:13:42 +04:00
delete pCondColl;
2000-09-18 23:08:29 +00:00
if ( mpAttrSet.get() && mbSetModifyAtAttr )
((SwAttrSet*)mpAttrSet.get())->SetModifyAtAttr( 0 );
}
2000-09-18 23:08:29 +00:00
void SwCntntNode::Modify( const SfxPoolItem* pOldValue, const SfxPoolItem* pNewValue )
2000-09-18 23:08:29 +00:00
{
sal_uInt16 nWhich = pOldValue ? pOldValue->Which() :
2000-09-18 23:08:29 +00:00
pNewValue ? pNewValue->Which() : 0 ;
switch( nWhich )
{
case RES_OBJECTDYING :
{
SwFmt * pFmt = (SwFmt *) ((SwPtrMsgPoolItem *)pNewValue)->pObject;
// Do not mangle pointers if it is the upper-most format!
if( GetRegisteredIn() == pFmt )
2000-09-18 23:08:29 +00:00
{
if( pFmt->GetRegisteredIn() )
{
// If Parent, register anew in the new Parent
2000-09-18 23:08:29 +00:00
((SwModify*)pFmt->GetRegisteredIn())->Add( this );
if ( GetpSwAttrSet() )
AttrSetHandleHelper::SetParent( mpAttrSet, *this, GetFmtColl(), GetFmtColl() );
2000-09-18 23:08:29 +00:00
}
else
{
// Else register anyways when dying
2000-09-18 23:08:29 +00:00
((SwModify*)GetRegisteredIn())->Remove( this );
if ( GetpSwAttrSet() )
AttrSetHandleHelper::SetParent( mpAttrSet, *this, 0, 0 );
2000-09-18 23:08:29 +00:00
}
}
}
break;
case RES_FMT_CHG:
// If the Format parent was switched, register the Attrset at the new one
// Skip own Modify!
if( GetpSwAttrSet() &&
2000-09-18 23:08:29 +00:00
((SwFmtChg*)pNewValue)->pChangedFmt == GetRegisteredIn() )
{
// Attach Set to the new parent
AttrSetHandleHelper::SetParent( mpAttrSet, *this, GetFmtColl(), GetFmtColl() );
2000-09-18 23:08:29 +00:00
}
break;
2000-09-18 23:08:29 +00:00
//FEATURE::CONDCOLL
case RES_CONDCOLL_CONDCHG:
if( ((SwCondCollCondChg*)pNewValue)->pChangedFmt == GetRegisteredIn() &&
&GetNodes() == &GetDoc()->GetNodes() )
{
ChkCondColl();
}
return ; // Do not pass through to the base class/Frames
2000-09-18 23:08:29 +00:00
//FEATURE::CONDCOLL
case RES_ATTRSET_CHG:
if( GetNodes().IsDocNodes() && IsTxtNode() )
{
if( SFX_ITEM_SET == ((SwAttrSetChg*)pOldValue)->GetChgSet()->GetItemState(
RES_CHRATR_HIDDEN, sal_False ) )
{
((SwTxtNode*)this)->SetCalcHiddenCharFlags();
}
2000-09-18 23:08:29 +00:00
}
break;
case RES_UPDATE_ATTR:
if( GetNodes().IsDocNodes() && IsTxtNode() )
{
const sal_uInt16 nTmp = ((SwUpdateAttr*)pNewValue)->nWhichAttr;
if ( RES_ATTRSET_CHG == nTmp )
{
// TODO: anybody wants to do some optimization here?
((SwTxtNode*)this)->SetCalcHiddenCharFlags();
}
}
break;
2000-09-18 23:08:29 +00:00
}
NotifyClients( pOldValue, pNewValue );
2000-09-18 23:08:29 +00:00
}
sal_Bool SwCntntNode::InvalidateNumRule()
2000-09-18 23:08:29 +00:00
{
SwNumRule* pRule = 0;
const SfxPoolItem* pItem;
if( GetNodes().IsDocNodes() &&
0 != ( pItem = GetNoCondAttr( RES_PARATR_NUMRULE, sal_True )) &&
!((SwNumRuleItem*)pItem)->GetValue().isEmpty() &&
2000-09-18 23:08:29 +00:00
0 != (pRule = GetDoc()->FindNumRulePtr(
((SwNumRuleItem*)pItem)->GetValue() ) ) )
{
pRule->SetInvalidRule( sal_True );
2000-09-18 23:08:29 +00:00
}
return 0 != pRule;
}
SwCntntFrm *SwCntntNode::getLayoutFrm( const SwRootFrm* _pRoot,
const Point* pPoint, const SwPosition *pPos, const sal_Bool bCalcFrm ) const
2000-09-18 23:08:29 +00:00
{
return (SwCntntFrm*) ::GetFrmOfModify( _pRoot, *(SwModify*)this, FRM_CNTNT,
2000-09-18 23:08:29 +00:00
pPoint, pPos, bCalcFrm );
}
SwRect SwCntntNode::FindLayoutRect( const sal_Bool bPrtArea, const Point* pPoint,
const sal_Bool bCalcFrm ) const
2000-09-18 23:08:29 +00:00
{
SwRect aRet;
SwCntntFrm* pFrm = (SwCntntFrm*)::GetFrmOfModify( 0, *(SwModify*)this,
2000-09-18 23:08:29 +00:00
FRM_CNTNT, pPoint, 0, bCalcFrm );
if( pFrm )
aRet = bPrtArea ? pFrm->Prt() : pFrm->Frm();
return aRet;
}
SwRect SwCntntNode::FindPageFrmRect( const sal_Bool bPrtArea, const Point* pPoint,
const sal_Bool bCalcFrm ) const
2000-09-18 23:08:29 +00:00
{
SwRect aRet;
SwFrm* pFrm = ::GetFrmOfModify( 0, *(SwModify*)this,
2000-09-18 23:08:29 +00:00
FRM_CNTNT, pPoint, 0, bCalcFrm );
if( pFrm && 0 != ( pFrm = pFrm->FindPageFrm() ))
aRet = bPrtArea ? pFrm->Prt() : pFrm->Frm();
return aRet;
}
sal_Int32 SwCntntNode::Len() const { return 0; }
2000-09-18 23:08:29 +00:00
SwFmtColl *SwCntntNode::ChgFmtColl( SwFmtColl *pNewColl )
{
OSL_ENSURE( pNewColl, "Collectionpointer is 0." );
2000-09-18 23:08:29 +00:00
SwFmtColl *pOldColl = GetFmtColl();
2000-09-18 23:08:29 +00:00
if( pNewColl != pOldColl )
{
pNewColl->Add( this );
// Set the Parent of out AutoAttributes to the new Collection
if( GetpSwAttrSet() )
AttrSetHandleHelper::SetParent( mpAttrSet, *this, pNewColl, pNewColl );
2000-09-18 23:08:29 +00:00
//FEATURE::CONDCOLL
// TODO: HACK: We need to recheck this condition according to the new template!
if( true /*pNewColl */ )
2000-09-18 23:08:29 +00:00
{
SetCondFmtColl( 0 );
}
//FEATURE::CONDCOLL
if( !IsModifyLocked() )
{
SwFmtChg aTmp1( pOldColl );
SwFmtChg aTmp2( pNewColl );
SwCntntNode::Modify( &aTmp1, &aTmp2 );
}
}
if ( IsInCache() )
{
SwFrm::GetCache().Delete( this );
SetInCache( sal_False );
2000-09-18 23:08:29 +00:00
}
return pOldColl;
}
sal_Bool SwCntntNode::GoNext(SwIndex * pIdx, sal_uInt16 nMode ) const
2000-09-18 23:08:29 +00:00
{
sal_Bool bRet = sal_True;
2000-09-18 23:08:29 +00:00
if( pIdx->GetIndex() < Len() )
{
if( !IsTxtNode() )
++(*pIdx);
else
2000-09-18 23:08:29 +00:00
{
const SwTxtNode& rTNd = *GetTxtNode();
sal_Int32 nPos = pIdx->GetIndex();
if( g_pBreakIt->GetBreakIter().is() )
2000-09-18 23:08:29 +00:00
{
sal_Int32 nDone = 0;
sal_uInt16 nItrMode = ( CRSR_SKIP_CELLS & nMode ) ?
CharacterIteratorMode::SKIPCELL :
CharacterIteratorMode::SKIPCONTROLCHARACTER;
nPos = g_pBreakIt->GetBreakIter()->nextCharacters( rTNd.GetTxt(), nPos,
g_pBreakIt->GetLocale( rTNd.GetLang( nPos ) ),
nItrMode, 1, nDone );
// Check if nPos is inside hidden text range:
if ( CRSR_SKIP_HIDDEN & nMode )
{
sal_Int32 nHiddenStart;
sal_Int32 nHiddenEnd;
SwScriptInfo::GetBoundsOfHiddenRange( rTNd, nPos, nHiddenStart, nHiddenEnd );
if ( nHiddenStart != COMPLETE_STRING && nHiddenStart != nPos )
nPos = nHiddenEnd;
}
if( 1 == nDone )
*pIdx = nPos;
else
bRet = sal_False;
2000-09-18 23:08:29 +00:00
}
else if (nPos < rTNd.GetTxt().getLength())
++(*pIdx);
else
bRet = sal_False;
2000-09-18 23:08:29 +00:00
}
}
else
bRet = sal_False;
return bRet;
2000-09-18 23:08:29 +00:00
}
sal_Bool SwCntntNode::GoPrevious(SwIndex * pIdx, sal_uInt16 nMode ) const
2000-09-18 23:08:29 +00:00
{
sal_Bool bRet = sal_True;
2000-09-18 23:08:29 +00:00
if( pIdx->GetIndex() > 0 )
{
if( !IsTxtNode() )
(*pIdx)--;
else
2000-09-18 23:08:29 +00:00
{
const SwTxtNode& rTNd = *GetTxtNode();
sal_Int32 nPos = pIdx->GetIndex();
if( g_pBreakIt->GetBreakIter().is() )
2000-09-18 23:08:29 +00:00
{
sal_Int32 nDone = 0;
sal_uInt16 nItrMode = ( CRSR_SKIP_CELLS & nMode ) ?
CharacterIteratorMode::SKIPCELL :
CharacterIteratorMode::SKIPCONTROLCHARACTER;
nPos = g_pBreakIt->GetBreakIter()->previousCharacters( rTNd.GetTxt(), nPos,
g_pBreakIt->GetLocale( rTNd.GetLang( nPos ) ),
nItrMode, 1, nDone );
// Check if nPos is inside hidden text range:
if ( CRSR_SKIP_HIDDEN & nMode )
{
sal_Int32 nHiddenStart;
sal_Int32 nHiddenEnd;
SwScriptInfo::GetBoundsOfHiddenRange( rTNd, nPos, nHiddenStart, nHiddenEnd );
if ( nHiddenStart != COMPLETE_STRING )
nPos = nHiddenStart;
}
if( 1 == nDone )
*pIdx = nPos;
else
bRet = sal_False;
2000-09-18 23:08:29 +00:00
}
else if( nPos )
(*pIdx)--;
else
bRet = sal_False;
2000-09-18 23:08:29 +00:00
}
}
else
bRet = sal_False;
return bRet;
2000-09-18 23:08:29 +00:00
}
/**
* Creates all Views for the Doc for this Node.
* The created ContentFrames are attached to the corresponding Layout.
2000-09-18 23:08:29 +00:00
*/
void SwCntntNode::MakeFrms( SwCntntNode& rNode )
{
OSL_ENSURE( &rNode != this,
"No ContentNode or CopyNode and new Node identical." );
2000-09-18 23:08:29 +00:00
if( !GetDepends() || &rNode == this ) // Do we actually have Frames?
2000-09-18 23:08:29 +00:00
return;
SwFrm *pFrm, *pNew;
SwLayoutFrm *pUpper;
// Create Frames for Nodes which come after the Table?
OSL_ENSURE( FindTableNode() == rNode.FindTableNode(), "Table confusion" );
2000-09-18 23:08:29 +00:00
SwNode2Layout aNode2Layout( *this, rNode.GetIndex() );
while( 0 != (pUpper = aNode2Layout.UpperFrm( pFrm, rNode )) )
{
pNew = rNode.MakeFrm( pUpper );
2000-09-18 23:08:29 +00:00
pNew->Paste( pUpper, pFrm );
2011-02-02 20:41:40 +09:00
// #i27138#
// notify accessibility paragraphs objects about changed
// CONTENT_FLOWS_FROM/_TO relation.
// Relation CONTENT_FLOWS_FROM for next paragraph will change
// and relation CONTENT_FLOWS_TO for previous paragraph will change.
if ( pNew->IsTxtFrm() )
{
SwViewShell* pViewShell( pNew->getRootFrm()->GetCurrShell() );
if ( pViewShell && pViewShell->GetLayout() &&
pViewShell->GetLayout()->IsAnyShellAccessible() )
{
pViewShell->InvalidateAccessibleParaFlowRelation(
dynamic_cast<SwTxtFrm*>(pNew->FindNextCnt( true )),
dynamic_cast<SwTxtFrm*>(pNew->FindPrevCnt( true )) );
}
}
2000-09-18 23:08:29 +00:00
}
}
/**
* Deletes all Views from the Doc for this Node.
* The ContentFrames are removed from the corresponding Layout.
*
* An input param to identify if the acc table should be disposed. and a
* flag(bNeedDel) to indicate whether to del corresponding frm even in doc
* loading process,
2000-09-18 23:08:29 +00:00
*/
void SwCntntNode::DelFrms( sal_Bool /*bNeedDel*/, sal_Bool bIsDisposeAccTable )
2000-09-18 23:08:29 +00:00
{
if( !GetDepends() )
return;
SwIterator<SwCntntFrm,SwCntntNode> aIter( *this );
for( SwCntntFrm* pFrm = aIter.First(); pFrm; pFrm = aIter.Next() )
{
// #i27138#
// notify accessibility paragraphs objects about changed
// CONTENT_FLOWS_FROM/_TO relation.
// Relation CONTENT_FLOWS_FROM for current next paragraph will change
// and relation CONTENT_FLOWS_TO for current previous paragraph will change.
if ( pFrm->IsTxtFrm() )
{
SwViewShell* pViewShell( pFrm->getRootFrm()->GetCurrShell() );
if ( pViewShell && pViewShell->GetLayout() &&
pViewShell->GetLayout()->IsAnyShellAccessible() )
{
pViewShell->InvalidateAccessibleParaFlowRelation(
dynamic_cast<SwTxtFrm*>(pFrm->FindNextCnt( true )),
dynamic_cast<SwTxtFrm*>(pFrm->FindPrevCnt( true )) );
}
}
if( pFrm->IsFollow() )
{
SwCntntFrm* pMaster = (SwTxtFrm*)pFrm->FindMaster();
pMaster->SetFollow( pFrm->GetFollow() );
}
pFrm->SetFollow( 0 );//So it doesn't get funny ideas.
//Otherwise it could be possible that a follow
//gets destroyed before its master. Following
//the now invalid pointer will then lead to an
//illegal memory access. The chain can be
//crushed here because we'll destroy all of it
//anyway.
if( pFrm->GetUpper() && pFrm->IsInFtn() && !pFrm->GetIndNext() &&
!pFrm->GetIndPrev() )
{
SwFtnFrm *pFtn = pFrm->FindFtnFrm();
OSL_ENSURE( pFtn, "You promised a FtnFrm?" );
SwCntntFrm* pCFrm;
if( !pFtn->GetFollow() && !pFtn->GetMaster() &&
0 != ( pCFrm = pFtn->GetRefFromAttr()) && pCFrm->IsFollow() )
{
OSL_ENSURE( pCFrm->IsTxtFrm(), "NoTxtFrm has Footnote?" );
((SwTxtFrm*)pCFrm->FindMaster())->Prepare( PREP_FTN_GONE );
}
}
//Set acc table dispose state
pFrm->SetAccTableDispose( bIsDisposeAccTable );
pFrm->Cut();
//Set acc table dispose state to default value
pFrm->SetAccTableDispose( true );
delete pFrm;
}
2000-09-18 23:08:29 +00:00
if( IsTxtNode() )
{
((SwTxtNode*)this)->SetWrong( NULL );
((SwTxtNode*)this)->SetWrongDirty( true );
((SwTxtNode*)this)->SetGrammarCheck( NULL );
((SwTxtNode*)this)->SetGrammarCheckDirty( true );
// SMARTTAGS
((SwTxtNode*)this)->SetSmartTags( NULL );
((SwTxtNode*)this)->SetSmartTagDirty( true );
((SwTxtNode*)this)->SetWordCountDirty( true );
((SwTxtNode*)this)->SetAutoCompleteWordDirty( true );
2000-09-18 23:08:29 +00:00
}
}
SwCntntNode *SwCntntNode::JoinNext()
{
return this;
}
SwCntntNode *SwCntntNode::JoinPrev()
{
return this;
}
/// Get info from Modify
bool SwCntntNode::GetInfo( SfxPoolItem& rInfo ) const
2000-09-18 23:08:29 +00:00
{
switch( rInfo.Which() )
{
case RES_AUTOFMT_DOCNODE:
if( &GetNodes() == ((SwAutoFmtGetDocNode&)rInfo).pNodes )
{
((SwAutoFmtGetDocNode&)rInfo).pCntntNode = this;
return false;
2000-09-18 23:08:29 +00:00
}
break;
case RES_FINDNEARESTNODE:
if( ((SwFmtPageDesc&)GetAttr( RES_PAGEDESC )).GetPageDesc() )
((SwFindNearestNode&)rInfo).CheckNode( *this );
return true;
2000-09-18 23:08:29 +00:00
case RES_CONTENT_VISIBLE:
{
((SwPtrMsgPoolItem&)rInfo).pObject =
SwIterator<SwFrm,SwCntntNode>::FirstElement(*this);
2000-09-18 23:08:29 +00:00
}
return false;
2000-09-18 23:08:29 +00:00
}
return SwModify::GetInfo( rInfo );
}
/// @param rAttr the attribute to set
sal_Bool SwCntntNode::SetAttr(const SfxPoolItem& rAttr )
2000-09-18 23:08:29 +00:00
{
if( !GetpSwAttrSet() ) // Have the Nodes created by the corresponding AttrSets
NewAttrSet( GetDoc()->GetAttrPool() );
2000-09-18 23:08:29 +00:00
OSL_ENSURE( GetpSwAttrSet(), "Why did't we create an AttrSet?");
2000-09-18 23:08:29 +00:00
if ( IsInCache() )
{
SwFrm::GetCache().Delete( this );
SetInCache( sal_False );
2000-09-18 23:08:29 +00:00
}
sal_Bool bRet = sal_False;
// If Modify is locked, we do not send any Modifys
if( IsModifyLocked() ||
( !GetDepends() && RES_PARATR_NUMRULE != rAttr.Which() ))
2000-09-18 23:08:29 +00:00
{
bRet = 0 != AttrSetHandleHelper::Put( mpAttrSet, *this, rAttr );
2000-09-18 23:08:29 +00:00
}
else
{
SwAttrSet aOld( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() ),
aNew( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() );
if( 0 != ( bRet = AttrSetHandleHelper::Put_BC( mpAttrSet, *this, rAttr, &aOld, &aNew ) ))
2000-09-18 23:08:29 +00:00
{
SwAttrSetChg aChgOld( *GetpSwAttrSet(), aOld );
SwAttrSetChg aChgNew( *GetpSwAttrSet(), aNew );
ModifyNotification( &aChgOld, &aChgNew ); // Send all changed ones
2000-09-18 23:08:29 +00:00
}
}
return bRet;
}
#include <svl/itemiter.hxx>
2000-09-18 23:08:29 +00:00
sal_Bool SwCntntNode::SetAttr( const SfxItemSet& rSet )
2000-09-18 23:08:29 +00:00
{
if ( IsInCache() )
{
SwFrm::GetCache().Delete( this );
SetInCache( sal_False );
2000-09-18 23:08:29 +00:00
}
const SfxPoolItem* pFnd = 0;
if( SFX_ITEM_SET == rSet.GetItemState( RES_AUTO_STYLE, sal_False, &pFnd ) )
{
OSL_ENSURE( rSet.Count() == 1, "SetAutoStyle mixed with other attributes?!" );
const SwFmtAutoFmt* pTmp = static_cast<const SwFmtAutoFmt*>(pFnd);
// If there already is an attribute set (usually containing a numbering
// item), we have to merge the attribute of the new set into the old set:
bool bSetParent = true;
if ( GetpSwAttrSet() )
{
bSetParent = false;
AttrSetHandleHelper::Put( mpAttrSet, *this, *pTmp->GetStyleHandle() );
}
else
{
mpAttrSet = pTmp->GetStyleHandle();
}
2000-09-18 23:08:29 +00:00
if ( bSetParent )
{
// If the content node has a conditional style, we have to set the
// string item containing the correct conditional style name (the
// style name property has already been set during the import!)
// In case we do not have a conditional style, we make use of the
// fact that nobody else uses the attribute set behind the handle.
// FME 2007-07-10 #i78124# If autostyle does not have a parent,
// the string is empty.
const SfxPoolItem* pNameItem = 0;
if ( 0 != GetCondFmtColl() ||
SFX_ITEM_SET != mpAttrSet->GetItemState( RES_FRMATR_STYLE_NAME, sal_False, &pNameItem ) ||
static_cast<const SfxStringItem*>(pNameItem)->GetValue().isEmpty() )
AttrSetHandleHelper::SetParent( mpAttrSet, *this, &GetAnyFmtColl(), GetFmtColl() );
else
const_cast<SfxItemSet*>(mpAttrSet.get())->SetParent( &GetFmtColl()->GetAttrSet() );
}
return sal_True;
}
if( !GetpSwAttrSet() ) // Have the AttrsSets created by the corresponding Nodes
NewAttrSet( GetDoc()->GetAttrPool() );
sal_Bool bRet = sal_False;
// If Modify is locked, do not send any Modifys
if ( IsModifyLocked() ||
( !GetDepends() &&
SFX_ITEM_SET != rSet.GetItemState( RES_PARATR_NUMRULE, sal_False ) ) )
2000-09-18 23:08:29 +00:00
{
// Some special treatment for Attributes
bRet = AttrSetHandleHelper::Put( mpAttrSet, *this, rSet );
2000-09-18 23:08:29 +00:00
}
else
{
SwAttrSet aOld( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() ),
aNew( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() );
if( 0 != (bRet = AttrSetHandleHelper::Put_BC( mpAttrSet, *this, rSet, &aOld, &aNew )) )
2000-09-18 23:08:29 +00:00
{
// Some special treatment for Attributes
SwAttrSetChg aChgOld( *GetpSwAttrSet(), aOld );
SwAttrSetChg aChgNew( *GetpSwAttrSet(), aNew );
ModifyNotification( &aChgOld, &aChgNew ); // Send out all changed ones
2000-09-18 23:08:29 +00:00
}
}
return bRet;
}
// With nWhich it takes the Hint from the Delta array
sal_Bool SwCntntNode::ResetAttr( sal_uInt16 nWhich1, sal_uInt16 nWhich2 )
2000-09-18 23:08:29 +00:00
{
if( !GetpSwAttrSet() )
return sal_False;
2000-09-18 23:08:29 +00:00
if ( IsInCache() )
{
SwFrm::GetCache().Delete( this );
SetInCache( sal_False );
2000-09-18 23:08:29 +00:00
}
// If Modify is locked, do not send out any Modifys
2000-09-18 23:08:29 +00:00
if( IsModifyLocked() )
{
sal_uInt16 nDel = 0;
if ( !nWhich2 || nWhich2 < nWhich1 )
{
std::vector<sal_uInt16> aClearWhichIds;
aClearWhichIds.push_back( nWhich1 );
nDel = ClearItemsFromAttrSet( aClearWhichIds );
}
else
nDel = AttrSetHandleHelper::ClearItem_BC( mpAttrSet, *this, nWhich1, nWhich2, 0, 0 );
2000-09-18 23:08:29 +00:00
if( !GetpSwAttrSet()->Count() ) // Empt? Delete
mpAttrSet.reset();
2000-09-18 23:08:29 +00:00
return 0 != nDel;
}
// No valid area defined?
2000-09-18 23:08:29 +00:00
if( !nWhich2 || nWhich2 < nWhich1 )
nWhich2 = nWhich1; // Then set only this Item to 1st Id
2000-09-18 23:08:29 +00:00
SwAttrSet aOld( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() ),
aNew( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() );
sal_Bool bRet = 0 != AttrSetHandleHelper::ClearItem_BC( mpAttrSet, *this, nWhich1, nWhich2, &aOld, &aNew );
2000-09-18 23:08:29 +00:00
if( bRet )
{
SwAttrSetChg aChgOld( *GetpSwAttrSet(), aOld );
SwAttrSetChg aChgNew( *GetpSwAttrSet(), aNew );
ModifyNotification( &aChgOld, &aChgNew ); // All changed ones are sent
2000-09-18 23:08:29 +00:00
if( !GetpSwAttrSet()->Count() ) // Empty?, delete it
mpAttrSet.reset();
2000-09-18 23:08:29 +00:00
}
return bRet;
}
sal_Bool SwCntntNode::ResetAttr( const std::vector<sal_uInt16>& rWhichArr )
2000-09-18 23:08:29 +00:00
{
if( !GetpSwAttrSet() )
return sal_False;
2000-09-18 23:08:29 +00:00
if ( IsInCache() )
{
SwFrm::GetCache().Delete( this );
SetInCache( sal_False );
2000-09-18 23:08:29 +00:00
}
// If Modify is locked, do not send out any Modifys
sal_uInt16 nDel = 0;
2000-09-18 23:08:29 +00:00
if( IsModifyLocked() )
{
std::vector<sal_uInt16> aClearWhichIds(rWhichArr);
nDel = ClearItemsFromAttrSet( aClearWhichIds );
2000-09-18 23:08:29 +00:00
}
else
{
SwAttrSet aOld( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() ),
aNew( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() );
2000-09-18 23:08:29 +00:00
std::vector<sal_uInt16>::const_iterator it;
for ( it = rWhichArr.begin(); it != rWhichArr.end(); ++it )
if( AttrSetHandleHelper::ClearItem_BC( mpAttrSet, *this, *it, &aOld, &aNew ))
2000-09-18 23:08:29 +00:00
++nDel;
if( nDel )
{
SwAttrSetChg aChgOld( *GetpSwAttrSet(), aOld );
SwAttrSetChg aChgNew( *GetpSwAttrSet(), aNew );
ModifyNotification( &aChgOld, &aChgNew ); // All changed ones are sent
2000-09-18 23:08:29 +00:00
}
}
if( !GetpSwAttrSet()->Count() ) // Empty?, delete it
mpAttrSet.reset();
2000-09-18 23:08:29 +00:00
return 0 != nDel ;
}
sal_uInt16 SwCntntNode::ResetAllAttr()
2000-09-18 23:08:29 +00:00
{
if( !GetpSwAttrSet() )
2000-09-18 23:08:29 +00:00
return 0;
if ( IsInCache() )
{
SwFrm::GetCache().Delete( this );
SetInCache( sal_False );
2000-09-18 23:08:29 +00:00
}
// If Modify is locked, do not send out any Modifys
2000-09-18 23:08:29 +00:00
if( IsModifyLocked() )
{
std::vector<sal_uInt16> aClearWhichIds;
aClearWhichIds.push_back(0);
sal_uInt16 nDel = ClearItemsFromAttrSet( aClearWhichIds );
if( !GetpSwAttrSet()->Count() ) // Empty? Delete
mpAttrSet.reset();
2000-09-18 23:08:29 +00:00
return nDel;
}
SwAttrSet aOld( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() ),
aNew( *GetpSwAttrSet()->GetPool(), GetpSwAttrSet()->GetRanges() );
sal_Bool bRet = 0 != AttrSetHandleHelper::ClearItem_BC( mpAttrSet, *this, 0, &aOld, &aNew );
2000-09-18 23:08:29 +00:00
if( bRet )
{
SwAttrSetChg aChgOld( *GetpSwAttrSet(), aOld );
SwAttrSetChg aChgNew( *GetpSwAttrSet(), aNew );
ModifyNotification( &aChgOld, &aChgNew ); // All changed ones are sent
2000-09-18 23:08:29 +00:00
if( !GetpSwAttrSet()->Count() ) // Empty? Delete
mpAttrSet.reset();
2000-09-18 23:08:29 +00:00
}
return aNew.Count();
}
sal_Bool SwCntntNode::GetAttr( SfxItemSet& rSet, sal_Bool bInParent ) const
2000-09-18 23:08:29 +00:00
{
if( rSet.Count() )
rSet.ClearItem();
const SwAttrSet& rAttrSet = GetSwAttrSet();
if( bInParent )
return rSet.Set( rAttrSet, sal_True ) ? sal_True : sal_False;
2000-09-18 23:08:29 +00:00
rSet.Put( rAttrSet );
return rSet.Count() ? sal_True : sal_False;
2000-09-18 23:08:29 +00:00
}
sal_uInt16 SwCntntNode::ClearItemsFromAttrSet( const std::vector<sal_uInt16>& rWhichIds )
{
sal_uInt16 nRet = 0;
if ( 0 == rWhichIds.size() )
return nRet;
OSL_ENSURE( GetpSwAttrSet(), "no item set" );
SwAttrSet aNewAttrSet( *GetpSwAttrSet() );
for ( std::vector<sal_uInt16>::const_iterator aIter = rWhichIds.begin();
aIter != rWhichIds.end();
++aIter )
{
nRet = nRet + aNewAttrSet.ClearItem( *aIter );
}
if ( nRet )
AttrSetHandleHelper::GetNewAutoStyle( mpAttrSet, *this, aNewAttrSet );
return nRet;
}
const SfxPoolItem* SwCntntNode::GetNoCondAttr( sal_uInt16 nWhich,
sal_Bool bInParents ) const
2000-09-18 23:08:29 +00:00
{
const SfxPoolItem* pFnd = 0;
if( pCondColl && pCondColl->GetRegisteredIn() )
{
if( !GetpSwAttrSet() || ( SFX_ITEM_SET != GetpSwAttrSet()->GetItemState(
nWhich, sal_False, &pFnd ) && bInParents ))
2000-09-18 23:08:29 +00:00
((SwFmt*)GetRegisteredIn())->GetItemState( nWhich, bInParents, &pFnd );
}
2011-02-02 20:41:40 +09:00
// undo change of issue #i51029#
// Note: <GetSwAttrSet()> returns <mpAttrSet>, if set, otherwise it returns
// the attribute set of the paragraph style, which is valid for the
// content node - see file <node.hxx>
else
{
2000-09-18 23:08:29 +00:00
GetSwAttrSet().GetItemState( nWhich, bInParents, &pFnd );
}
2000-09-18 23:08:29 +00:00
return pFnd;
}
static bool lcl_CheckMaxLength(SwNode const& rPrev, SwNode const& rNext)
{
if (rPrev.GetNodeType() != rNext.GetNodeType())
{
return false;
}
if (!rPrev.IsTxtNode())
{
return true;
}
// Check if a node can contain the other (order is not significant)
return static_cast<const SwTxtNode&>(rPrev).GetSpaceLeft() >
static_cast<const SwTxtNode&>(rNext).Len();
}
/// Can we join two Nodes?
/// We can return the 2nd position in pIdx.
bool SwCntntNode::CanJoinNext( SwNodeIndex* pIdx ) const
2000-09-18 23:08:29 +00:00
{
const SwNodes& rNds = GetNodes();
SwNodeIndex aIdx( *this, 1 );
const SwNode* pNd = this;
while( aIdx < rNds.Count()-1 &&
(( pNd = &aIdx.GetNode())->IsSectionNode() ||
INTEGRATION: CWS writercorehandoff (1.22.48); FILE MERGED 2006/07/27 14:39:25 fme 1.22.48.18: RESYNC: (1.26-1.27); FILE MERGED 2006/05/09 10:37:57 fme 1.22.48.17: #i50348# make SwDoc accessible via interfaces 2006/05/08 11:21:11 fme 1.22.48.16: #i50348# Make SwDoc accessible via interfaces 2006/03/17 08:03:39 tra 1.22.48.15: RESYNC: (1.25-1.26); FILE MERGED 2006/01/19 08:50:04 fme 1.22.48.14: #i50348# General cleanup - removed unused header files, functions, members, declarations 2005/12/20 15:09:39 tra 1.22.48.13: RESYNC: (1.24-1.25); FILE MERGED 2005/11/18 14:53:21 fme 1.22.48.12: #i50348# Make SwDoc accessible via interfaces 2005/11/11 07:56:07 fme 1.22.48.11: #i50348# make SwDoc accessible via interfaces 2005/09/13 13:27:52 tra 1.22.48.10: RESYNC: (1.23-1.24); FILE MERGED 2005/07/28 11:55:30 tra 1.22.48.9: RESYNC: (1.22-1.23); FILE MERGED 2005/07/19 06:05:46 fme 1.22.48.8: #i50348# make SwDoc accessible via interfaces 2005/07/13 13:24:19 fme 1.22.48.7: #i50348# Make SwDoc accessible via interfaces 2005/07/05 08:12:39 tra 1.22.48.6: #i50348#make SwDoc interface based 2005/06/24 11:43:17 fme 1.22.48.5: #i50348# Make SwDoc accessible via interfaces 2005/06/22 13:08:12 tra 1.22.48.4: #i50348#toward a interface based SwDoc 2005/06/22 06:40:10 tra 1.22.48.3: #i50348# make SwDoc accessible via interfaces 2005/06/07 14:13:38 fme 1.22.48.2: #i50348# General cleanup - removed unused header files, functions, members, declarations etc. 2005/06/06 09:27:18 tra 1.22.48.1: Unnecessary includes removed #i50348#
2006-08-14 15:05:06 +00:00
( pNd->IsEndNode() && pNd->StartOfSectionNode()->IsSectionNode() )))
++aIdx;
2000-09-18 23:08:29 +00:00
if (rNds.Count()-1 == aIdx.GetIndex())
return false;
if (!lcl_CheckMaxLength(*this, *pNd))
{
return false;
}
2000-09-18 23:08:29 +00:00
if( pIdx )
*pIdx = aIdx;
return true;
2000-09-18 23:08:29 +00:00
}
/// Can we join two Nodes?
/// We can return the 2nd position in pIdx.
bool SwCntntNode::CanJoinPrev( SwNodeIndex* pIdx ) const
2000-09-18 23:08:29 +00:00
{
SwNodeIndex aIdx( *this, -1 );
const SwNode* pNd = this;
while( aIdx.GetIndex() &&
(( pNd = &aIdx.GetNode())->IsSectionNode() ||
INTEGRATION: CWS writercorehandoff (1.22.48); FILE MERGED 2006/07/27 14:39:25 fme 1.22.48.18: RESYNC: (1.26-1.27); FILE MERGED 2006/05/09 10:37:57 fme 1.22.48.17: #i50348# make SwDoc accessible via interfaces 2006/05/08 11:21:11 fme 1.22.48.16: #i50348# Make SwDoc accessible via interfaces 2006/03/17 08:03:39 tra 1.22.48.15: RESYNC: (1.25-1.26); FILE MERGED 2006/01/19 08:50:04 fme 1.22.48.14: #i50348# General cleanup - removed unused header files, functions, members, declarations 2005/12/20 15:09:39 tra 1.22.48.13: RESYNC: (1.24-1.25); FILE MERGED 2005/11/18 14:53:21 fme 1.22.48.12: #i50348# Make SwDoc accessible via interfaces 2005/11/11 07:56:07 fme 1.22.48.11: #i50348# make SwDoc accessible via interfaces 2005/09/13 13:27:52 tra 1.22.48.10: RESYNC: (1.23-1.24); FILE MERGED 2005/07/28 11:55:30 tra 1.22.48.9: RESYNC: (1.22-1.23); FILE MERGED 2005/07/19 06:05:46 fme 1.22.48.8: #i50348# make SwDoc accessible via interfaces 2005/07/13 13:24:19 fme 1.22.48.7: #i50348# Make SwDoc accessible via interfaces 2005/07/05 08:12:39 tra 1.22.48.6: #i50348#make SwDoc interface based 2005/06/24 11:43:17 fme 1.22.48.5: #i50348# Make SwDoc accessible via interfaces 2005/06/22 13:08:12 tra 1.22.48.4: #i50348#toward a interface based SwDoc 2005/06/22 06:40:10 tra 1.22.48.3: #i50348# make SwDoc accessible via interfaces 2005/06/07 14:13:38 fme 1.22.48.2: #i50348# General cleanup - removed unused header files, functions, members, declarations etc. 2005/06/06 09:27:18 tra 1.22.48.1: Unnecessary includes removed #i50348#
2006-08-14 15:05:06 +00:00
( pNd->IsEndNode() && pNd->StartOfSectionNode()->IsSectionNode() )))
2000-09-18 23:08:29 +00:00
aIdx--;
if (0 == aIdx.GetIndex())
return false;
if (!lcl_CheckMaxLength(*pNd, *this))
{
return false;
}
2000-09-18 23:08:29 +00:00
if( pIdx )
*pIdx = aIdx;
return true;
2000-09-18 23:08:29 +00:00
}
//FEATURE::CONDCOLL
void SwCntntNode::SetCondFmtColl( SwFmtColl* pColl )
{
if( (!pColl && pCondColl) || ( pColl && !pCondColl ) ||
( pColl && pColl != pCondColl->GetRegisteredIn() ) )
{
SwFmtColl* pOldColl = GetCondFmtColl();
delete pCondColl;
if( pColl )
pCondColl = new SwDepend( this, pColl );
else
pCondColl = 0;
if( GetpSwAttrSet() )
2000-09-18 23:08:29 +00:00
{
AttrSetHandleHelper::SetParent( mpAttrSet, *this, &GetAnyFmtColl(), GetFmtColl() );
2000-09-18 23:08:29 +00:00
}
if( !IsModifyLocked() )
{
SwFmtChg aTmp1( pOldColl ? pOldColl : GetFmtColl() );
SwFmtChg aTmp2( pColl ? pColl : GetFmtColl() );
NotifyClients( &aTmp1, &aTmp2 );
2000-09-18 23:08:29 +00:00
}
if( IsInCache() )
{
SwFrm::GetCache().Delete( this );
SetInCache( sal_False );
2000-09-18 23:08:29 +00:00
}
}
}
sal_Bool SwCntntNode::IsAnyCondition( SwCollCondition& rTmp ) const
2000-09-18 23:08:29 +00:00
{
const SwNodes& rNds = GetNodes();
{
int nCond = 0;
INTEGRATION: CWS writercorehandoff (1.22.48); FILE MERGED 2006/07/27 14:39:25 fme 1.22.48.18: RESYNC: (1.26-1.27); FILE MERGED 2006/05/09 10:37:57 fme 1.22.48.17: #i50348# make SwDoc accessible via interfaces 2006/05/08 11:21:11 fme 1.22.48.16: #i50348# Make SwDoc accessible via interfaces 2006/03/17 08:03:39 tra 1.22.48.15: RESYNC: (1.25-1.26); FILE MERGED 2006/01/19 08:50:04 fme 1.22.48.14: #i50348# General cleanup - removed unused header files, functions, members, declarations 2005/12/20 15:09:39 tra 1.22.48.13: RESYNC: (1.24-1.25); FILE MERGED 2005/11/18 14:53:21 fme 1.22.48.12: #i50348# Make SwDoc accessible via interfaces 2005/11/11 07:56:07 fme 1.22.48.11: #i50348# make SwDoc accessible via interfaces 2005/09/13 13:27:52 tra 1.22.48.10: RESYNC: (1.23-1.24); FILE MERGED 2005/07/28 11:55:30 tra 1.22.48.9: RESYNC: (1.22-1.23); FILE MERGED 2005/07/19 06:05:46 fme 1.22.48.8: #i50348# make SwDoc accessible via interfaces 2005/07/13 13:24:19 fme 1.22.48.7: #i50348# Make SwDoc accessible via interfaces 2005/07/05 08:12:39 tra 1.22.48.6: #i50348#make SwDoc interface based 2005/06/24 11:43:17 fme 1.22.48.5: #i50348# Make SwDoc accessible via interfaces 2005/06/22 13:08:12 tra 1.22.48.4: #i50348#toward a interface based SwDoc 2005/06/22 06:40:10 tra 1.22.48.3: #i50348# make SwDoc accessible via interfaces 2005/06/07 14:13:38 fme 1.22.48.2: #i50348# General cleanup - removed unused header files, functions, members, declarations etc. 2005/06/06 09:27:18 tra 1.22.48.1: Unnecessary includes removed #i50348#
2006-08-14 15:05:06 +00:00
const SwStartNode* pSttNd = StartOfSectionNode();
2000-09-18 23:08:29 +00:00
while( pSttNd )
{
switch( pSttNd->GetNodeType() )
{
case ND_TABLENODE: nCond = PARA_IN_TABLEBODY; break;
case ND_SECTIONNODE: nCond = PARA_IN_SECTION; break;
default:
switch( pSttNd->GetStartNodeType() )
{
case SwTableBoxStartNode:
{
nCond = PARA_IN_TABLEBODY;
const SwTableNode* pTblNd = pSttNd->FindTableNode();
const SwTableBox* pBox;
if( pTblNd && 0 != ( pBox = pTblNd->GetTable().
GetTblBox( pSttNd->GetIndex() ) ) && pBox &&
2000-09-18 23:08:29 +00:00
pBox->IsInHeadline( &pTblNd->GetTable() ) )
nCond = PARA_IN_TABLEHEAD;
}
break;
case SwFlyStartNode: nCond = PARA_IN_FRAME; break;
case SwFootnoteStartNode:
{
nCond = PARA_IN_FOOTENOTE;
const SwFtnIdxs& rFtnArr = rNds.GetDoc()->GetFtnIdxs();
const SwTxtFtn* pTxtFtn;
const SwNode* pSrchNd = pSttNd;
for( sal_uInt16 n = 0; n < rFtnArr.size(); ++n )
2000-09-18 23:08:29 +00:00
if( 0 != ( pTxtFtn = rFtnArr[ n ])->GetStartNode() &&
pSrchNd == &pTxtFtn->GetStartNode()->GetNode() )
{
if( pTxtFtn->GetFtn().IsEndNote() )
nCond = PARA_IN_ENDNOTE;
break;
}
}
break;
case SwHeaderStartNode: nCond = PARA_IN_HEADER; break;
case SwFooterStartNode: nCond = PARA_IN_FOOTER; break;
case SwNormalStartNode: break;
2000-09-18 23:08:29 +00:00
}
}
if( nCond )
{
rTmp.SetCondition( (Master_CollConditions)nCond, 0 );
return sal_True;
2000-09-18 23:08:29 +00:00
}
pSttNd = pSttNd->GetIndex()
INTEGRATION: CWS writercorehandoff (1.22.48); FILE MERGED 2006/07/27 14:39:25 fme 1.22.48.18: RESYNC: (1.26-1.27); FILE MERGED 2006/05/09 10:37:57 fme 1.22.48.17: #i50348# make SwDoc accessible via interfaces 2006/05/08 11:21:11 fme 1.22.48.16: #i50348# Make SwDoc accessible via interfaces 2006/03/17 08:03:39 tra 1.22.48.15: RESYNC: (1.25-1.26); FILE MERGED 2006/01/19 08:50:04 fme 1.22.48.14: #i50348# General cleanup - removed unused header files, functions, members, declarations 2005/12/20 15:09:39 tra 1.22.48.13: RESYNC: (1.24-1.25); FILE MERGED 2005/11/18 14:53:21 fme 1.22.48.12: #i50348# Make SwDoc accessible via interfaces 2005/11/11 07:56:07 fme 1.22.48.11: #i50348# make SwDoc accessible via interfaces 2005/09/13 13:27:52 tra 1.22.48.10: RESYNC: (1.23-1.24); FILE MERGED 2005/07/28 11:55:30 tra 1.22.48.9: RESYNC: (1.22-1.23); FILE MERGED 2005/07/19 06:05:46 fme 1.22.48.8: #i50348# make SwDoc accessible via interfaces 2005/07/13 13:24:19 fme 1.22.48.7: #i50348# Make SwDoc accessible via interfaces 2005/07/05 08:12:39 tra 1.22.48.6: #i50348#make SwDoc interface based 2005/06/24 11:43:17 fme 1.22.48.5: #i50348# Make SwDoc accessible via interfaces 2005/06/22 13:08:12 tra 1.22.48.4: #i50348#toward a interface based SwDoc 2005/06/22 06:40:10 tra 1.22.48.3: #i50348# make SwDoc accessible via interfaces 2005/06/07 14:13:38 fme 1.22.48.2: #i50348# General cleanup - removed unused header files, functions, members, declarations etc. 2005/06/06 09:27:18 tra 1.22.48.1: Unnecessary includes removed #i50348#
2006-08-14 15:05:06 +00:00
? pSttNd->StartOfSectionNode()
2000-09-18 23:08:29 +00:00
: 0;
}
}
{
sal_uInt16 nPos;
2000-09-18 23:08:29 +00:00
const SwOutlineNodes& rOutlNds = rNds.GetOutLineNds();
if( !rOutlNds.empty() )
2000-09-18 23:08:29 +00:00
{
if( !rOutlNds.Seek_Entry( (SwCntntNode*)this, &nPos ) && nPos )
--nPos;
if( nPos < rOutlNds.size() &&
2000-09-18 23:08:29 +00:00
rOutlNds[ nPos ]->GetIndex() < GetIndex() )
{
SwTxtNode* pOutlNd = rOutlNds[ nPos ]->GetTxtNode();
if( pOutlNd->IsOutline())
2000-09-18 23:08:29 +00:00
{
CWS-TOOLING: integrate CWS outlinelevel 2008-12-19 10:32:51 +0100 od r265718 : #i70748# method <SwWW8Writer::StartTOX(..)> - correction for custom to outline style assigned paragraph styles 2008-12-19 09:24:41 +0100 od r265715 : #i70748# method <HandleModifyAtTxtNode(..)> - retrieve former applied list style before potential reset of empty list style due to set outline level 2008-12-17 15:33:57 +0100 hde r265608 : #i97013# 2008-12-17 14:43:42 +0100 od r265603 : #i70748# adjust fix i44177 - adjustment of to outline style assigned paragraph styles only for OOo-Templates. 2008-12-17 12:59:42 +0100 od r265598 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - special handling of OOo 2.x document regarding outline numbering of headings. 2008-12-17 12:45:53 +0100 od r265597 : #i70748# method <HandleModifyAtTxtNode(..)> - correct determination of new and former applied list style 2008-12-17 10:18:41 +0100 od r265581 : #i97312# method <XMLTextNumRuleInfo::Set(..)> - check, if numbering rules instance contains any numbering rule. 2008-12-16 14:34:22 +0100 hde r265542 : #i97013 2008-12-16 14:20:24 +0100 od r265541 : #i70748# adjust documentation of "Which"-ID numbers 2008-12-16 14:19:49 +0100 od r265539 : #i70748# Adjust Attribute-Function-Mapping table due to new attribute 2008-12-16 14:06:24 +0100 od r265538 : #i70748# - Correct handling of to outline style assigned paragraph styles on reset of all paragraph style attributes - WW8 import: Consider refactoring of paragraph style's outline level attribute - NO_NUMBERING define no longer exsits. 2008-12-16 10:37:19 +0100 od r265530 : #i70478# Correction on moving outline paragraph up respectively down in its outline level: - Check also outline paragraph, which are not an outline via a to outline style assigned paragraph style, if action is applicable. 2008-12-16 09:10:13 +0100 hde r265523 : #i97277 2008-12-16 09:09:30 +0100 hde r265522 : #i97277 2008-12-16 09:07:40 +0100 hde r265521 : Added control and purged obsolete id's 2008-12-10 13:09:36 +0100 od r265174 : #i70748# correction of previous fix due to warning-free code 2008-12-10 13:03:30 +0100 od r265172 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - Due to performance issues avoid retrieving outline level value from paragraph's paragraph style for each paragraph. Instead retrieve current outline level value from paragraph, which is the inherited value from its paragraph style, and only when it is needed. 2008-12-09 16:50:36 +0100 ufi r265117 : help 2008-12-09 16:49:50 +0100 ufi r265116 : help 2008-12-09 15:45:05 +0100 od r265107 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - some minor rework and check access to paragraph styles 2008-12-09 15:42:04 +0100 od r265106 : #i70748# adjust name of local variable to avoid hiding of class variable 2008-12-09 15:40:51 +0100 od r265105 : #i70748# correct initialization order 2008-12-09 15:35:07 +0100 od r265101 : #i70748# remove duplicate entry in certain property map 2008-12-09 15:33:39 +0100 od r265100 : #i70748# add end of file token 2008-12-07 15:11:54 +0100 zhaojianwei r264952 : conflicts left not to be resolved when cws rebase 2008-12-04 14:52:21 +0100 zhaojianwei r264846 : CWS-TOOLING: rebase CWS outlinelevel to trunk@264325 (milestone: DEV300:m36) 2008-11-28 03:42:09 +0100 zhaojianwei r264525 : #i70748#: migrate CWS outlinelevel to SVN 2008-11-28 03:41:39 +0100 zhaojianwei r264524 : #i70748#: migrate CWS outlinelevel to SVN 2008-11-28 03:41:11 +0100 zhaojianwei r264523 : #i70748#: migrate CWS outlinelevel to SVN
2009-01-07 11:57:24 +00:00
rTmp.SetCondition( PARA_IN_OUTLINE, pOutlNd->GetAttrOutlineLevel() - 1 );
return sal_True;
2000-09-18 23:08:29 +00:00
}
}
}
}
return sal_False;
2000-09-18 23:08:29 +00:00
}
void SwCntntNode::ChkCondColl()
{
// Check, just to be sure
2000-09-18 23:08:29 +00:00
if( RES_CONDTXTFMTCOLL == GetFmtColl()->Which() )
{
SwCollCondition aTmp( 0, 0, 0 );
const SwCollCondition* pCColl;
bool bDone = false;
if( IsAnyCondition( aTmp ))
{
pCColl = static_cast<SwConditionTxtFmtColl*>(GetFmtColl())
->HasCondition( aTmp );
if (pCColl)
{
SetCondFmtColl( pCColl->GetTxtFmtColl() );
bDone = true;
}
}
if (!bDone)
2000-09-18 23:08:29 +00:00
{
if( IsTxtNode() && ((SwTxtNode*)this)->GetNumRule())
2000-09-18 23:08:29 +00:00
{
// Is at which Level in a list?
2000-09-18 23:08:29 +00:00
aTmp.SetCondition( PARA_IN_LIST,
((SwTxtNode*)this)->GetActualListLevel() );
2000-09-18 23:08:29 +00:00
pCColl = ((SwConditionTxtFmtColl*)GetFmtColl())->
HasCondition( aTmp );
}
else
pCColl = 0;
if( pCColl )
SetCondFmtColl( pCColl->GetTxtFmtColl() );
else if( pCondColl )
SetCondFmtColl( 0 );
}
}
}
2011-02-02 20:41:40 +09:00
// #i42921#
short SwCntntNode::GetTextDirection( const SwPosition& rPos,
const Point* pPt ) const
{
short nRet = -1;
Point aPt;
if( pPt )
aPt = *pPt;
2011-02-02 20:41:40 +09:00
// #i72024# - No format of the frame, because this can cause recursive layout actions
SwFrm* pFrm = getLayoutFrm( GetDoc()->GetCurrentLayout(), &aPt, &rPos, sal_False );
if ( pFrm )
{
if ( pFrm->IsVertical() )
{
if ( pFrm->IsRightToLeft() )
nRet = FRMDIR_VERT_TOP_LEFT;
else
nRet = FRMDIR_VERT_TOP_RIGHT;
}
else
{
if ( pFrm->IsRightToLeft() )
nRet = FRMDIR_HORI_RIGHT_TOP;
else
nRet = FRMDIR_HORI_LEFT_TOP;
}
}
return nRet;
}
SwOLENodes* SwCntntNode::CreateOLENodesArray( const SwFmtColl& rColl, bool bOnlyWithInvalidSize )
{
SwOLENodes *pNodes = 0;
SwIterator<SwCntntNode,SwFmtColl> aIter( rColl );
for( SwCntntNode* pNd = aIter.First(); pNd; pNd = aIter.Next() )
{
SwOLENode *pONd = pNd->GetOLENode();
if ( pONd && (!bOnlyWithInvalidSize || pONd->IsOLESizeInvalid()) )
{
if ( !pNodes )
pNodes = new SwOLENodes;
pNodes->push_back( pONd );
}
}
return pNodes;
}
INTEGRATION: CWS writercorehandoff (1.22.48); FILE MERGED 2006/07/27 14:39:25 fme 1.22.48.18: RESYNC: (1.26-1.27); FILE MERGED 2006/05/09 10:37:57 fme 1.22.48.17: #i50348# make SwDoc accessible via interfaces 2006/05/08 11:21:11 fme 1.22.48.16: #i50348# Make SwDoc accessible via interfaces 2006/03/17 08:03:39 tra 1.22.48.15: RESYNC: (1.25-1.26); FILE MERGED 2006/01/19 08:50:04 fme 1.22.48.14: #i50348# General cleanup - removed unused header files, functions, members, declarations 2005/12/20 15:09:39 tra 1.22.48.13: RESYNC: (1.24-1.25); FILE MERGED 2005/11/18 14:53:21 fme 1.22.48.12: #i50348# Make SwDoc accessible via interfaces 2005/11/11 07:56:07 fme 1.22.48.11: #i50348# make SwDoc accessible via interfaces 2005/09/13 13:27:52 tra 1.22.48.10: RESYNC: (1.23-1.24); FILE MERGED 2005/07/28 11:55:30 tra 1.22.48.9: RESYNC: (1.22-1.23); FILE MERGED 2005/07/19 06:05:46 fme 1.22.48.8: #i50348# make SwDoc accessible via interfaces 2005/07/13 13:24:19 fme 1.22.48.7: #i50348# Make SwDoc accessible via interfaces 2005/07/05 08:12:39 tra 1.22.48.6: #i50348#make SwDoc interface based 2005/06/24 11:43:17 fme 1.22.48.5: #i50348# Make SwDoc accessible via interfaces 2005/06/22 13:08:12 tra 1.22.48.4: #i50348#toward a interface based SwDoc 2005/06/22 06:40:10 tra 1.22.48.3: #i50348# make SwDoc accessible via interfaces 2005/06/07 14:13:38 fme 1.22.48.2: #i50348# General cleanup - removed unused header files, functions, members, declarations etc. 2005/06/06 09:27:18 tra 1.22.48.1: Unnecessary includes removed #i50348#
2006-08-14 15:05:06 +00:00
/*
* Document Interface Access
*/
const IDocumentSettingAccess* SwNode::getIDocumentSettingAccess() const { return GetDoc(); }
const IDocumentDeviceAccess* SwNode::getIDocumentDeviceAccess() const { return GetDoc(); }
const IDocumentRedlineAccess* SwNode::getIDocumentRedlineAccess() const { return GetDoc(); }
const IDocumentStylePoolAccess* SwNode::getIDocumentStylePoolAccess() const { return GetDoc(); }
const IDocumentLineNumberAccess* SwNode::getIDocumentLineNumberAccess() const { return GetDoc(); }
const IDocumentDrawModelAccess* SwNode::getIDocumentDrawModelAccess() const { return GetDoc(); }
const IDocumentLayoutAccess* SwNode::getIDocumentLayoutAccess() const { return GetDoc(); }
IDocumentLayoutAccess* SwNode::getIDocumentLayoutAccess() { return GetDoc(); }
const IDocumentLinksAdministration* SwNode::getIDocumentLinksAdministration() const { return GetDoc(); }
IDocumentLinksAdministration* SwNode::getIDocumentLinksAdministration() { return GetDoc(); }
const IDocumentFieldsAccess* SwNode::getIDocumentFieldsAccess() const { return GetDoc(); }
IDocumentFieldsAccess* SwNode::getIDocumentFieldsAccess() { return GetDoc(); }
IDocumentContentOperations* SwNode::getIDocumentContentOperations() { return GetDoc(); }
IDocumentListItems& SwNode::getIDocumentListItems() { return *GetDoc(); } // #i83479#
const IDocumentMarkAccess* SwNode::getIDocumentMarkAccess() const { return GetDoc()->getIDocumentMarkAccess(); }
IStyleAccess& SwNode::getIDocumentStyleAccess() { return GetDoc()->GetIStyleAccess(); }
INTEGRATION: CWS writercorehandoff (1.22.48); FILE MERGED 2006/07/27 14:39:25 fme 1.22.48.18: RESYNC: (1.26-1.27); FILE MERGED 2006/05/09 10:37:57 fme 1.22.48.17: #i50348# make SwDoc accessible via interfaces 2006/05/08 11:21:11 fme 1.22.48.16: #i50348# Make SwDoc accessible via interfaces 2006/03/17 08:03:39 tra 1.22.48.15: RESYNC: (1.25-1.26); FILE MERGED 2006/01/19 08:50:04 fme 1.22.48.14: #i50348# General cleanup - removed unused header files, functions, members, declarations 2005/12/20 15:09:39 tra 1.22.48.13: RESYNC: (1.24-1.25); FILE MERGED 2005/11/18 14:53:21 fme 1.22.48.12: #i50348# Make SwDoc accessible via interfaces 2005/11/11 07:56:07 fme 1.22.48.11: #i50348# make SwDoc accessible via interfaces 2005/09/13 13:27:52 tra 1.22.48.10: RESYNC: (1.23-1.24); FILE MERGED 2005/07/28 11:55:30 tra 1.22.48.9: RESYNC: (1.22-1.23); FILE MERGED 2005/07/19 06:05:46 fme 1.22.48.8: #i50348# make SwDoc accessible via interfaces 2005/07/13 13:24:19 fme 1.22.48.7: #i50348# Make SwDoc accessible via interfaces 2005/07/05 08:12:39 tra 1.22.48.6: #i50348#make SwDoc interface based 2005/06/24 11:43:17 fme 1.22.48.5: #i50348# Make SwDoc accessible via interfaces 2005/06/22 13:08:12 tra 1.22.48.4: #i50348#toward a interface based SwDoc 2005/06/22 06:40:10 tra 1.22.48.3: #i50348# make SwDoc accessible via interfaces 2005/06/07 14:13:38 fme 1.22.48.2: #i50348# General cleanup - removed unused header files, functions, members, declarations etc. 2005/06/06 09:27:18 tra 1.22.48.1: Unnecessary includes removed #i50348#
2006-08-14 15:05:06 +00:00
sal_Bool SwNode::IsInRedlines() const
{
const SwDoc * pDoc = GetDoc();
sal_Bool bResult = sal_False;
2000-09-18 23:08:29 +00:00
if (pDoc != NULL)
bResult = pDoc->IsInRedlines(*this);
2000-09-18 23:08:29 +00:00
return bResult;
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */