forked from amazingfate/loongoffice
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.
396 lines
10 KiB
C++
396 lines
10 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 .
|
|
*/
|
|
|
|
|
|
#include <editeng/svxenum.hxx>
|
|
#include <numrule.hxx>
|
|
#include <SwNodeNum.hxx>
|
|
#include <ndtxt.hxx>
|
|
#include <pam.hxx>
|
|
#include <stdio.h>
|
|
// #i83479#
|
|
#include <IDocumentListItems.hxx>
|
|
#include <doc.hxx>
|
|
|
|
SwNodeNum::SwNodeNum( SwTxtNode* pTxtNode )
|
|
: SwNumberTreeNode(),
|
|
mpTxtNode( pTxtNode ),
|
|
mpNumRule( 0 )
|
|
{
|
|
}
|
|
|
|
SwNodeNum::SwNodeNum( SwNumRule* pNumRule )
|
|
: SwNumberTreeNode(),
|
|
mpTxtNode( 0 ),
|
|
mpNumRule( pNumRule )
|
|
{
|
|
}
|
|
|
|
SwNodeNum::~SwNodeNum()
|
|
{
|
|
}
|
|
|
|
SwTxtNode * SwNodeNum::GetTxtNode() const
|
|
{
|
|
return mpTxtNode;
|
|
}
|
|
|
|
SwNumRule * SwNodeNum::GetNumRule() const
|
|
{
|
|
return mpNumRule;
|
|
}
|
|
|
|
void SwNodeNum::ChangeNumRule( SwNumRule& rNumRule )
|
|
{
|
|
OSL_ENSURE( GetNumRule() && GetTxtNode(),
|
|
"<SwNodeNum::ChangeNumRule(..)> - missing list style and/or text node. Serious defect -> please informm OD." );
|
|
if ( GetNumRule() && GetTxtNode() )
|
|
{
|
|
GetNumRule()->RemoveTxtNode( *(GetTxtNode()) );
|
|
}
|
|
|
|
mpNumRule = &rNumRule;
|
|
|
|
if ( GetNumRule() && GetTxtNode() )
|
|
{
|
|
GetNumRule()->AddTxtNode( *(GetTxtNode()) );
|
|
}
|
|
}
|
|
|
|
SwPosition SwNodeNum::GetPosition() const
|
|
{
|
|
OSL_ENSURE( GetTxtNode(),
|
|
"<SwNodeNum::GetPosition()> - no text node set at <SwNodeNum> instance" );
|
|
return SwPosition(*mpTxtNode);
|
|
}
|
|
|
|
SwNumberTreeNode * SwNodeNum::Create() const
|
|
{
|
|
SwNodeNum * pResult = new SwNodeNum( GetNumRule() );
|
|
|
|
return pResult;
|
|
}
|
|
|
|
void SwNodeNum::PreAdd()
|
|
{
|
|
OSL_ENSURE( GetTxtNode(),
|
|
"<SwNodeNum::PreAdd()> - no text node set at <SwNodeNum> instance" );
|
|
if ( !GetNumRule() && GetTxtNode() )
|
|
{
|
|
mpNumRule = GetTxtNode()->GetNumRule();
|
|
}
|
|
OSL_ENSURE( GetNumRule(),
|
|
"<SwNodeNum::PreAdd()> - no list style set at <SwNodeNum> instance" );
|
|
if ( GetNumRule() && GetTxtNode() )
|
|
{
|
|
GetNumRule()->AddTxtNode( *(GetTxtNode()) );
|
|
}
|
|
|
|
|
|
{
|
|
if ( GetTxtNode() &&
|
|
GetTxtNode()->GetNodes().IsDocNodes() )
|
|
{
|
|
GetTxtNode()->getIDocumentListItems().addListItem( *this );
|
|
}
|
|
}
|
|
}
|
|
|
|
void SwNodeNum::PostRemove()
|
|
{
|
|
OSL_ENSURE( GetTxtNode(),
|
|
"<SwNodeNum::PostRemove()> - no text node set at <SwNodeNum> instance" );
|
|
OSL_ENSURE( GetNumRule(),
|
|
"<SwNodeNum::PostRemove()> - no list style set at <SwNodeNum> instance" );
|
|
|
|
if ( GetTxtNode() )
|
|
{
|
|
GetTxtNode()->getIDocumentListItems().removeListItem( *this );
|
|
}
|
|
|
|
if ( GetNumRule() )
|
|
{
|
|
if ( GetTxtNode() )
|
|
{
|
|
GetNumRule()->RemoveTxtNode( *(GetTxtNode()) );
|
|
}
|
|
mpNumRule = 0;
|
|
}
|
|
}
|
|
|
|
bool SwNodeNum::IsNotifiable() const
|
|
{
|
|
bool aResult = true;
|
|
|
|
if ( GetTxtNode() )
|
|
aResult = GetTxtNode()->IsNotifiable();
|
|
|
|
return aResult;
|
|
}
|
|
|
|
bool SwNodeNum::IsNotificationEnabled() const
|
|
{
|
|
bool aResult = true;
|
|
|
|
if ( GetTxtNode() )
|
|
aResult = GetTxtNode()->IsNotificationEnabled();
|
|
|
|
return aResult;
|
|
}
|
|
|
|
bool SwNodeNum::IsContinuous() const
|
|
{
|
|
bool aResult = false;
|
|
|
|
// #i64311#
|
|
if ( GetNumRule() )
|
|
{
|
|
aResult = mpNumRule->IsContinusNum();
|
|
}
|
|
else if ( GetParent() )
|
|
{
|
|
aResult = GetParent()->IsContinuous();
|
|
}
|
|
else
|
|
{
|
|
OSL_FAIL( "<SwNodeNum::IsContinuous()> - OD debug" );
|
|
}
|
|
|
|
return aResult;
|
|
}
|
|
|
|
bool SwNodeNum::IsCounted() const
|
|
{
|
|
bool aResult = false;
|
|
|
|
if ( GetTxtNode() )
|
|
{
|
|
// #i59559#
|
|
// <SwTxtNode::IsCounted()> determines, if a text node is counted for numbering
|
|
aResult = GetTxtNode()->IsCountedInList();
|
|
}
|
|
else
|
|
aResult = SwNumberTreeNode::IsCounted();
|
|
|
|
return aResult;
|
|
}
|
|
|
|
// #i64010#
|
|
bool SwNodeNum::HasCountedChildren() const
|
|
{
|
|
bool bResult = false;
|
|
|
|
tSwNumberTreeChildren::const_iterator aIt;
|
|
|
|
for (aIt = mChildren.begin(); aIt != mChildren.end(); ++aIt)
|
|
{
|
|
SwNodeNum* pChild( dynamic_cast<SwNodeNum*>(*aIt) );
|
|
OSL_ENSURE( pChild,
|
|
"<SwNodeNum::HasCountedChildren()> - unexcepted type of child -> please inform OD" );
|
|
if ( pChild &&
|
|
( pChild->IsCountedForNumbering() ||
|
|
pChild->HasCountedChildren() ) )
|
|
{
|
|
bResult = true;
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
return bResult;
|
|
}
|
|
// #i64010#
|
|
bool SwNodeNum::IsCountedForNumbering() const
|
|
{
|
|
return IsCounted() &&
|
|
( IsPhantom() || // phantoms
|
|
!GetTxtNode() || // root node
|
|
GetTxtNode()->HasNumber() || // text node
|
|
GetTxtNode()->HasBullet() ); // text node
|
|
}
|
|
|
|
|
|
void SwNodeNum::NotifyNode()
|
|
{
|
|
ValidateMe();
|
|
|
|
if (mpTxtNode)
|
|
{
|
|
mpTxtNode->NumRuleChgd();
|
|
}
|
|
}
|
|
|
|
bool SwNodeNum::LessThan(const SwNumberTreeNode & rNode) const
|
|
{
|
|
bool bResult = false;
|
|
const SwNodeNum & rTmpNode = static_cast<const SwNodeNum &>(rNode);
|
|
|
|
if (mpTxtNode == NULL && rTmpNode.mpTxtNode != NULL)
|
|
bResult = true;
|
|
else if (mpTxtNode != NULL && rTmpNode.mpTxtNode != NULL)
|
|
{
|
|
// #i83479# - refactoring
|
|
// simplify comparison by comparing the indexes of the text nodes
|
|
bResult = ( mpTxtNode->GetIndex() < rTmpNode.mpTxtNode->GetIndex() ) ? true : false;
|
|
}
|
|
|
|
return bResult;
|
|
}
|
|
|
|
bool SwNodeNum::IsRestart() const
|
|
{
|
|
bool bIsRestart = false;
|
|
|
|
if ( GetTxtNode() )
|
|
{
|
|
bIsRestart = GetTxtNode()->IsListRestart();
|
|
}
|
|
|
|
return bIsRestart;
|
|
}
|
|
|
|
bool SwNodeNum::IsCountPhantoms() const
|
|
{
|
|
bool bResult = true;
|
|
|
|
// #i64311#
|
|
// phantoms aren't counted in consecutive numbering rules
|
|
if ( mpNumRule )
|
|
bResult = !mpNumRule->IsContinusNum() &&
|
|
mpNumRule->IsCountPhantoms();
|
|
else
|
|
{
|
|
OSL_FAIL( "<SwNodeNum::IsCountPhantoms(): missing numbering rule - please inform OD" );
|
|
}
|
|
|
|
return bResult;
|
|
}
|
|
|
|
SwNumberTree::tSwNumTreeNumber SwNodeNum::GetStartValue() const
|
|
{
|
|
SwNumberTree::tSwNumTreeNumber aResult = 1;
|
|
|
|
if ( IsRestart() && GetTxtNode() )
|
|
{
|
|
aResult = GetTxtNode()->GetActualListStartValue();
|
|
}
|
|
else
|
|
{
|
|
SwNumRule * pRule = GetNumRule();
|
|
|
|
if (pRule)
|
|
{
|
|
int nLevel = GetParent() ? GetLevelInListTree() : 0;
|
|
|
|
if (nLevel >= 0 && nLevel < MAXLEVEL)
|
|
{
|
|
const SwNumFmt * pFmt = pRule->GetNumFmt( static_cast<sal_uInt16>(nLevel));
|
|
|
|
if (pFmt)
|
|
aResult = pFmt->GetStart();
|
|
}
|
|
}
|
|
}
|
|
|
|
return aResult;
|
|
}
|
|
|
|
void SwNodeNum::HandleNumberTreeRootNodeDelete( SwNodeNum& rNodeNum )
|
|
{
|
|
SwNodeNum* pRootNode = rNodeNum.GetParent()
|
|
? dynamic_cast<SwNodeNum*>(rNodeNum.GetRoot())
|
|
: &rNodeNum;
|
|
if ( !pRootNode )
|
|
{
|
|
// no root node -> nothing do.
|
|
return;
|
|
}
|
|
|
|
// unregister all number tree node entries, which correspond to a text node,
|
|
// about the deletion of the number tree root node.
|
|
_UnregisterMeAndChildrenDueToRootDelete( *pRootNode );
|
|
}
|
|
|
|
void SwNodeNum::_UnregisterMeAndChildrenDueToRootDelete( SwNodeNum& rNodeNum )
|
|
{
|
|
const bool bIsPhantom( rNodeNum.IsPhantom() );
|
|
tSwNumberTreeChildren::size_type nAllowedChildCount( 0 );
|
|
bool bDone( false );
|
|
while ( !bDone &&
|
|
rNodeNum.GetChildCount() > nAllowedChildCount )
|
|
{
|
|
SwNodeNum* pChildNode( dynamic_cast<SwNodeNum*>((*rNodeNum.mChildren.begin())) );
|
|
if ( !pChildNode )
|
|
{
|
|
OSL_FAIL( "<SwNodeNum::_UnregisterMeAndChildrenDueToRootDelete(..)> - unknown number tree node child" );
|
|
++nAllowedChildCount;
|
|
continue;
|
|
}
|
|
|
|
// Unregistering the last child of a phantom will destroy the phantom.
|
|
// Thus <rNodeNum> will be destroyed and access on <rNodeNum> has to
|
|
// be suppressed.
|
|
if ( bIsPhantom && rNodeNum.GetChildCount() == 1 )
|
|
{
|
|
bDone = true;
|
|
}
|
|
|
|
_UnregisterMeAndChildrenDueToRootDelete( *pChildNode );
|
|
}
|
|
|
|
if ( !bIsPhantom )
|
|
{
|
|
SwTxtNode* pTxtNode( rNodeNum.GetTxtNode() );
|
|
if ( pTxtNode )
|
|
{
|
|
pTxtNode->RemoveFromList();
|
|
// --> clear all list attributes and the list style
|
|
std::set<sal_uInt16> aResetAttrsArray;
|
|
aResetAttrsArray.insert( aResetAttrsArray.end(), RES_PARATR_LIST_ID );
|
|
aResetAttrsArray.insert( aResetAttrsArray.end(), RES_PARATR_LIST_LEVEL );
|
|
aResetAttrsArray.insert( aResetAttrsArray.end(), RES_PARATR_LIST_ISRESTART );
|
|
aResetAttrsArray.insert( aResetAttrsArray.end(), RES_PARATR_LIST_RESTARTVALUE );
|
|
aResetAttrsArray.insert( aResetAttrsArray.end(), RES_PARATR_LIST_ISCOUNTED );
|
|
aResetAttrsArray.insert( aResetAttrsArray.end(), RES_PARATR_NUMRULE );
|
|
SwPaM aPam( *pTxtNode );
|
|
pTxtNode->GetDoc()->ResetAttrs( aPam, false,
|
|
aResetAttrsArray,
|
|
false );
|
|
}
|
|
}
|
|
}
|
|
|
|
// #i81002#
|
|
const SwNodeNum* SwNodeNum::GetPrecedingNodeNumOf( const SwTxtNode& rTxtNode ) const
|
|
{
|
|
const SwNodeNum* pPrecedingNodeNum( 0 );
|
|
|
|
// #i83479#
|
|
SwNodeNum aNodeNumForTxtNode( const_cast<SwTxtNode*>(&rTxtNode) );
|
|
|
|
pPrecedingNodeNum = dynamic_cast<const SwNodeNum*>(
|
|
GetRoot()
|
|
? GetRoot()->GetPrecedingNodeOf( aNodeNumForTxtNode )
|
|
: GetPrecedingNodeOf( aNodeNumForTxtNode ) );
|
|
|
|
return pPrecedingNodeNum;
|
|
}
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|