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

755 lines
25 KiB
C++
Raw Normal View History

2000-09-18 23:08:29 +00:00
/*************************************************************************
*
* $RCSfile: number.cxx,v $
*
2003-09-05 14:13:51 +00:00
* $Revision: 1.11 $
2000-09-18 23:08:29 +00:00
*
2003-09-05 14:13:51 +00:00
* last change: $Author: hbrinkm $ $Date: 2003-09-05 15:11:10 $
2000-09-18 23:08:29 +00:00
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (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.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#pragma hdrstop
#ifndef _HINTIDS_HXX
#include <hintids.hxx>
#endif
#include <string.h>
#ifndef _SV_FONT_HXX //autogen
#include <vcl/font.hxx>
#endif
#ifndef _SVX_BRSHITEM_HXX //autogen
#include <svx/brshitem.hxx>
#endif
#ifndef _SVX_LRSPITEM_HXX //autogen
#include <svx/lrspitem.hxx>
#endif
#ifndef _SVX_NUMITEM_HXX //autogen
#include <svx/numitem.hxx>
#endif
#ifndef _FMTORNT_HXX //autogen
#include <fmtornt.hxx>
#endif
#ifndef _DOC_HXX
#include <doc.hxx>
#endif
#ifndef _PAM_HXX
#include <pam.hxx>
#endif
#ifndef _CHARFMT_HXX
#include <charfmt.hxx>
#endif
#ifndef _PARATR_HXX
#include <paratr.hxx>
#endif
#ifndef _FRMFMT_HXX
#include <frmfmt.hxx>
#endif
#ifndef _NDTXT_HXX
#include <ndtxt.hxx>
#endif
#ifndef _HINTS_HXX
#include <hints.hxx>
#endif
#ifndef _NUMRULE_HXX
#include <numrule.hxx>
#endif
#ifndef _DOCARY_HXX
#include <docary.hxx>
#endif
#ifndef _DOCSH_HXX
#include <docsh.hxx>
#endif
#ifndef _SWSTYLENAMEMAPPER_HXX
#include <SwStyleNameMapper.hxx>
#endif
2000-09-18 23:08:29 +00:00
USHORT SwNumRule::nRefCount = 0;
SwNumFmt* SwNumRule::aBaseFmts[ RULE_END ][ MAXLEVEL ] = {
0, 0, 0, 0, 0,
0, 0, 0, 0, 0 };
Font* SwNumRule::pDefBulletFont = 0;
sal_Char* SwNumRule::pDefOutlineName = "Outline";
USHORT SwNumRule::aDefNumIndents[ MAXLEVEL ] = {
//cm: 0,5 1,0 1,5 2,0 2,5 3,0 3,5 4,0 4,5 5,0
283, 567, 850, 1134, 1417, 1701, 1984, 2268, 2551, 2835
};
#if defined( UNX ) && defined( GCC )
2000-09-18 23:08:29 +00:00
extern const sal_Char __FAR_DATA sBulletFntName[];
const sal_Char __FAR_DATA sBulletFntName[] = "StarSymbol";
2000-09-18 23:08:29 +00:00
#else
extern const sal_Char __FAR_DATA sBulletFntName[] = "StarSymbol";
2000-09-18 23:08:29 +00:00
#endif
inline void lcl_SetRuleChgd( SwTxtNode& rNd, BYTE nLevel )
2000-09-18 23:08:29 +00:00
{
if( rNd.GetNum() &&
(~NO_NUMLEVEL & rNd.GetNum()->GetLevel() ) == nLevel )
rNd.NumRuleChgd();
2000-09-18 23:08:29 +00:00
}
/* -----------------------------22.02.01 13:41--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
SwNumFmt::SwNumFmt() :
SwClient( 0 ),
SvxNumberFormat(SVX_NUM_ARABIC),
pVertOrient(new SwFmtVertOrient( 0, VERT_NONE))
2000-09-18 23:08:29 +00:00
{
}
/* -----------------------------22.02.01 13:42--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
SwNumFmt::SwNumFmt( const SwNumFmt& rFmt) :
SwClient( rFmt.pRegisteredIn ),
SvxNumberFormat(rFmt),
pVertOrient(new SwFmtVertOrient( 0, (SwVertOrient)rFmt.GetVertOrient()))
2000-09-18 23:08:29 +00:00
{
SvxFrameVertOrient eVertOrient = rFmt.GetVertOrient();
SetGraphicBrush( rFmt.GetBrush(), &rFmt.GetGraphicSize(),
&eVertOrient);
2000-09-18 23:08:29 +00:00
}
/* -----------------------------22.02.01 13:58--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
SwNumFmt::SwNumFmt(const SvxNumberFormat& rNumFmt, SwDoc* pDoc) :
SvxNumberFormat(rNumFmt),
pVertOrient(new SwFmtVertOrient( 0, (SwVertOrient)rNumFmt.GetVertOrient()))
2000-09-18 23:08:29 +00:00
{
SvxFrameVertOrient eVertOrient = rNumFmt.GetVertOrient();
SetGraphicBrush( rNumFmt.GetBrush(), &rNumFmt.GetGraphicSize(),
&eVertOrient);
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
{
USHORT nId = SwStyleNameMapper::GetPoolIdFromUIName( rCharStyleName,
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() )
pRegisteredIn->Remove( this );
2000-09-18 23:08:29 +00:00
}
/* -----------------------------22.02.01 13:42--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
SwNumFmt::~SwNumFmt()
{
delete pVertOrient;
}
/* -----------------------------02.07.01 15:37--------------------------------
---------------------------------------------------------------------------*/
void SwNumFmt::NotifyGraphicArrived()
{
if( GetCharFmt() )
UpdateNumNodes( (SwDoc*)GetCharFmt()->GetDoc() );
}
/* -----------------------------23.02.01 09:28--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
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.pRegisteredIn->Add( this );
else if( GetRegisteredIn() )
pRegisteredIn->Remove( this );
return *this;
}
/* -----------------------------23.02.01 09:28--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
BOOL SwNumFmt::operator==( const SwNumFmt& rNumFmt) const
2000-09-18 23:08:29 +00:00
{
BOOL bRet = SvxNumberFormat::operator==(rNumFmt) &&
pRegisteredIn == rNumFmt.pRegisteredIn;
2000-09-18 23:08:29 +00:00
return bRet;
}
/* -----------------------------22.02.01 13:42--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
const Graphic* SwNumFmt::GetGraphic() const
{
const Graphic* pGrf = 0;
if( GetBrush() && GetCharFmt() )
pGrf = GetBrush()->GetGraphic( GetCharFmt()->GetDoc()->GetDocShell() );
return pGrf;
}
/* -----------------------------22.02.01 13:44--------------------------------
---------------------------------------------------------------------------*/
void SwNumFmt::SetCharFmt( SwCharFmt* pChFmt)
2000-09-18 23:08:29 +00:00
{
if( pChFmt )
pChFmt->Add( this );
else if( GetRegisteredIn() )
pRegisteredIn->Remove( this );
}
/* -----------------------------22.02.01 13:45--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
2000-09-18 23:08:29 +00:00
void SwNumFmt::Modify( SfxPoolItem* pOld, SfxPoolItem* pNew )
{
// 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;
switch( pOld ? pOld->Which() : pNew ? pNew->Which() : 0 )
{
case RES_ATTRSET_CHG:
case RES_FMT_CHG:
pFmt = GetCharFmt();
break;
}
if( pFmt && !pFmt->GetDoc()->IsInDtor() )
UpdateNumNodes( (SwDoc*)pFmt->GetDoc() );
else
SwClient::Modify( pOld, pNew );
}
/* -----------------------------23.02.01 11:08--------------------------------
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
}
/* -----------------------------22.02.01 13:47--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
const String& SwNumFmt::GetCharFmtName() const
{
if((SwCharFmt*)pRegisteredIn)
return ((SwCharFmt*)pRegisteredIn)->GetName();
else
return aEmptyStr;
}
/* -----------------------------22.02.01 16:05--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
void SwNumFmt::SetGraphicBrush( const SvxBrushItem* pBrushItem, const Size* pSize,
const SvxFrameVertOrient* pOrient)
2000-09-18 23:08:29 +00:00
{
if(pOrient)
pVertOrient->SetVertOrient( (SwVertOrient)*pOrient );
SvxNumberFormat::SetGraphicBrush( pBrushItem, pSize, pOrient);
}
/* -----------------------------22.02.01 16:05--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
void SwNumFmt::SetVertOrient(SvxFrameVertOrient eSet)
{
SvxNumberFormat::SetVertOrient(eSet);
2000-09-18 23:08:29 +00:00
}
/* -----------------------------22.02.01 16:05--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
SvxFrameVertOrient SwNumFmt::GetVertOrient() const
2000-09-18 23:08:29 +00:00
{
return SvxNumberFormat::GetVertOrient();
2000-09-18 23:08:29 +00:00
}
/* -----------------------------22.02.01 13:54--------------------------------
2000-09-18 23:08:29 +00:00
---------------------------------------------------------------------------*/
2000-09-18 23:08:29 +00:00
void SwNumFmt::UpdateNumNodes( SwDoc* pDoc )
{
BOOL bDocIsModified = pDoc->IsModified();
BOOL bFnd = FALSE;
const SwNumRule* pRule;
for( USHORT n = pDoc->GetNumRuleTbl().Count(); !bFnd && n; )
{
pRule = pDoc->GetNumRuleTbl()[ --n ];
for( BYTE i = 0; i < MAXLEVEL; ++i )
if( pRule->GetNumFmt( i ) == this )
{
const String& rRuleNm = pRule->GetName();
SwModify* pMod;
const SfxPoolItem* pItem;
USHORT k, nMaxItems = pDoc->GetAttrPool().GetItemCount(
RES_PARATR_NUMRULE );
for( k = 0; k < nMaxItems; ++k )
if( 0 != (pItem = pDoc->GetAttrPool().GetItem(
RES_PARATR_NUMRULE, k ) ) &&
0 != ( pMod = (SwModify*)((SwNumRuleItem*)pItem)->
GetDefinedIn()) &&
((SwNumRuleItem*)pItem)->GetValue() == rRuleNm )
{
if( pMod->IsA( TYPE( SwFmt )) )
{
SwNumRuleInfo aInfo( rRuleNm );
pMod->GetInfo( aInfo );
for( ULONG nFirst = 0, nLast = aInfo.GetList().Count();
nFirst < nLast; ++nFirst )
lcl_SetRuleChgd(
*aInfo.GetList().GetObject( nFirst ), i );
}
else if( ((SwTxtNode*)pMod)->GetNodes().IsDocNodes() )
lcl_SetRuleChgd( *(SwTxtNode*)pMod, i );
}
bFnd = TRUE;
break;
}
}
if( !bFnd )
{
pRule = pDoc->GetOutlineNumRule();
for( BYTE i = 0; i < MAXLEVEL; ++i )
if( pRule->GetNumFmt( i ) == this )
{
ULONG nStt = pDoc->GetNodes().GetEndOfContent().StartOfSectionIndex();
const SwTxtFmtColls& rColls = *pDoc->GetTxtFmtColls();
for( USHORT n = 1; n < rColls.Count(); ++n )
{
const SwTxtFmtColl* pColl = rColls[ n ];
if( i == pColl->GetOutlineLevel() )
{
SwClientIter aIter( *(SwTxtFmtColl*)pColl );
for( SwTxtNode* pNd = (SwTxtNode*)aIter.First( TYPE( SwTxtNode ));
pNd; pNd = (SwTxtNode*)aIter.Next() )
if( pNd->GetNodes().IsDocNodes() &&
nStt < pNd->GetIndex() &&
pNd->GetOutlineNum() && i == (~NO_NUMLEVEL &
pNd->GetOutlineNum()->GetLevel() ) )
pNd->NumRuleChgd();
break;
}
}
bFnd = TRUE;
break;
}
}
if( bFnd && !bDocIsModified )
pDoc->ResetModified();
}
/* -----------------------------31.05.01 16:08--------------------------------
---------------------------------------------------------------------------*/
const SwFmtVertOrient* SwNumFmt::GetGraphicOrientation() const
{
SvxFrameVertOrient eOrient = SvxNumberFormat::GetVertOrient();
if(SVX_VERT_NONE == eOrient)
return 0;
else
{
pVertOrient->SetVertOrient((SwVertOrient)eOrient);
return pVertOrient;
}
}
2000-09-18 23:08:29 +00:00
BOOL SwNodeNum::operator==( const SwNodeNum& rNum ) const
{
2003-09-05 14:13:51 +00:00
return
nMyLevel == rNum.nMyLevel &&
nSetValue == rNum.nSetValue &&
bStartNum == rNum.bStartNum &&
bContNum == rNum.bContNum && // #111955#
( nMyLevel >= MAXLEVEL ||
0 == memcmp( nLevelVal, rNum.nLevelVal,
sizeof( USHORT ) * (nMyLevel+1) ));
2000-09-18 23:08:29 +00:00
}
SwNumRule::SwNumRule( const String& rNm, SwNumRuleType eType, BOOL bAutoFlg )
: eRuleType( eType ),
sName( rNm ),
bAutoRuleFlag( bAutoFlg ),
bInvalidRuleFlag( TRUE ),
bContinusNum( FALSE ),
bAbsSpaces( FALSE ),
nPoolFmtId( USHRT_MAX ),
nPoolHelpId( USHRT_MAX ),
nPoolHlpFileId( UCHAR_MAX )
{
if( !nRefCount++ ) // zum erstmal, also initialisiern
{
SwNumFmt* pFmt;
// Nummerierung:
for( int n = 0; n < MAXLEVEL; ++n )
{
pFmt = new SwNumFmt;
pFmt->SetIncludeUpperLevels( 1 );
pFmt->SetStart( 1 );
2000-09-18 23:08:29 +00:00
pFmt->SetLSpace( lNumIndent );
pFmt->SetAbsLSpace( SwNumRule::GetNumIndent( n ) );
pFmt->SetFirstLineOffset( lNumFirstLineOffset );
pFmt->SetSuffix( aDotStr );
2000-09-18 23:08:29 +00:00
SwNumRule::aBaseFmts[ NUM_RULE ][ n ] = pFmt;
}
// Gliederung:
for( n = 0; n < MAXLEVEL; ++n )
{
pFmt = new SwNumFmt;
//JP 18.01.96: heute soll es mal wieder vollstaendig numeriert werden
//JP 10.03.96: und nun mal wieder nicht
pFmt->SetNumberingType(SVX_NUM_NUMBER_NONE);
pFmt->SetIncludeUpperLevels( MAXLEVEL );
2000-09-18 23:08:29 +00:00
// pFmt->eType = ARABIC;
pFmt->SetStart( 1 );
2000-09-18 23:08:29 +00:00
SwNumRule::aBaseFmts[ OUTLINE_RULE ][ n ] = pFmt;
}
}
memset( aFmts, 0, sizeof( aFmts ));
ASSERT( sName.Len(), "NumRule ohne Namen!" );
}
SwNumRule::SwNumRule( const SwNumRule& rNumRule )
: eRuleType( rNumRule.eRuleType ),
sName( rNumRule.sName ),
bAutoRuleFlag( rNumRule.bAutoRuleFlag ),
bInvalidRuleFlag( TRUE ),
bContinusNum( rNumRule.bContinusNum ),
bAbsSpaces( rNumRule.bAbsSpaces ),
nPoolFmtId( rNumRule.GetPoolFmtId() ),
nPoolHelpId( rNumRule.GetPoolHelpId() ),
nPoolHlpFileId( rNumRule.GetPoolHlpFileId() )
{
++nRefCount;
memset( aFmts, 0, sizeof( aFmts ));
for( USHORT n = 0; n < MAXLEVEL; ++n )
if( rNumRule.aFmts[ n ] )
Set( n, *rNumRule.aFmts[ n ] );
}
SwNumRule::~SwNumRule()
{
for( USHORT n = 0; n < MAXLEVEL; ++n )
delete aFmts[ n ];
if( !--nRefCount ) // der letzte macht die Tuer zu
{
// Nummerierung:
SwNumFmt** ppFmts = (SwNumFmt**)SwNumRule::aBaseFmts;
for( int n = 0; n < MAXLEVEL; ++n, ++ppFmts )
delete *ppFmts, *ppFmts = 0;
// Gliederung:
for( n = 0; n < MAXLEVEL; ++n, ++ppFmts )
delete *ppFmts, *ppFmts = 0;
}
}
void SwNumRule::_MakeDefBulletFont()
{
pDefBulletFont = new Font( String::CreateFromAscii( sBulletFntName ),
aEmptyStr, Size( 0, 14 ) );
pDefBulletFont->SetCharSet( RTL_TEXTENCODING_SYMBOL );
pDefBulletFont->SetFamily( FAMILY_DONTKNOW );
pDefBulletFont->SetPitch( PITCH_DONTKNOW );
pDefBulletFont->SetWeight( WEIGHT_DONTKNOW );
pDefBulletFont->SetTransparent( TRUE );
}
void SwNumRule::CheckCharFmts( SwDoc* pDoc )
{
SwCharFmt* pFmt;
for( BYTE n = 0; n < MAXLEVEL; ++n )
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;
}
}
// setzt Num oder NoNum fuer den Level am TextNode UND setzt die
// richtige Attributierung
BOOL SwNumRule::IsRuleLSpace( SwTxtNode& rNd ) const
{
const SfxPoolItem* pItem;
BYTE nLvl;
const SwAttrSet* pASet = rNd.GetpSwAttrSet();
BOOL bRet = rNd.GetNum() && pASet && SFX_ITEM_SET == pASet->GetItemState(
RES_LR_SPACE, FALSE, &pItem ) && ( nLvl = (~NO_NUMLEVEL &
rNd.GetNum()->GetLevel() )) < MAXLEVEL &&
Get( nLvl ).GetAbsLSpace() == ((SvxLRSpaceItem*)pItem)->GetTxtLeft();
return bRet;
}
SwNumRule& SwNumRule::operator=( const SwNumRule& rNumRule )
{
if( this != &rNumRule )
{
for( USHORT n = 0; n < MAXLEVEL; ++n )
Set( n, rNumRule.aFmts[ n ] );
eRuleType = rNumRule.eRuleType;
sName = rNumRule.sName;
bAutoRuleFlag = rNumRule.bAutoRuleFlag;
bInvalidRuleFlag = TRUE;
bContinusNum = rNumRule.bContinusNum;
bAbsSpaces = rNumRule.bAbsSpaces;
nPoolFmtId = rNumRule.GetPoolFmtId();
nPoolHelpId = rNumRule.GetPoolHelpId();
nPoolHlpFileId = rNumRule.GetPoolHlpFileId();
}
return *this;
}
BOOL SwNumRule::operator==( const SwNumRule& rRule ) const
{
BOOL bRet = eRuleType == rRule.eRuleType &&
sName == rRule.sName &&
bAutoRuleFlag == rRule.bAutoRuleFlag &&
bContinusNum == rRule.bContinusNum &&
bAbsSpaces == rRule.bAbsSpaces &&
nPoolFmtId == rRule.GetPoolFmtId() &&
nPoolHelpId == rRule.GetPoolHelpId() &&
nPoolHlpFileId == rRule.GetPoolHlpFileId();
if( bRet )
{
for( BYTE n = 0; n < MAXLEVEL; ++n )
if( !( rRule.Get( n ) == Get( n ) ))
{
bRet = FALSE;
break;
}
}
return bRet;
}
void SwNumRule::Set( USHORT i, const SwNumFmt& rNumFmt )
{
if( !aFmts[ i ] || !(rNumFmt == Get( i )) )
{
delete aFmts[ i ];
aFmts[ i ] = new SwNumFmt( rNumFmt );
bInvalidRuleFlag = TRUE;
}
}
void SwNumRule::Set( USHORT i, const SwNumFmt* pNumFmt )
{
SwNumFmt* pOld = aFmts[ i ];
if( !pOld )
{
if( pNumFmt )
{
aFmts[ i ] = new SwNumFmt( *pNumFmt );
bInvalidRuleFlag = TRUE;
}
}
else if( !pNumFmt )
delete pOld, aFmts[ i ] = 0, bInvalidRuleFlag = TRUE;
else if( *pOld != *pNumFmt )
*pOld = *pNumFmt, bInvalidRuleFlag = TRUE;
}
String SwNumRule::MakeNumString( const SwNodeNum& rNum, BOOL bInclStrings,
BOOL bOnlyArabic ) const
{
String aStr;
if( NO_NUM > rNum.GetLevel() && !( NO_NUMLEVEL & rNum.GetLevel() ) )
{
const SwNumFmt& rMyNFmt = Get( rNum.GetLevel() );
if( SVX_NUM_NUMBER_NONE != rMyNFmt.GetNumberingType() )
2000-09-18 23:08:29 +00:00
{
BYTE i = rNum.GetLevel();
if( !IsContinusNum() &&
rMyNFmt.GetIncludeUpperLevels() ) // nur der eigene Level ?
2000-09-18 23:08:29 +00:00
{
BYTE 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 <= rNum.GetLevel(); ++i )
{
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;
continue;
}
if( rNum.GetLevelVal()[ i ] )
{
if( bOnlyArabic )
aStr += String::CreateFromInt32( rNum.GetLevelVal()[ i ] );
else
aStr += rNFmt.GetNumStr( rNum.GetLevelVal()[ i ] );
}
else
aStr += '0'; // alle 0-Level sind eine 0
if( i != rNum.GetLevel() && aStr.Len() )
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() )
2000-09-18 23:08:29 +00:00
{
aStr.Insert( rMyNFmt.GetPrefix(), 0 );
aStr += rMyNFmt.GetSuffix();
2000-09-18 23:08:29 +00:00
}
}
return aStr;
}
// ----- 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( USHORT n = 0; n < MAXLEVEL; ++n )
{
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 = TRUE;
return *this;
}
/* -----------------30.10.98 08:33-------------------
*
* --------------------------------------------------*/
void SwNumRule::SetSvxRule(const SvxNumRule& rNumRule, SwDoc* pDoc)
{
for( USHORT n = 0; n < MAXLEVEL; ++n )
{
const SvxNumberFormat* pSvxFmt = rNumRule.Get(n);
delete aFmts[n];
aFmts[n] = pSvxFmt ? new SwNumFmt(*pSvxFmt, pDoc) : 0;
}
// eRuleType = rNumRule.eRuleType;
// sName = rNumRule.sName;
// bAutoRuleFlag = rNumRule.bAutoRuleFlag;
bInvalidRuleFlag = TRUE;
bContinusNum = rNumRule.IsContinuousNumbering();
//!!! bAbsSpaces = rNumRule.IsAbsSpaces();
}
/* -----------------30.10.98 08:33-------------------
*
* --------------------------------------------------*/
SvxNumRule SwNumRule::MakeSvxNumRule() const
{
SvxNumRule aRule(NUM_CONTINUOUS|NUM_CHAR_TEXT_DISTANCE|NUM_CHAR_STYLE|
NUM_ENABLE_LINKED_BMP|NUM_ENABLE_EMBEDDED_BMP,
MAXLEVEL,
eRuleType ==
NUM_RULE ?
SVX_RULETYPE_NUMBERING :
SVX_RULETYPE_OUTLINE_NUMBERING );
aRule.SetContinuousNumbering(bContinusNum);
//!!! aRule.SetAbsSpaces( bAbsSpaces );
for( USHORT n = 0; n < MAXLEVEL; ++n )
{
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;
}
/* #109308# */
void SwNumRule::SetNumAdjust(SvxAdjust eNumAdjust)
{
for (int i = 0; i < MAXLEVEL; i++)
aFmts[i]->SetNumAdjust(eNumAdjust);
}