Files
libreoffice/sw/source/core/doc/number.cxx

1458 lines
45 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2000-09-18 23:08:29 +00:00
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2000-09-18 23:08:29 +00:00
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 23:08:29 +00:00
*
* This file is part of OpenOffice.org.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
2000-09-18 23:08:29 +00:00
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
2000-09-18 23:08:29 +00:00
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_sw.hxx"
2000-09-18 23:08:29 +00:00
#include <hintids.hxx>
#include <string.h>
#include <vcl/font.hxx>
#include <editeng/brshitem.hxx>
#include <editeng/lrspitem.hxx>
#include <editeng/numitem.hxx>
2000-09-18 23:08:29 +00:00
#include <fmtornt.hxx>
#include <doc.hxx>
#include <pam.hxx>
#include <charfmt.hxx>
#include <paratr.hxx>
#include <frmfmt.hxx>
#include <ndtxt.hxx>
#include <docary.hxx>
#include <docsh.hxx>
#include <SwStyleNameMapper.hxx>
2010-10-18 12:57:41 +01:00
// Needed to load default bullet list configuration
#include <unotools/configitem.hxx>
2010-10-18 12:57:41 +01:00
#include <numrule.hxx>
#include <SwNodeNum.hxx>
2000-09-18 23:08:29 +00:00
#include <boost/unordered_map.hpp>
2010-10-18 12:57:41 +01:00
#include <list.hxx>
#include <algorithm>
2010-10-18 12:57:41 +01:00
#include <unotools/saveopt.hxx>
2010-10-18 12:57:41 +01:00
#include <IDocumentListsAccess.hxx>
using namespace ::com::sun::star;
sal_uInt16 SwNumRule::nRefCount = 0;
2000-09-18 23:08:29 +00:00
SwNumFmt* SwNumRule::aBaseFmts[ RULE_END ][ MAXLEVEL ] = {
{0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } };
2010-10-18 12:57:41 +01:00
SwNumFmt* SwNumRule::aLabelAlignmentBaseFmts[ RULE_END ][ MAXLEVEL ] = {
{0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } };
char sOutline[] = "Outline";
char* SwNumRule::pDefOutlineName = sOutline;
2000-09-18 23:08:29 +00:00
sal_uInt16 SwNumRule::aDefNumIndents[ MAXLEVEL ] = {
//inch: 0,5 1,0 1,5 2,0 2,5 3,0 3,5 4,0 4,5 5,0
1440/4, 1440/2, 1440*3/4, 1440, 1440*5/4, 1440*3/2, 1440*7/4, 1440*2,
1440*9/4, 1440*5/2
2000-09-18 23:08:29 +00:00
};
const SwNumFmt& SwNumRule::Get( sal_uInt16 i ) const
{
2011-02-20 17:58:46 +01:00
OSL_ASSERT( i < MAXLEVEL && eRuleType < RULE_END );
return aFmts[ i ]
? *aFmts[ i ]
: ( meDefaultNumberFormatPositionAndSpaceMode == SvxNumberFormat::LABEL_WIDTH_AND_POSITION
? *aBaseFmts[ eRuleType ][ i ]
: *aLabelAlignmentBaseFmts[ eRuleType ][ i ] );
}
const SwNumFmt* SwNumRule::GetNumFmt( sal_uInt16 i ) const
{
const SwNumFmt * pResult = NULL;
2011-02-20 17:58:46 +01:00
OSL_ASSERT( i < MAXLEVEL && eRuleType < RULE_END );
if ( i < MAXLEVEL && eRuleType < RULE_END)
{
pResult = aFmts[ i ];
}
return pResult;
}
2011-02-02 20:41:40 +09:00
// #i91400#
void SwNumRule::SetName( const String & rName,
IDocumentListsAccess& rDocListAccess)
// <--
{
if ( sName != rName )
{
if (pNumRuleMap)
{
pNumRuleMap->erase(sName);
(*pNumRuleMap)[rName] = this;
if ( GetDefaultListId().Len() > 0 )
{
rDocListAccess.trackChangeOfListStyleName( sName, rName );
}
}
sName = rName;
}
}
2010-10-18 12:57:41 +01:00
void SwNumRule::GetTxtNodeList( SwNumRule::tTxtNodeList& rTxtNodeList ) const
{
rTxtNodeList = maTxtNodeList;
}
2010-10-18 12:57:41 +01:00
SwNumRule::tTxtNodeList::size_type SwNumRule::GetTxtNodeListSize() const
{
return maTxtNodeList.size();
}
2010-10-18 12:57:41 +01:00
void SwNumRule::AddTxtNode( SwTxtNode& rTxtNode )
{
tTxtNodeList::iterator aIter =
std::find( maTxtNodeList.begin(), maTxtNodeList.end(), &rTxtNode );
if ( aIter == maTxtNodeList.end() )
{
maTxtNodeList.push_back( &rTxtNode );
}
}
2010-10-18 12:57:41 +01:00
void SwNumRule::RemoveTxtNode( SwTxtNode& rTxtNode )
{
tTxtNodeList::iterator aIter =
std::find( maTxtNodeList.begin(), maTxtNodeList.end(), &rTxtNode );
if ( aIter != maTxtNodeList.end() )
{
maTxtNodeList.erase( aIter );
}
}
2010-10-18 12:57:41 +01:00
void SwNumRule::SetNumRuleMap(boost::unordered_map<String, SwNumRule *, StringHash> *
_pNumRuleMap)
{
pNumRuleMap = _pNumRuleMap;
}
sal_uInt16 SwNumRule::GetNumIndent( sal_uInt8 nLvl )
{
OSL_ENSURE( MAXLEVEL > nLvl, "NumLevel is out of range" );
return aDefNumIndents[ nLvl ];
}
sal_uInt16 SwNumRule::GetBullIndent( sal_uInt8 nLvl )
{
OSL_ENSURE( MAXLEVEL > nLvl, "NumLevel is out of range" );
return aDefNumIndents[ nLvl ];
}
static void lcl_SetRuleChgd( SwTxtNode& rNd, sal_uInt8 nLevel )
2000-09-18 23:08:29 +00:00
{
if( rNd.GetActualListLevel() == nLevel )
rNd.NumRuleChgd();
2000-09-18 23:08:29 +00:00
}
SwNumFmt::SwNumFmt() :
SvxNumberFormat(SVX_NUM_ARABIC),
SwClient( 0 ),
pVertOrient(new SwFmtVertOrient( 0, text::VertOrientation::NONE))
2000-09-18 23:08:29 +00:00
{
}
SwNumFmt::SwNumFmt( const SwNumFmt& rFmt) :
SvxNumberFormat(rFmt),
SwClient( rFmt.GetRegisteredInNonConst() ),
pVertOrient(new SwFmtVertOrient( 0, rFmt.GetVertOrient()))
2000-09-18 23:08:29 +00:00
{
sal_Int16 eMyVertOrient = rFmt.GetVertOrient();
SetGraphicBrush( rFmt.GetBrush(), &rFmt.GetGraphicSize(),
&eMyVertOrient);
2000-09-18 23:08:29 +00:00
}
SwNumFmt::SwNumFmt(const SvxNumberFormat& rNumFmt, SwDoc* pDoc) :
SvxNumberFormat(rNumFmt),
pVertOrient(new SwFmtVertOrient( 0, rNumFmt.GetVertOrient()))
2000-09-18 23:08:29 +00:00
{
sal_Int16 eMyVertOrient = rNumFmt.GetVertOrient();
SetGraphicBrush( rNumFmt.GetBrush(), &rNumFmt.GetGraphicSize(),
&eMyVertOrient);
const String& rCharStyleName = rNumFmt.SvxNumberFormat::GetCharFmtName();
if( rCharStyleName.Len() )
2000-09-18 23:08:29 +00:00
{
SwCharFmt* pCFmt = pDoc->FindCharFmtByName( rCharStyleName );
if( !pCFmt )
2000-09-18 23:08:29 +00:00
{
sal_uInt16 nId = SwStyleNameMapper::GetPoolIdFromUIName( rCharStyleName,
nsSwGetPoolIdFromName::GET_POOLID_CHRFMT );
pCFmt = nId != USHRT_MAX
? pDoc->GetCharFmtFromPool( nId )
: pDoc->MakeCharFmt( rCharStyleName, 0 );
2000-09-18 23:08:29 +00:00
}
pCFmt->Add( this );
2000-09-18 23:08:29 +00:00
}
else if( GetRegisteredIn() )
GetRegisteredInNonConst()->Remove( this );
2000-09-18 23:08:29 +00:00
}
SwNumFmt::~SwNumFmt()
{
delete pVertOrient;
}
void SwNumFmt::NotifyGraphicArrived()
{
if( GetCharFmt() )
UpdateNumNodes( (SwDoc*)GetCharFmt()->GetDoc() );
}
// #i22362#
sal_Bool SwNumFmt::IsEnumeration() const
{
// --> FME 2004-08-12 #i30655# native numbering did not work any longer
// using this code. Therefore HBRINKM and I agreed upon defining
// IsEnumeration() as !IsItemize()
return !IsItemize();
}
2010-10-18 12:57:41 +01:00
sal_Bool SwNumFmt::IsItemize() const
{
sal_Bool bResult;
switch(GetNumberingType())
{
case SVX_NUM_CHAR_SPECIAL:
case SVX_NUM_BITMAP:
bResult = sal_True;
break;
default:
bResult = sal_False;
}
return bResult;
}
SwNumFmt& SwNumFmt::operator=( const SwNumFmt& rNumFmt)
2000-09-18 23:08:29 +00:00
{
SvxNumberFormat::operator=(rNumFmt);
2000-09-18 23:08:29 +00:00
if( rNumFmt.GetRegisteredIn() )
rNumFmt.GetRegisteredInNonConst()->Add( this );
2000-09-18 23:08:29 +00:00
else if( GetRegisteredIn() )
GetRegisteredInNonConst()->Remove( this );
2000-09-18 23:08:29 +00:00
return *this;
}
sal_Bool SwNumFmt::operator==( const SwNumFmt& rNumFmt) const
2000-09-18 23:08:29 +00:00
{
sal_Bool bRet = SvxNumberFormat::operator==(rNumFmt) &&
GetRegisteredIn() == rNumFmt.GetRegisteredIn();
2000-09-18 23:08:29 +00:00
return bRet;
}
void SwNumFmt::SetCharFmt( SwCharFmt* pChFmt)
2000-09-18 23:08:29 +00:00
{
if( pChFmt )
pChFmt->Add( this );
else if( GetRegisteredIn() )
GetRegisteredInNonConst()->Remove( this );
2000-09-18 23:08:29 +00:00
}
void SwNumFmt::Modify( const SfxPoolItem* pOld, const SfxPoolItem* pNew )
2000-09-18 23:08:29 +00:00
{
// dann suche mal in dem Doc nach dem NumRules-Object, in dem dieses
// NumFormat gesetzt ist. Das Format muss es nicht geben!
const SwCharFmt* pFmt = 0;
sal_uInt16 nWhich = pOld ? pOld->Which() : pNew ? pNew->Which() : 0;
switch( nWhich )
2000-09-18 23:08:29 +00:00
{
case RES_ATTRSET_CHG:
case RES_FMT_CHG:
pFmt = GetCharFmt();
break;
}
if( pFmt && !pFmt->GetDoc()->IsInDtor() )
UpdateNumNodes( (SwDoc*)pFmt->GetDoc() );
else
CheckRegistration( pOld, pNew );
2000-09-18 23:08:29 +00:00
}
void SwNumFmt::SetCharFmtName(const String& rSet)
2000-09-18 23:08:29 +00:00
{
SvxNumberFormat::SetCharFmtName(rSet);
2000-09-18 23:08:29 +00:00
}
const String& SwNumFmt::GetCharFmtName() const
{
if((SwCharFmt*)GetRegisteredIn())
return ((SwCharFmt*)GetRegisteredIn())->GetName();
else
return aEmptyStr;
}
2000-09-18 23:08:29 +00:00
void SwNumFmt::ForgetCharFmt()
{
if ( GetRegisteredIn() )
GetRegisteredInNonConst()->Remove( this );
}
2000-09-18 23:08:29 +00:00
void SwNumFmt::SetGraphicBrush( const SvxBrushItem* pBrushItem, const Size* pSize,
const sal_Int16* pOrient)
2000-09-18 23:08:29 +00:00
{
if(pOrient)
pVertOrient->SetVertOrient( *pOrient );
SvxNumberFormat::SetGraphicBrush( pBrushItem, pSize, pOrient);
}
2000-09-18 23:08:29 +00:00
void SwNumFmt::SetVertOrient(sal_Int16 eSet)
{
SvxNumberFormat::SetVertOrient(eSet);
2000-09-18 23:08:29 +00:00
}
sal_Int16 SwNumFmt::GetVertOrient() const
2000-09-18 23:08:29 +00:00
{
return SvxNumberFormat::GetVertOrient();
2000-09-18 23:08:29 +00:00
}
void SwNumFmt::UpdateNumNodes( SwDoc* pDoc )
{
sal_Bool bDocIsModified = pDoc->IsModified();
sal_Bool bFnd = sal_False;
2000-09-18 23:08:29 +00:00
const SwNumRule* pRule;
for( sal_uInt16 n = pDoc->GetNumRuleTbl().Count(); !bFnd && n; )
2000-09-18 23:08:29 +00:00
{
pRule = pDoc->GetNumRuleTbl()[ --n ];
for( sal_uInt8 i = 0; i < MAXLEVEL; ++i )
2000-09-18 23:08:29 +00:00
if( pRule->GetNumFmt( i ) == this )
{
SwNumRule::tTxtNodeList aTxtNodeList;
pRule->GetTxtNodeList( aTxtNodeList );
for ( SwNumRule::tTxtNodeList::iterator aIter = aTxtNodeList.begin();
aIter != aTxtNodeList.end(); ++aIter )
{
lcl_SetRuleChgd( *(*aIter), i );
}
// <--
bFnd = sal_True;
2000-09-18 23:08:29 +00:00
break;
}
}
if( bFnd && !bDocIsModified )
pDoc->ResetModified();
}
const SwFmtVertOrient* SwNumFmt::GetGraphicOrientation() const
{
sal_Int16 eOrient = SvxNumberFormat::GetVertOrient();
if(text::VertOrientation::NONE == eOrient)
return 0;
else
{
pVertOrient->SetVertOrient(eOrient);
return pVertOrient;
}
}
2000-09-18 23:08:29 +00:00
#if OSL_DEBUG_LEVEL > 1
long int SwNumRule::nInstances = 0;
#endif
// handle new parameter <eDefaultNumberFormatPositionAndSpaceMode>
SwNumRule::SwNumRule( const String& rNm,
const SvxNumberFormat::SvxNumPositionAndSpaceMode eDefaultNumberFormatPositionAndSpaceMode,
SwNumRuleType eType,
sal_Bool bAutoFlg )
: maTxtNodeList(),
maParagraphStyleList(),
pNumRuleMap(0),
2000-09-18 23:08:29 +00:00
sName( rNm ),
eRuleType( eType ),
nPoolFmtId( USHRT_MAX ),
nPoolHelpId( USHRT_MAX ),
nPoolHlpFileId( UCHAR_MAX ),
2000-09-18 23:08:29 +00:00
bAutoRuleFlag( bAutoFlg ),
bInvalidRuleFlag( sal_True ),
bContinusNum( sal_False ),
bAbsSpaces( sal_False ),
mbCountPhantoms( true ),
meDefaultNumberFormatPositionAndSpaceMode( eDefaultNumberFormatPositionAndSpaceMode ),
msDefaultListId()
2000-09-18 23:08:29 +00:00
{
#if OSL_DEBUG_LEVEL > 1
nSerial = nInstances++;
#endif
2000-09-18 23:08:29 +00:00
if( !nRefCount++ ) // zum erstmal, also initialisiern
{
SwNumFmt* pFmt;
sal_uInt8 n;
// numbering:
// position-and-space mode LABEL_WIDTH_AND_POSITION:
for( n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
{
pFmt = new SwNumFmt;
pFmt->SetIncludeUpperLevels( 1 );
pFmt->SetStart( 1 );
2000-09-18 23:08:29 +00:00
pFmt->SetLSpace( lNumIndent );
pFmt->SetAbsLSpace( lNumIndent + SwNumRule::GetNumIndent( n ) );
2000-09-18 23:08:29 +00:00
pFmt->SetFirstLineOffset( lNumFirstLineOffset );
pFmt->SetSuffix( aDotStr );
pFmt->SetBulletChar( numfunc::GetBulletChar(n));
2000-09-18 23:08:29 +00:00
SwNumRule::aBaseFmts[ NUM_RULE ][ n ] = pFmt;
}
// position-and-space mode LABEL_ALIGNMENT
// first line indent of general numbering in inch: -0,25 inch
const long cFirstLineIndent = -1440/4;
// indent values of general numbering in inch:
// 0,5 0,75 1,0 1,25 1,5
// 1,75 2,0 2,25 2,5 2,75
const long cIndentAt[ MAXLEVEL ] = {
1440/2, 1440*3/4, 1440, 1440*5/4, 1440*3/2,
1440*7/4, 1440*2, 1440*9/4, 1440*5/2, 1440*11/4 };
for( n = 0; n < MAXLEVEL; ++n )
{
pFmt = new SwNumFmt;
pFmt->SetIncludeUpperLevels( 1 );
pFmt->SetStart( 1 );
pFmt->SetPositionAndSpaceMode( SvxNumberFormat::LABEL_ALIGNMENT );
pFmt->SetLabelFollowedBy( SvxNumberFormat::LISTTAB );
pFmt->SetListtabPos( cIndentAt[ n ] );
pFmt->SetFirstLineIndent( cFirstLineIndent );
pFmt->SetIndentAt( cIndentAt[ n ] );
pFmt->SetSuffix( aDotStr );
pFmt->SetBulletChar( numfunc::GetBulletChar(n));
SwNumRule::aLabelAlignmentBaseFmts[ NUM_RULE ][ n ] = pFmt;
}
2000-09-18 23:08:29 +00:00
// outline:
// position-and-space mode LABEL_WIDTH_AND_POSITION:
2000-09-18 23:08:29 +00:00
for( n = 0; n < MAXLEVEL; ++n )
{
pFmt = new SwNumFmt;
pFmt->SetNumberingType(SVX_NUM_NUMBER_NONE);
pFmt->SetIncludeUpperLevels( MAXLEVEL );
pFmt->SetStart( 1 );
pFmt->SetCharTextDistance( lOutlineMinTextDistance );
pFmt->SetBulletChar( numfunc::GetBulletChar(n));
2000-09-18 23:08:29 +00:00
SwNumRule::aBaseFmts[ OUTLINE_RULE ][ n ] = pFmt;
}
// position-and-space mode LABEL_ALIGNMENT:
// indent values of default outline numbering in inch:
// 0,3 0,4 0,5 0,6 0,7
// 0,8 0,9 1,0 1,1 1,2
const long cOutlineIndentAt[ MAXLEVEL ] = {
1440*3/10, 1440*2/5, 1440/2, 1440*3/5, 1440*7/10,
1440*4/5, 1440*9/10, 1440, 1440*11/10, 1440*6/5 };
for( n = 0; n < MAXLEVEL; ++n )
{
pFmt = new SwNumFmt;
pFmt->SetNumberingType(SVX_NUM_NUMBER_NONE);
pFmt->SetIncludeUpperLevels( MAXLEVEL );
pFmt->SetStart( 1 );
pFmt->SetPositionAndSpaceMode( SvxNumberFormat::LABEL_ALIGNMENT );
pFmt->SetLabelFollowedBy( SvxNumberFormat::LISTTAB );
pFmt->SetListtabPos( cOutlineIndentAt[ n ] );
pFmt->SetFirstLineIndent( -cOutlineIndentAt[ n ] );
pFmt->SetIndentAt( cOutlineIndentAt[ n ] );
pFmt->SetBulletChar( numfunc::GetBulletChar(n));
SwNumRule::aLabelAlignmentBaseFmts[ OUTLINE_RULE ][ n ] = pFmt;
}
2000-09-18 23:08:29 +00:00
}
memset( aFmts, 0, sizeof( aFmts ));
OSL_ENSURE( sName.Len(), "NumRule ohne Namen!" );
2000-09-18 23:08:29 +00:00
}
SwNumRule::SwNumRule( const SwNumRule& rNumRule )
: maTxtNodeList(),
maParagraphStyleList(),
pNumRuleMap(0),
sName( rNumRule.sName ),
eRuleType( rNumRule.eRuleType ),
nPoolFmtId( rNumRule.GetPoolFmtId() ),
nPoolHelpId( rNumRule.GetPoolHelpId() ),
nPoolHlpFileId( rNumRule.GetPoolHlpFileId() ),
bAutoRuleFlag( rNumRule.bAutoRuleFlag ),
bInvalidRuleFlag( sal_True ),
bContinusNum( rNumRule.bContinusNum ),
bAbsSpaces( rNumRule.bAbsSpaces ),
mbCountPhantoms( true ),
meDefaultNumberFormatPositionAndSpaceMode( rNumRule.meDefaultNumberFormatPositionAndSpaceMode ),
msDefaultListId( rNumRule.msDefaultListId )
2000-09-18 23:08:29 +00:00
{
#if OSL_DEBUG_LEVEL > 1
nSerial = nInstances++;
#endif
2000-09-18 23:08:29 +00:00
++nRefCount;
memset( aFmts, 0, sizeof( aFmts ));
for( sal_uInt16 n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
if( rNumRule.aFmts[ n ] )
Set( n, *rNumRule.aFmts[ n ] );
}
SwNumRule::~SwNumRule()
{
for( sal_uInt16 n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
delete aFmts[ n ];
if (pNumRuleMap)
{
pNumRuleMap->erase(GetName());
}
2000-09-18 23:08:29 +00:00
if( !--nRefCount ) // der letzte macht die Tuer zu
{
// Nummerierung:
SwNumFmt** ppFmts = (SwNumFmt**)SwNumRule::aBaseFmts;
int n;
for( n = 0; n < MAXLEVEL; ++n, ++ppFmts )
2000-09-18 23:08:29 +00:00
delete *ppFmts, *ppFmts = 0;
// Gliederung:
for( n = 0; n < MAXLEVEL; ++n, ++ppFmts )
delete *ppFmts, *ppFmts = 0;
ppFmts = (SwNumFmt**)SwNumRule::aLabelAlignmentBaseFmts;
for( n = 0; n < MAXLEVEL; ++n, ++ppFmts )
delete *ppFmts, *ppFmts = 0;
for( n = 0; n < MAXLEVEL; ++n, ++ppFmts )
delete *ppFmts, *ppFmts = 0;
2000-09-18 23:08:29 +00:00
}
maTxtNodeList.clear();
maParagraphStyleList.clear();
2000-09-18 23:08:29 +00:00
}
void SwNumRule::CheckCharFmts( SwDoc* pDoc )
{
SwCharFmt* pFmt;
for( sal_uInt8 n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
if( aFmts[ n ] && 0 != ( pFmt = aFmts[ n ]->GetCharFmt() ) &&
pFmt->GetDoc() != pDoc )
{
// dann kopieren!
SwNumFmt* pNew = new SwNumFmt( *aFmts[ n ] );
pNew->SetCharFmt( pDoc->CopyCharFmt( *pFmt ) );
delete aFmts[ n ];
aFmts[ n ] = pNew;
}
}
SwNumRule& SwNumRule::operator=( const SwNumRule& rNumRule )
{
if( this != &rNumRule )
{
for( sal_uInt16 n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
Set( n, rNumRule.aFmts[ n ] );
eRuleType = rNumRule.eRuleType;
sName = rNumRule.sName;
bAutoRuleFlag = rNumRule.bAutoRuleFlag;
bInvalidRuleFlag = sal_True;
2000-09-18 23:08:29 +00:00
bContinusNum = rNumRule.bContinusNum;
bAbsSpaces = rNumRule.bAbsSpaces;
nPoolFmtId = rNumRule.GetPoolFmtId();
nPoolHelpId = rNumRule.GetPoolHelpId();
nPoolHlpFileId = rNumRule.GetPoolHlpFileId();
}
return *this;
}
sal_Bool SwNumRule::operator==( const SwNumRule& rRule ) const
2000-09-18 23:08:29 +00:00
{
sal_Bool bRet = eRuleType == rRule.eRuleType &&
2000-09-18 23:08:29 +00:00
sName == rRule.sName &&
bAutoRuleFlag == rRule.bAutoRuleFlag &&
bContinusNum == rRule.bContinusNum &&
bAbsSpaces == rRule.bAbsSpaces &&
nPoolFmtId == rRule.GetPoolFmtId() &&
nPoolHelpId == rRule.GetPoolHelpId() &&
nPoolHlpFileId == rRule.GetPoolHlpFileId();
if( bRet )
{
for( sal_uInt8 n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
if( !( rRule.Get( n ) == Get( n ) ))
{
bRet = sal_False;
2000-09-18 23:08:29 +00:00
break;
}
}
return bRet;
}
void SwNumRule::Set( sal_uInt16 i, const SwNumFmt& rNumFmt )
2000-09-18 23:08:29 +00:00
{
OSL_ENSURE( i < MAXLEVEL, "Serious defect, please inform OD" );
if( i < MAXLEVEL )
2000-09-18 23:08:29 +00:00
{
if( !aFmts[ i ] || !(rNumFmt == Get( i )) )
{
delete aFmts[ i ];
aFmts[ i ] = new SwNumFmt( rNumFmt );
bInvalidRuleFlag = sal_True;
}
2000-09-18 23:08:29 +00:00
}
}
void SwNumRule::Set( sal_uInt16 i, const SwNumFmt* pNumFmt )
2000-09-18 23:08:29 +00:00
{
OSL_ENSURE( i < MAXLEVEL, "Serious defect, please inform OD" );
if( i >= MAXLEVEL )
return;
2000-09-18 23:08:29 +00:00
SwNumFmt* pOld = aFmts[ i ];
if( !pOld )
{
if( pNumFmt )
{
aFmts[ i ] = new SwNumFmt( *pNumFmt );
bInvalidRuleFlag = sal_True;
2000-09-18 23:08:29 +00:00
}
}
else if( !pNumFmt )
delete pOld, aFmts[ i ] = 0, bInvalidRuleFlag = sal_True;
2000-09-18 23:08:29 +00:00
else if( *pOld != *pNumFmt )
*pOld = *pNumFmt, bInvalidRuleFlag = sal_True;
2000-09-18 23:08:29 +00:00
}
String SwNumRule::MakeNumString( const SwNodeNum& rNum, sal_Bool bInclStrings,
sal_Bool bOnlyArabic ) const
2000-09-18 23:08:29 +00:00
{
String aStr;
if (rNum.IsCounted())
aStr = MakeNumString(rNum.GetNumberVector(),
bInclStrings, bOnlyArabic, MAXLEVEL);
return aStr;
}
String SwNumRule::MakeNumString( const SwNumberTree::tNumberVector & rNumVector,
const sal_Bool bInclStrings,
const sal_Bool bOnlyArabic,
const unsigned int _nRestrictToThisLevel ) const
{
String aStr;
unsigned int nLevel = rNumVector.size() - 1;
2010-10-18 12:57:41 +01:00
if ( nLevel > _nRestrictToThisLevel )
{
nLevel = _nRestrictToThisLevel;
}
if (nLevel < MAXLEVEL)
2000-09-18 23:08:29 +00:00
{
const SwNumFmt& rMyNFmt = Get( static_cast<sal_uInt16>(nLevel) );
2010-11-18 08:25:05 +01:00
2000-09-18 23:08:29 +00:00
{
sal_uInt8 i = static_cast<sal_uInt8>(nLevel);
2000-09-18 23:08:29 +00:00
if( !IsContinusNum() &&
// - do not include upper levels, if level isn't numbered.
rMyNFmt.GetNumberingType() != SVX_NUM_NUMBER_NONE &&
rMyNFmt.GetIncludeUpperLevels() ) // nur der eigene Level ?
2000-09-18 23:08:29 +00:00
{
sal_uInt8 n = rMyNFmt.GetIncludeUpperLevels();
2000-09-18 23:08:29 +00:00
if( 1 < n )
{
if( i+1 >= n )
i -= n - 1;
else
i = 0;
}
}
for( ; i <= nLevel; ++i )
2000-09-18 23:08:29 +00:00
{
const SwNumFmt& rNFmt = Get( i );
if( SVX_NUM_NUMBER_NONE == rNFmt.GetNumberingType() )
2000-09-18 23:08:29 +00:00
{
// Soll aus 1.1.1 --> 2. NoNum --> 1..1 oder 1.1 ??
// if( i != rNum.nMyLevel )
// aStr += aDotStr;
2000-09-18 23:08:29 +00:00
continue;
}
if( rNumVector[ i ] )
2000-09-18 23:08:29 +00:00
{
if( bOnlyArabic )
aStr += String::CreateFromInt32( rNumVector[ i ] );
2000-09-18 23:08:29 +00:00
else
aStr += rNFmt.GetNumStr( rNumVector[ i ] );
2000-09-18 23:08:29 +00:00
}
else
aStr += '0'; // alle 0-Level sind eine 0
if( i != nLevel && aStr.Len() )
2000-09-18 23:08:29 +00:00
aStr += aDotStr;
}
//JP 14.12.99: the type dont have any number, so dont append
// the Post-/Prefix String
if( bInclStrings && !bOnlyArabic &&
SVX_NUM_CHAR_SPECIAL != rMyNFmt.GetNumberingType() &&
SVX_NUM_BITMAP != rMyNFmt.GetNumberingType() )
{
aStr.Insert( rMyNFmt.GetPrefix(), 0 );
aStr += rMyNFmt.GetSuffix();
}
2000-09-18 23:08:29 +00:00
}
}
2000-09-18 23:08:29 +00:00
return aStr;
}
2010-10-18 12:57:41 +01:00
String SwNumRule::MakeRefNumString( const SwNodeNum& rNodeNum,
const bool bInclSuperiorNumLabels,
const sal_uInt8 nRestrictInclToThisLevel ) const
{
String aRefNumStr;
if ( rNodeNum.GetLevelInListTree() >= 0 )
{
const SwNodeNum* pWorkingNodeNum( &rNodeNum );
do
{
bool bMakeNumStringForPhantom( false );
if ( pWorkingNodeNum->IsPhantom() )
{
SwNumFmt aFmt( Get( static_cast<sal_uInt16>(pWorkingNodeNum->GetLevelInListTree()) ) );
bMakeNumStringForPhantom = aFmt.IsEnumeration() &&
SVX_NUM_NUMBER_NONE != aFmt.GetNumberingType();
}
if ( bMakeNumStringForPhantom ||
( !pWorkingNodeNum->IsPhantom() &&
pWorkingNodeNum->GetTxtNode() &&
pWorkingNodeNum->GetTxtNode()->HasNumber() ) )
{
aRefNumStr.Insert( MakeNumString( pWorkingNodeNum->GetNumberVector() ), 0 );
}
else if ( aRefNumStr.Len() > 0 )
{
aRefNumStr.Insert( String::CreateFromAscii(" "), 0 );
}
if ( bInclSuperiorNumLabels && pWorkingNodeNum->GetLevelInListTree() > 0 )
{
sal_uInt8 n = Get( static_cast<sal_uInt16>(pWorkingNodeNum->GetLevelInListTree()) ).GetIncludeUpperLevels();
pWorkingNodeNum = dynamic_cast<SwNodeNum*>(pWorkingNodeNum->GetParent());
// skip parents, whose list label is already contained in the actual list label.
while ( pWorkingNodeNum && n > 1 )
{
pWorkingNodeNum = dynamic_cast<SwNodeNum*>(pWorkingNodeNum->GetParent());
--n;
}
}
else
{
break;
}
} while ( pWorkingNodeNum &&
pWorkingNodeNum->GetLevelInListTree() >= 0 &&
static_cast<sal_uInt8>(pWorkingNodeNum->GetLevelInListTree()) >= nRestrictInclToThisLevel );
}
return aRefNumStr;
}
2000-09-18 23:08:29 +00:00
// ----- Copy-Methode vom SwNumRule ------
// eine Art Copy-Constructor, damit die Num-Formate auch an den
// richtigen CharFormaten eines Dokumentes haengen !!
// (Kopiert die NumFormate und returnt sich selbst)
SwNumRule& SwNumRule::CopyNumRule( SwDoc* pDoc, const SwNumRule& rNumRule )
{
for( sal_uInt16 n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
{
Set( n, rNumRule.aFmts[ n ] );
if( aFmts[ n ] && aFmts[ n ]->GetCharFmt() &&
USHRT_MAX == pDoc->GetCharFmts()->GetPos( aFmts[n]->GetCharFmt() ))
// ueber unterschiedliche Dokumente kopieren, dann
// kopiere das entsprechende Char-Format ins neue
// Dokument.
aFmts[n]->SetCharFmt( pDoc->CopyCharFmt( *aFmts[n]->
GetCharFmt() ) );
}
eRuleType = rNumRule.eRuleType;
sName = rNumRule.sName;
bAutoRuleFlag = rNumRule.bAutoRuleFlag;
nPoolFmtId = rNumRule.GetPoolFmtId();
nPoolHelpId = rNumRule.GetPoolHelpId();
nPoolHlpFileId = rNumRule.GetPoolHlpFileId();
bInvalidRuleFlag = sal_True;
2000-09-18 23:08:29 +00:00
return *this;
}
2000-09-18 23:08:29 +00:00
void SwNumRule::SetSvxRule(const SvxNumRule& rNumRule, SwDoc* pDoc)
{
for( sal_uInt16 n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
{
const SvxNumberFormat* pSvxFmt = rNumRule.Get(n);
delete aFmts[n];
aFmts[n] = pSvxFmt ? new SwNumFmt(*pSvxFmt, pDoc) : 0;
}
bInvalidRuleFlag = sal_True;
2000-09-18 23:08:29 +00:00
bContinusNum = rNumRule.IsContinuousNumbering();
}
2000-09-18 23:08:29 +00:00
SvxNumRule SwNumRule::MakeSvxNumRule() const
{
SvxNumRule aRule(NUM_CONTINUOUS|NUM_CHAR_TEXT_DISTANCE|NUM_CHAR_STYLE|
NUM_ENABLE_LINKED_BMP|NUM_ENABLE_EMBEDDED_BMP,
MAXLEVEL, bContinusNum,
2000-09-18 23:08:29 +00:00
eRuleType ==
NUM_RULE ?
SVX_RULETYPE_NUMBERING :
SVX_RULETYPE_OUTLINE_NUMBERING );
for( sal_uInt16 n = 0; n < MAXLEVEL; ++n )
2000-09-18 23:08:29 +00:00
{
SwNumFmt aNumFmt = Get(n);
if(aNumFmt.GetCharFmt())
aNumFmt.SetCharFmtName(aNumFmt.GetCharFmt()->GetName());
aRule.SetLevel(n, aNumFmt, aFmts[n] != 0);
2000-09-18 23:08:29 +00:00
}
return aRule;
}
void SwNumRule::SetInvalidRule(sal_Bool bFlag)
{
if (bFlag)
{
std::set< SwList* > aLists;
tTxtNodeList::iterator aIter;
for ( aIter = maTxtNodeList.begin(); aIter != maTxtNodeList.end(); ++aIter )
{
const SwTxtNode* pTxtNode = *aIter;
2011-02-02 20:41:40 +09:00
// #i111681# - applying patch from cmc
SwList* pList = pTxtNode->GetDoc()->getListByName( pTxtNode->GetListId() );
OSL_ENSURE( pList, "<SwNumRule::SetInvalidRule(..)> - list at which the text node is registered at does not exist. This is a serious issue --> please inform OD.");
if ( pList )
{
aLists.insert( pList );
}
// <--
}
std::for_each( aLists.begin(), aLists.end(),
std::mem_fun( &SwList::InvalidateListTree ) );
// <--
}
bInvalidRuleFlag = bFlag;
}
2000-09-18 23:08:29 +00:00
// change indent of all list levels by given difference
void SwNumRule::ChangeIndent( const short nDiff )
{
for ( sal_uInt16 i = 0; i < MAXLEVEL; ++i )
{
SwNumFmt aTmpNumFmt( Get(i) );
const SvxNumberFormat::SvxNumPositionAndSpaceMode ePosAndSpaceMode(
aTmpNumFmt.GetPositionAndSpaceMode() );
if ( ePosAndSpaceMode == SvxNumberFormat::LABEL_WIDTH_AND_POSITION )
{
short nNewIndent = nDiff +
aTmpNumFmt.GetAbsLSpace();
if ( nNewIndent < 0 )
{
nNewIndent = 0;
}
aTmpNumFmt.SetAbsLSpace( nNewIndent );
}
else if ( ePosAndSpaceMode == SvxNumberFormat::LABEL_ALIGNMENT )
{
CWS-TOOLING: integrate CWS sw31bf04 2009-01-21 14:24:10 +0100 od r266670 : #i59051# correction of metric change for PolyPolygonBezier needed 2009-01-21 09:35:44 +0100 od r266632 : #i96062# adjustment of fix after rebasing 2009-01-21 09:34:56 +0100 od r266631 : #i94152# adjustment of fix after rebasing 2009-01-20 16:43:12 +0100 od r266596 : CWS-TOOLING: rebase CWS sw31bf04 to trunk@266428 (milestone: DEV300:m39) 2009-01-20 11:52:22 +0100 od r266561 : #i94152 method <SwDoc::SetOutlineNumRule(..)> - assure that at outline list style registered text node have the correct list level set 2009-01-20 10:43:53 +0100 od r266556 : #i93399# methods <SwNumRule::SetIndent(..)> and <SwNumRule::ChangeIndent(..)> - adjust also the list tab position, if a list tab stop is applied 2009-01-16 16:26:56 +0100 od r266432 : #i59051# adjust Writer's UNO-API for drawing objects - correct conversion of "StartPosition" and "EndPosition" - conversion of "PolyPolygonBezier" 2009-01-16 16:20:49 +0100 od r266430 : #i59051# - adjust UNO-API of connector shape -- convert "PolyPolygonBezier" to correct metric -- convert "StartPosition" and "EndPosition" in set-method before applying anchor position - adjust UNO-API of measure shape -- convert "StartPosition" and "EndPosition" to correct metric 2009-01-16 15:01:21 +0100 od r266419 : #i95698# method <SwFrm::GetPrevSctLeaf(..)> - only columns as previous section leaves for tables inside sections, which are inside another table. 2009-01-14 14:34:58 +0100 od r266304 : #i96092# method <HandleResetAttrAtTxtNode::~HandleResetAttrAtTxtNode()> - set list level to outline level, if needed. 2009-01-13 17:09:43 +0100 od r266238 : #i98037# method <SwWW8ImplReader::IsObjectLayoutInTableCell(..)> - adjust evaluation of WW8 attributes 2009-01-13 11:49:48 +0100 od r266203 : #i94187# method <SwTxtFormatter::NewTabPortion(..)> - correct consideration of compatibility option TAB_AT_LEFT_INDENT_FOR_PARA_IN_LIST 2009-01-13 11:48:45 +0100 od r266202 : #i94187# method <OutWW8_SwTxtNode(..)> - set list style directly at paragraph only in position and space mode LABEL_WIDTH_AND_POSITION 2009-01-12 12:22:58 +0100 od r266143 : #i70582# method <SwFlyAtCntFrm::SetAbsPos(..)> and local method <lcl_CalcDownDist(..)> - correct determination of anchor's frame top for object positioning.
2009-02-13 10:05:35 +00:00
// adjust also the list tab position, if a list tab stop is applied
if ( aTmpNumFmt.GetLabelFollowedBy() == SvxNumberFormat::LISTTAB )
{
const long nNewListTab = aTmpNumFmt.GetListtabPos() + nDiff;
aTmpNumFmt.SetListtabPos( nNewListTab );
}
2010-10-18 12:57:41 +01:00
CWS-TOOLING: integrate CWS sw31bf04 2009-01-21 14:24:10 +0100 od r266670 : #i59051# correction of metric change for PolyPolygonBezier needed 2009-01-21 09:35:44 +0100 od r266632 : #i96062# adjustment of fix after rebasing 2009-01-21 09:34:56 +0100 od r266631 : #i94152# adjustment of fix after rebasing 2009-01-20 16:43:12 +0100 od r266596 : CWS-TOOLING: rebase CWS sw31bf04 to trunk@266428 (milestone: DEV300:m39) 2009-01-20 11:52:22 +0100 od r266561 : #i94152 method <SwDoc::SetOutlineNumRule(..)> - assure that at outline list style registered text node have the correct list level set 2009-01-20 10:43:53 +0100 od r266556 : #i93399# methods <SwNumRule::SetIndent(..)> and <SwNumRule::ChangeIndent(..)> - adjust also the list tab position, if a list tab stop is applied 2009-01-16 16:26:56 +0100 od r266432 : #i59051# adjust Writer's UNO-API for drawing objects - correct conversion of "StartPosition" and "EndPosition" - conversion of "PolyPolygonBezier" 2009-01-16 16:20:49 +0100 od r266430 : #i59051# - adjust UNO-API of connector shape -- convert "PolyPolygonBezier" to correct metric -- convert "StartPosition" and "EndPosition" in set-method before applying anchor position - adjust UNO-API of measure shape -- convert "StartPosition" and "EndPosition" to correct metric 2009-01-16 15:01:21 +0100 od r266419 : #i95698# method <SwFrm::GetPrevSctLeaf(..)> - only columns as previous section leaves for tables inside sections, which are inside another table. 2009-01-14 14:34:58 +0100 od r266304 : #i96092# method <HandleResetAttrAtTxtNode::~HandleResetAttrAtTxtNode()> - set list level to outline level, if needed. 2009-01-13 17:09:43 +0100 od r266238 : #i98037# method <SwWW8ImplReader::IsObjectLayoutInTableCell(..)> - adjust evaluation of WW8 attributes 2009-01-13 11:49:48 +0100 od r266203 : #i94187# method <SwTxtFormatter::NewTabPortion(..)> - correct consideration of compatibility option TAB_AT_LEFT_INDENT_FOR_PARA_IN_LIST 2009-01-13 11:48:45 +0100 od r266202 : #i94187# method <OutWW8_SwTxtNode(..)> - set list style directly at paragraph only in position and space mode LABEL_WIDTH_AND_POSITION 2009-01-12 12:22:58 +0100 od r266143 : #i70582# method <SwFlyAtCntFrm::SetAbsPos(..)> and local method <lcl_CalcDownDist(..)> - correct determination of anchor's frame top for object positioning.
2009-02-13 10:05:35 +00:00
const long nNewIndent = nDiff +
aTmpNumFmt.GetIndentAt();
aTmpNumFmt.SetIndentAt( nNewIndent );
}
Set( i, aTmpNumFmt );
}
SetInvalidRule( sal_True );
}
// set indent of certain list level to given value
void SwNumRule::SetIndent( const short nNewIndent,
const sal_uInt16 nListLevel )
{
SwNumFmt aTmpNumFmt( Get(nListLevel) );
const SvxNumberFormat::SvxNumPositionAndSpaceMode ePosAndSpaceMode(
aTmpNumFmt.GetPositionAndSpaceMode() );
if ( ePosAndSpaceMode == SvxNumberFormat::LABEL_WIDTH_AND_POSITION )
{
aTmpNumFmt.SetAbsLSpace( nNewIndent );
}
else if ( ePosAndSpaceMode == SvxNumberFormat::LABEL_ALIGNMENT )
{
CWS-TOOLING: integrate CWS sw31bf04 2009-01-21 14:24:10 +0100 od r266670 : #i59051# correction of metric change for PolyPolygonBezier needed 2009-01-21 09:35:44 +0100 od r266632 : #i96062# adjustment of fix after rebasing 2009-01-21 09:34:56 +0100 od r266631 : #i94152# adjustment of fix after rebasing 2009-01-20 16:43:12 +0100 od r266596 : CWS-TOOLING: rebase CWS sw31bf04 to trunk@266428 (milestone: DEV300:m39) 2009-01-20 11:52:22 +0100 od r266561 : #i94152 method <SwDoc::SetOutlineNumRule(..)> - assure that at outline list style registered text node have the correct list level set 2009-01-20 10:43:53 +0100 od r266556 : #i93399# methods <SwNumRule::SetIndent(..)> and <SwNumRule::ChangeIndent(..)> - adjust also the list tab position, if a list tab stop is applied 2009-01-16 16:26:56 +0100 od r266432 : #i59051# adjust Writer's UNO-API for drawing objects - correct conversion of "StartPosition" and "EndPosition" - conversion of "PolyPolygonBezier" 2009-01-16 16:20:49 +0100 od r266430 : #i59051# - adjust UNO-API of connector shape -- convert "PolyPolygonBezier" to correct metric -- convert "StartPosition" and "EndPosition" in set-method before applying anchor position - adjust UNO-API of measure shape -- convert "StartPosition" and "EndPosition" to correct metric 2009-01-16 15:01:21 +0100 od r266419 : #i95698# method <SwFrm::GetPrevSctLeaf(..)> - only columns as previous section leaves for tables inside sections, which are inside another table. 2009-01-14 14:34:58 +0100 od r266304 : #i96092# method <HandleResetAttrAtTxtNode::~HandleResetAttrAtTxtNode()> - set list level to outline level, if needed. 2009-01-13 17:09:43 +0100 od r266238 : #i98037# method <SwWW8ImplReader::IsObjectLayoutInTableCell(..)> - adjust evaluation of WW8 attributes 2009-01-13 11:49:48 +0100 od r266203 : #i94187# method <SwTxtFormatter::NewTabPortion(..)> - correct consideration of compatibility option TAB_AT_LEFT_INDENT_FOR_PARA_IN_LIST 2009-01-13 11:48:45 +0100 od r266202 : #i94187# method <OutWW8_SwTxtNode(..)> - set list style directly at paragraph only in position and space mode LABEL_WIDTH_AND_POSITION 2009-01-12 12:22:58 +0100 od r266143 : #i70582# method <SwFlyAtCntFrm::SetAbsPos(..)> and local method <lcl_CalcDownDist(..)> - correct determination of anchor's frame top for object positioning.
2009-02-13 10:05:35 +00:00
// adjust also the list tab position, if a list tab stop is applied
if ( aTmpNumFmt.GetLabelFollowedBy() == SvxNumberFormat::LISTTAB )
{
const long nNewListTab = aTmpNumFmt.GetListtabPos() +
( nNewIndent - aTmpNumFmt.GetIndentAt() );
aTmpNumFmt.SetListtabPos( nNewListTab );
}
2010-10-18 12:57:41 +01:00
aTmpNumFmt.SetIndentAt( nNewIndent );
}
SetInvalidRule( sal_True );
}
// set indent of first list level to given value and change other list level's
// indents accordingly
void SwNumRule::SetIndentOfFirstListLevelAndChangeOthers( const short nNewIndent )
{
SwNumFmt aTmpNumFmt( Get(0) );
short nDiff( 0 );
const SvxNumberFormat::SvxNumPositionAndSpaceMode ePosAndSpaceMode(
aTmpNumFmt.GetPositionAndSpaceMode() );
if ( ePosAndSpaceMode == SvxNumberFormat::LABEL_WIDTH_AND_POSITION )
{
nDiff = nNewIndent
- aTmpNumFmt.GetFirstLineOffset()
- aTmpNumFmt.GetAbsLSpace();
}
else if ( ePosAndSpaceMode == SvxNumberFormat::LABEL_ALIGNMENT )
{
nDiff = static_cast<short>(nNewIndent
- aTmpNumFmt.GetIndentAt());
}
if ( nDiff != 0 )
{
ChangeIndent( nDiff );
}
}
2010-10-18 12:57:41 +01:00
void SwNumRule::Validate()
{
std::set< SwList* > aLists;
tTxtNodeList::iterator aIter;
for ( aIter = maTxtNodeList.begin(); aIter != maTxtNodeList.end(); ++aIter )
{
const SwTxtNode* pTxtNode = *aIter;
aLists.insert( pTxtNode->GetDoc()->getListByName( pTxtNode->GetListId() ) );
}
std::for_each( aLists.begin(), aLists.end(),
std::mem_fun( &SwList::ValidateListTree ) );
2010-10-18 12:57:41 +01:00
SetInvalidRule(sal_False);
}
2010-10-18 12:57:41 +01:00
bool SwNumRule::IsCountPhantoms() const
{
return mbCountPhantoms;
}
2010-10-18 12:57:41 +01:00
void SwNumRule::SetCountPhantoms(bool bCountPhantoms)
{
mbCountPhantoms = bCountPhantoms;
}
2010-10-18 12:57:41 +01:00
SwNumRule::tParagraphStyleList::size_type SwNumRule::GetParagraphStyleListSize() const
{
return maParagraphStyleList.size();
}
2010-10-18 12:57:41 +01:00
void SwNumRule::AddParagraphStyle( SwTxtFmtColl& rTxtFmtColl )
{
tParagraphStyleList::iterator aIter =
std::find( maParagraphStyleList.begin(), maParagraphStyleList.end(), &rTxtFmtColl );
if ( aIter == maParagraphStyleList.end() )
{
maParagraphStyleList.push_back( &rTxtFmtColl );
}
}
2010-10-18 12:57:41 +01:00
void SwNumRule::RemoveParagraphStyle( SwTxtFmtColl& rTxtFmtColl )
{
tParagraphStyleList::iterator aIter =
std::find( maParagraphStyleList.begin(), maParagraphStyleList.end(), &rTxtFmtColl );
if ( aIter != maParagraphStyleList.end() )
{
maParagraphStyleList.erase( aIter );
}
}
2010-10-18 12:57:41 +01:00
namespace numfunc
{
/** class containing default bullet list configuration data
@author OD
*/
class SwDefBulletConfig : private utl::ConfigItem
{
public:
static SwDefBulletConfig* getInstance()
{
if ( mpInstance == 0 )
{
mpInstance = new SwDefBulletConfig;
}
return mpInstance;
}
inline const String& GetFontname() const
{
return msFontname;
}
2010-10-18 12:57:41 +01:00
2008-10-10 13:02:43 +00:00
inline bool IsFontnameUserDefined() const
{
return mbUserDefinedFontname;
}
2010-10-18 12:57:41 +01:00
inline const Font& GetFont() const
{
return *mpFont;
}
2010-10-18 12:57:41 +01:00
2008-10-10 13:02:43 +00:00
inline short GetFontWeight() const
{
return static_cast<short>(meFontWeight);
}
2010-10-18 12:57:41 +01:00
2008-10-10 13:02:43 +00:00
inline short GetFontItalic() const
{
return static_cast<short>(meFontItalic);
}
inline sal_Unicode GetChar( sal_uInt8 p_nListLevel ) const
{
if ( p_nListLevel > MAXLEVEL )
{
p_nListLevel = MAXLEVEL;
}
return mnLevelChars[p_nListLevel];
}
private:
SwDefBulletConfig();
/** sets internal default bullet configuration data to default values
@author OD
*/
void SetToDefault();
/** returns sequence of default bullet configuration property names
@author OD
*/
uno::Sequence<rtl::OUString> GetPropNames() const;
/** loads default bullet configuration properties and applies
values to internal data
@author OD
*/
void LoadConfig();
/** initialize font instance for default bullet list
@author OD
*/
void InitFont();
/** catches notification about changed default bullet configuration data
@author OD
*/
virtual void Notify( const uno::Sequence<rtl::OUString>& aPropertyNames );
virtual void Commit();
static SwDefBulletConfig* mpInstance;
// default bullet list configuration data
String msFontname;
bool mbUserDefinedFontname;
FontWeight meFontWeight;
FontItalic meFontItalic;
sal_Unicode mnLevelChars[MAXLEVEL];
// default bullet list font instance
Font* mpFont;
};
SwDefBulletConfig* SwDefBulletConfig::mpInstance = 0;
SwDefBulletConfig::SwDefBulletConfig()
2010-10-27 11:38:46 +01:00
: ConfigItem( rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Office.Writer/Numbering/DefaultBulletList")) ),
// default bullet font is now OpenSymbol
msFontname( String::CreateFromAscii("OpenSymbol") ),
mbUserDefinedFontname( false ),
meFontWeight( WEIGHT_DONTKNOW ),
meFontItalic( ITALIC_NONE ),
mpFont( 0 )
{
SetToDefault();
LoadConfig();
InitFont();
// enable notification for changes on default bullet configuration change
EnableNotification( GetPropNames() );
}
void SwDefBulletConfig::SetToDefault()
{
msFontname = String::CreateFromAscii("OpenSymbol");
mbUserDefinedFontname = false;
// <--
meFontWeight = WEIGHT_DONTKNOW;
meFontItalic = ITALIC_NONE;
mnLevelChars[0] = 0x2022;
mnLevelChars[1] = 0x25e6;
mnLevelChars[2] = 0x25aa;
mnLevelChars[3] = 0x2022;
mnLevelChars[4] = 0x25e6;
mnLevelChars[5] = 0x25aa;
mnLevelChars[6] = 0x2022;
mnLevelChars[7] = 0x25e6;
mnLevelChars[8] = 0x25aa;
mnLevelChars[9] = 0x2022;
}
uno::Sequence<rtl::OUString> SwDefBulletConfig::GetPropNames() const
{
uno::Sequence<rtl::OUString> aPropNames(13);
rtl::OUString* pNames = aPropNames.getArray();
2010-10-27 11:38:46 +01:00
pNames[0] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletFont/FontFamilyname"));
pNames[1] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletFont/FontWeight"));
pNames[2] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletFont/FontItalic"));
pNames[3] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl1"));
pNames[4] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl2"));
pNames[5] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl3"));
pNames[6] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl4"));
pNames[7] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl5"));
pNames[8] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl6"));
pNames[9] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl7"));
pNames[10] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl8"));
pNames[11] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl9"));
pNames[12] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("BulletCharLvl10"));
return aPropNames;
}
void SwDefBulletConfig::LoadConfig()
{
uno::Sequence<rtl::OUString> aPropNames = GetPropNames();
uno::Sequence<uno::Any> aValues =
GetProperties( aPropNames );
const uno::Any* pValues = aValues.getConstArray();
OSL_ENSURE( aValues.getLength() == aPropNames.getLength(),
"<SwDefBulletConfig::SwDefBulletConfig()> - GetProperties failed");
if ( aValues.getLength() == aPropNames.getLength() )
{
for ( int nProp = 0; nProp < aPropNames.getLength(); ++nProp )
{
if ( pValues[nProp].hasValue() )
{
switch ( nProp )
{
case 0:
{
rtl::OUString aStr;
pValues[nProp] >>= aStr;
msFontname = aStr;
mbUserDefinedFontname = true;
}
break;
case 1:
case 2:
{
sal_uInt8 nTmp = 0;
pValues[nProp] >>= nTmp;
if ( nProp == 1 )
meFontWeight = static_cast<FontWeight>(nTmp);
else if ( nProp == 2 )
meFontItalic = static_cast<FontItalic>(nTmp);
}
break;
case 3:
case 4:
case 5:
case 6:
case 7:
case 8:
case 9:
case 10:
case 11:
case 12:
{
sal_Unicode cChar = sal_Unicode();
pValues[nProp] >>= cChar;
mnLevelChars[nProp-3] = cChar;
}
break;
}
}
}
}
}
void SwDefBulletConfig::InitFont()
{
delete mpFont;
mpFont = new Font( msFontname, aEmptyStr, Size( 0, 14 ) );
mpFont->SetWeight( meFontWeight );
mpFont->SetItalic( meFontItalic );
}
void SwDefBulletConfig::Notify( const uno::Sequence<rtl::OUString>& )
{
SetToDefault();
LoadConfig();
InitFont();
}
void SwDefBulletConfig::Commit()
{
}
const String& GetDefBulletFontname()
{
return SwDefBulletConfig::getInstance()->GetFontname();
}
2008-10-10 13:02:43 +00:00
bool IsDefBulletFontUserDefined()
{
return SwDefBulletConfig::getInstance()->IsFontnameUserDefined();
}
const Font& GetDefBulletFont()
{
return SwDefBulletConfig::getInstance()->GetFont();
}
sal_Unicode GetBulletChar( sal_uInt8 nLevel )
{
return SwDefBulletConfig::getInstance()->GetChar( nLevel );
}
/** class containing configuration data about user interface behavior
regarding lists and list items.
configuration item about behavior of <TAB>/<SHIFT-TAB>-key at first
position of first list item
@author OD
*/
class SwNumberingUIBehaviorConfig : private utl::ConfigItem
{
public:
static SwNumberingUIBehaviorConfig* getInstance()
{
if ( mpInstance == 0 )
{
mpInstance = new SwNumberingUIBehaviorConfig();
}
return mpInstance;
}
2008-10-10 13:02:43 +00:00
inline sal_Bool ChangeIndentOnTabAtFirstPosOfFirstListItem() const
{
return mbChangeIndentOnTabAtFirstPosOfFirstListItem;
}
private:
SwNumberingUIBehaviorConfig();
/** sets internal configuration data to default values
@author OD
*/
void SetToDefault();
/** returns sequence of configuration property names
@author OD
*/
com::sun::star::uno::Sequence<rtl::OUString> GetPropNames() const;
/** loads configuration properties and applies values to internal data
@author OD
*/
void LoadConfig();
/** catches notification about changed configuration data
@author OD
*/
virtual void Notify( const com::sun::star::uno::Sequence<rtl::OUString>& aPropertyNames );
virtual void Commit();
static SwNumberingUIBehaviorConfig* mpInstance;
// configuration data
sal_Bool mbChangeIndentOnTabAtFirstPosOfFirstListItem;
};
SwNumberingUIBehaviorConfig* SwNumberingUIBehaviorConfig::mpInstance = 0;
SwNumberingUIBehaviorConfig::SwNumberingUIBehaviorConfig()
2010-10-27 11:38:46 +01:00
: ConfigItem( rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Office.Writer/Numbering/UserInterfaceBehavior")) ),
mbChangeIndentOnTabAtFirstPosOfFirstListItem( sal_True )
{
SetToDefault();
LoadConfig();
// enable notification for changes on configuration change
EnableNotification( GetPropNames() );
}
void SwNumberingUIBehaviorConfig::SetToDefault()
{
mbChangeIndentOnTabAtFirstPosOfFirstListItem = sal_True;
}
com::sun::star::uno::Sequence<rtl::OUString> SwNumberingUIBehaviorConfig::GetPropNames() const
{
com::sun::star::uno::Sequence<rtl::OUString> aPropNames(1);
rtl::OUString* pNames = aPropNames.getArray();
2010-10-27 11:38:46 +01:00
pNames[0] = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ChangeIndentOnTabAtFirstPosOfFirstListItem"));
return aPropNames;
}
void SwNumberingUIBehaviorConfig::Commit() {}
void SwNumberingUIBehaviorConfig::LoadConfig()
{
com::sun::star::uno::Sequence<rtl::OUString> aPropNames = GetPropNames();
com::sun::star::uno::Sequence<com::sun::star::uno::Any> aValues =
GetProperties( aPropNames );
const com::sun::star::uno::Any* pValues = aValues.getConstArray();
OSL_ENSURE( aValues.getLength() == aPropNames.getLength(),
"<SwNumberingUIBehaviorConfig::LoadConfig()> - GetProperties failed");
if ( aValues.getLength() == aPropNames.getLength() )
{
for ( int nProp = 0; nProp < aPropNames.getLength(); ++nProp )
{
if ( pValues[nProp].hasValue() )
{
switch ( nProp )
{
case 0:
{
pValues[nProp] >>= mbChangeIndentOnTabAtFirstPosOfFirstListItem;
}
break;
default:
{
OSL_FAIL( "<SwNumberingUIBehaviorConfig::LoadConfig()> - unknown configuration property");
}
}
}
}
}
}
void SwNumberingUIBehaviorConfig::Notify( const com::sun::star::uno::Sequence<rtl::OUString>& aPropertyNames )
{
2007-10-18 09:47:45 +00:00
(void) aPropertyNames;
SetToDefault();
LoadConfig();
}
2008-10-10 13:02:43 +00:00
sal_Bool ChangeIndentOnTabAtFirstPosOfFirstListItem()
{
return SwNumberingUIBehaviorConfig::getInstance()->ChangeIndentOnTabAtFirstPosOfFirstListItem();
}
2008-10-10 13:02:43 +00:00
SvxNumberFormat::SvxNumPositionAndSpaceMode GetDefaultPositionAndSpaceMode()
{
SvxNumberFormat::SvxNumPositionAndSpaceMode ePosAndSpaceMode;
SvtSaveOptions aSaveOptions;
switch ( aSaveOptions.GetODFDefaultVersion() )
{
case SvtSaveOptions::ODFVER_010:
case SvtSaveOptions::ODFVER_011:
{
ePosAndSpaceMode = SvxNumberFormat::LABEL_WIDTH_AND_POSITION;
}
break;
default: // ODFVER_UNKNOWN or ODFVER_012
{
ePosAndSpaceMode = SvxNumberFormat::LABEL_ALIGNMENT;
}
}
return ePosAndSpaceMode;
}
// <--
}
// <--
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */