2000-09-18 23:08:29 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: number.cxx,v $
|
|
|
|
*
|
2005-03-23 10:51:45 +00:00
|
|
|
* $Revision: 1.29 $
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2005-03-23 10:51:45 +00:00
|
|
|
* last change: $Author: vg $ $Date: 2005-03-23 11:51:45 $
|
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
|
2001-07-20 09:40:14 +00:00
|
|
|
#ifndef _SWSTYLENAMEMAPPER_HXX
|
|
|
|
#include <SwStyleNameMapper.hxx>
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2004-10-22 07:12:03 +00:00
|
|
|
#include <hash_map>
|
|
|
|
|
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";
|
|
|
|
|
2004-07-05 13:39:02 +00:00
|
|
|
// #i30312#
|
2000-09-18 23:08:29 +00:00
|
|
|
USHORT SwNumRule::aDefNumIndents[ MAXLEVEL ] = {
|
2004-07-05 13:39:02 +00:00
|
|
|
//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
|
|
|
};
|
|
|
|
|
2001-07-20 18:33:33 +00:00
|
|
|
#if defined( UNX ) && defined( GCC )
|
2000-09-18 23:08:29 +00:00
|
|
|
extern const sal_Char __FAR_DATA sBulletFntName[];
|
2001-07-20 18:33:33 +00:00
|
|
|
const sal_Char __FAR_DATA sBulletFntName[] = "StarSymbol";
|
2000-09-18 23:08:29 +00:00
|
|
|
#else
|
2001-07-20 18:33:33 +00:00
|
|
|
extern const sal_Char __FAR_DATA sBulletFntName[] = "StarSymbol";
|
2000-09-18 23:08:29 +00:00
|
|
|
#endif
|
|
|
|
|
2004-03-08 11:24:46 +00:00
|
|
|
|
2004-03-11 16:21:38 +00:00
|
|
|
BYTE GetRealLevel( const BYTE nLvl )
|
2004-03-11 15:28:09 +00:00
|
|
|
{
|
|
|
|
return nLvl & (NO_NUMLEVEL - 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL IsNum( BYTE nLvl )
|
|
|
|
{
|
|
|
|
return 0 == (nLvl & NO_NUMLEVEL);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL IsShowNum( BYTE nLvl )
|
|
|
|
{
|
|
|
|
return IsNum(nLvl) && nLvl != NO_NUMBERING;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetNoNum( BYTE * nLvl, BOOL nVal )
|
|
|
|
{
|
|
|
|
if (nVal)
|
|
|
|
*nLvl |= NO_NUMLEVEL;
|
|
|
|
else
|
|
|
|
*nLvl &= ~NO_NUMLEVEL;
|
|
|
|
}
|
2004-03-08 11:24:46 +00:00
|
|
|
|
2004-11-26 12:24:48 +00:00
|
|
|
void SetLevel(BYTE * nLvl, BYTE nNewLevel)
|
|
|
|
{
|
2004-12-08 16:41:17 +00:00
|
|
|
if (IsNum(*nLvl))
|
2004-11-26 12:24:48 +00:00
|
|
|
*nLvl = nNewLevel;
|
|
|
|
else
|
|
|
|
*nLvl = nNewLevel | NO_NUMLEVEL;
|
|
|
|
}
|
|
|
|
|
2004-03-08 11:24:46 +00:00
|
|
|
const SwNumFmt& SwNumRule::Get( USHORT i ) const
|
|
|
|
{
|
|
|
|
ASSERT_ID( i < MAXLEVEL && eRuleType < RULE_END, ERR_NUMLEVEL);
|
|
|
|
return aFmts[ i ] ? *aFmts[ i ]
|
|
|
|
: *aBaseFmts[ eRuleType ][ i ];
|
|
|
|
}
|
|
|
|
|
|
|
|
const SwNumFmt* SwNumRule::GetNumFmt( USHORT i ) const
|
|
|
|
{
|
|
|
|
ASSERT_ID( i < MAXLEVEL && eRuleType < RULE_END, ERR_NUMLEVEL);
|
|
|
|
return aFmts[ i ];
|
|
|
|
}
|
2004-10-22 07:12:03 +00:00
|
|
|
|
2004-11-27 10:41:31 +00:00
|
|
|
void SwNumRule::SetName(const String & rName)
|
|
|
|
{
|
|
|
|
|
|
|
|
if (pNumRuleMap)
|
|
|
|
{
|
|
|
|
pNumRuleMap->erase(sName);
|
|
|
|
(*pNumRuleMap)[rName] = this;
|
|
|
|
}
|
|
|
|
|
|
|
|
sName = rName;
|
|
|
|
}
|
|
|
|
|
2004-10-22 07:12:03 +00:00
|
|
|
void SwNumRule::SetList(SwTxtNodeTable * _pList)
|
|
|
|
{
|
|
|
|
if (pList)
|
|
|
|
delete pList;
|
|
|
|
|
|
|
|
pList = _pList;
|
|
|
|
}
|
|
|
|
|
2004-11-27 10:41:31 +00:00
|
|
|
void SwNumRule::SetNumRuleMap(std::hash_map<String, SwNumRule *, StringHash> *
|
|
|
|
_pNumRuleMap)
|
|
|
|
{
|
|
|
|
pNumRuleMap = _pNumRuleMap;
|
|
|
|
}
|
|
|
|
|
2004-03-08 11:24:46 +00:00
|
|
|
const Font& SwNumRule::GetDefBulletFont()
|
|
|
|
{
|
|
|
|
if( !pDefBulletFont )
|
|
|
|
SwNumRule::_MakeDefBulletFont();
|
|
|
|
return *pDefBulletFont;
|
|
|
|
}
|
|
|
|
|
|
|
|
USHORT SwNumRule::GetNumIndent( BYTE nLvl )
|
|
|
|
{
|
|
|
|
ASSERT( MAXLEVEL > nLvl, "NumLevel is out of range" );
|
|
|
|
return aDefNumIndents[ nLvl ];
|
|
|
|
}
|
2004-11-27 10:41:31 +00:00
|
|
|
|
2004-03-08 11:24:46 +00:00
|
|
|
USHORT SwNumRule::GetBullIndent( BYTE nLvl )
|
|
|
|
{
|
|
|
|
ASSERT( MAXLEVEL > nLvl, "NumLevel is out of range" );
|
|
|
|
return aDefNumIndents[ nLvl ];
|
|
|
|
}
|
|
|
|
|
2005-02-21 15:04:08 +00:00
|
|
|
#ifndef PRODUCT
|
|
|
|
long SwNodeNum::nSerial = 0;
|
|
|
|
#endif
|
|
|
|
|
2004-03-08 11:24:46 +00:00
|
|
|
SwNodeNum::SwNodeNum( BYTE nLevel, USHORT nSetVal )
|
|
|
|
: nSetValue( nSetVal ), nMyLevel( nLevel ), bStartNum( FALSE ),
|
|
|
|
bContNum(FALSE)
|
|
|
|
{
|
|
|
|
memset( nLevelVal, 0, sizeof( nLevelVal ) );
|
2005-02-21 15:04:08 +00:00
|
|
|
|
|
|
|
#ifndef PRODUCT
|
|
|
|
nMySerial = nSerial;
|
|
|
|
nSerial++;
|
|
|
|
#endif
|
2004-03-08 11:24:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
SwNodeNum& SwNodeNum::operator=( const SwNodeNum& rCpy )
|
|
|
|
{
|
|
|
|
nSetValue = rCpy.nSetValue;
|
|
|
|
nMyLevel = rCpy.nMyLevel;
|
|
|
|
bStartNum = rCpy.bStartNum;
|
|
|
|
bContNum = rCpy.bContNum;
|
|
|
|
|
|
|
|
memcpy( nLevelVal, rCpy.nLevelVal, sizeof( nLevelVal ) );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2004-08-12 11:19:02 +00:00
|
|
|
static void lcl_SetRuleChgd( SwTxtNode& rNd, BYTE nLevel )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-23 11:45:30 +00:00
|
|
|
if( rNd.GetNum() &&
|
2004-03-08 11:24:46 +00:00
|
|
|
rNd.GetNum()->GetRealLevel() == nLevel )
|
2001-02-23 11:45:30 +00:00
|
|
|
rNd.NumRuleChgd();
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 13:41--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
SwNumFmt::SwNumFmt() :
|
|
|
|
SwClient( 0 ),
|
|
|
|
SvxNumberFormat(SVX_NUM_ARABIC),
|
2001-06-01 06:00:09 +00:00
|
|
|
pVertOrient(new SwFmtVertOrient( 0, VERT_NONE))
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 13:42--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
SwNumFmt::SwNumFmt( const SwNumFmt& rFmt) :
|
|
|
|
SwClient( rFmt.pRegisteredIn ),
|
|
|
|
SvxNumberFormat(rFmt),
|
2001-06-01 06:00:09 +00:00
|
|
|
pVertOrient(new SwFmtVertOrient( 0, (SwVertOrient)rFmt.GetVertOrient()))
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-06-01 06:00:09 +00:00
|
|
|
SvxFrameVertOrient eVertOrient = rFmt.GetVertOrient();
|
2001-02-23 11:45:30 +00:00
|
|
|
SetGraphicBrush( rFmt.GetBrush(), &rFmt.GetGraphicSize(),
|
2001-06-01 06:00:09 +00:00
|
|
|
&eVertOrient);
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 13:58--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
SwNumFmt::SwNumFmt(const SvxNumberFormat& rNumFmt, SwDoc* pDoc) :
|
|
|
|
SvxNumberFormat(rNumFmt),
|
2001-06-01 06:00:09 +00:00
|
|
|
pVertOrient(new SwFmtVertOrient( 0, (SwVertOrient)rNumFmt.GetVertOrient()))
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-06-01 06:00:09 +00:00
|
|
|
SvxFrameVertOrient eVertOrient = rNumFmt.GetVertOrient();
|
|
|
|
SetGraphicBrush( rNumFmt.GetBrush(), &rNumFmt.GetGraphicSize(),
|
|
|
|
&eVertOrient);
|
2001-02-23 11:45:30 +00:00
|
|
|
const String& rCharStyleName = rNumFmt.SvxNumberFormat::GetCharFmtName();
|
|
|
|
if( rCharStyleName.Len() )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-23 11:45:30 +00:00
|
|
|
SwCharFmt* pCFmt = pDoc->FindCharFmtByName( rCharStyleName );
|
|
|
|
if( !pCFmt )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-07-20 09:40:14 +00:00
|
|
|
USHORT nId = SwStyleNameMapper::GetPoolIdFromUIName( rCharStyleName,
|
2001-02-23 11:45:30 +00:00
|
|
|
GET_POOLID_CHRFMT );
|
|
|
|
pCFmt = nId != USHRT_MAX
|
|
|
|
? pDoc->GetCharFmtFromPool( nId )
|
|
|
|
: pDoc->MakeCharFmt( rCharStyleName, 0 );
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
pCFmt->Add( this );
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
else if( GetRegisteredIn() )
|
|
|
|
pRegisteredIn->Remove( this );
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 13:42--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
SwNumFmt::~SwNumFmt()
|
|
|
|
{
|
|
|
|
delete pVertOrient;
|
|
|
|
}
|
2001-07-02 13:25:51 +00:00
|
|
|
/* -----------------------------02.07.01 15:37--------------------------------
|
|
|
|
|
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
void SwNumFmt::NotifyGraphicArrived()
|
|
|
|
{
|
|
|
|
if( GetCharFmt() )
|
|
|
|
UpdateNumNodes( (SwDoc*)GetCharFmt()->GetDoc() );
|
|
|
|
}
|
2004-06-11 14:21:42 +00:00
|
|
|
|
|
|
|
// #i22362#
|
|
|
|
BOOL SwNumFmt::IsEnumeration() const
|
|
|
|
{
|
2004-08-31 12:52:44 +00:00
|
|
|
// --> 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();
|
|
|
|
// <--
|
|
|
|
|
|
|
|
/*
|
2004-06-11 14:21:42 +00:00
|
|
|
BOOL bResult;
|
|
|
|
|
|
|
|
switch(GetNumberingType())
|
|
|
|
{
|
|
|
|
case SVX_NUM_CHARS_UPPER_LETTER:
|
|
|
|
case SVX_NUM_CHARS_LOWER_LETTER:
|
|
|
|
case SVX_NUM_ROMAN_UPPER:
|
|
|
|
case SVX_NUM_ROMAN_LOWER:
|
|
|
|
case SVX_NUM_ARABIC:
|
|
|
|
case SVX_NUM_PAGEDESC:
|
|
|
|
case SVX_NUM_CHARS_UPPER_LETTER_N:
|
|
|
|
case SVX_NUM_CHARS_LOWER_LETTER_N:
|
|
|
|
bResult = TRUE;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
bResult = FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return bResult;
|
2004-08-31 12:52:44 +00:00
|
|
|
*/
|
2004-06-11 14:21:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// #i29560#
|
|
|
|
BOOL SwNumFmt::IsItemize() const
|
|
|
|
{
|
|
|
|
BOOL bResult;
|
|
|
|
|
|
|
|
switch(GetNumberingType())
|
|
|
|
{
|
|
|
|
case SVX_NUM_CHAR_SPECIAL:
|
|
|
|
case SVX_NUM_BITMAP:
|
|
|
|
bResult = TRUE;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
bResult = FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return bResult;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------23.02.01 09:28--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
SwNumFmt& SwNumFmt::operator=( const SwNumFmt& rNumFmt)
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-23 11:45:30 +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;
|
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------23.02.01 09:28--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
BOOL SwNumFmt::operator==( const SwNumFmt& rNumFmt) const
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-23 11:45:30 +00:00
|
|
|
BOOL bRet = SvxNumberFormat::operator==(rNumFmt) &&
|
|
|
|
pRegisteredIn == rNumFmt.pRegisteredIn;
|
2000-09-18 23:08:29 +00:00
|
|
|
return bRet;
|
|
|
|
}
|
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 13:42--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +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 );
|
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 13:45--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +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 );
|
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------23.02.01 11:08--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
void SwNumFmt::SetCharFmtName(const String& rSet)
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-23 11:45:30 +00:00
|
|
|
SvxNumberFormat::SetCharFmtName(rSet);
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 13:47--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +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
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
void SwNumFmt::SetGraphicBrush( const SvxBrushItem* pBrushItem, const Size* pSize,
|
|
|
|
const SvxFrameVertOrient* pOrient)
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-23 11:45:30 +00:00
|
|
|
if(pOrient)
|
2001-06-01 06:00:09 +00:00
|
|
|
pVertOrient->SetVertOrient( (SwVertOrient)*pOrient );
|
2001-02-23 11:45:30 +00:00
|
|
|
SvxNumberFormat::SetGraphicBrush( pBrushItem, pSize, pOrient);
|
|
|
|
}
|
|
|
|
/* -----------------------------22.02.01 16:05--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
void SwNumFmt::SetVertOrient(SvxFrameVertOrient eSet)
|
|
|
|
{
|
|
|
|
SvxNumberFormat::SetVertOrient(eSet);
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 16:05--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +00:00
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
SvxFrameVertOrient SwNumFmt::GetVertOrient() const
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-06-01 06:00:09 +00:00
|
|
|
return SvxNumberFormat::GetVertOrient();
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
/* -----------------------------22.02.01 13:54--------------------------------
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2001-02-23 11:45:30 +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() &&
|
2004-03-08 11:24:46 +00:00
|
|
|
nStt < pNd->GetIndex() &&
|
|
|
|
pNd->GetOutlineNum() && i ==
|
|
|
|
pNd->GetOutlineNum()->GetRealLevel() )
|
2000-09-18 23:08:29 +00:00
|
|
|
pNd->NumRuleChgd();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bFnd = TRUE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( bFnd && !bDocIsModified )
|
|
|
|
pDoc->ResetModified();
|
|
|
|
}
|
2001-06-01 06:00:09 +00:00
|
|
|
/* -----------------------------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
|
|
|
|
{
|
2004-03-08 11:24:46 +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 ),
|
2004-10-22 07:12:03 +00:00
|
|
|
pList(0),
|
2004-05-17 15:14:02 +00:00
|
|
|
aMarkedLevels( MAXLEVEL ), // #i27615#
|
2004-11-27 10:41:31 +00:00
|
|
|
pNumRuleMap(0),
|
2000-09-18 23:08:29 +00:00
|
|
|
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;
|
2003-12-01 15:36:27 +00:00
|
|
|
int n;
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
// Nummerierung:
|
2003-12-01 15:36:27 +00:00
|
|
|
for( n = 0; n < MAXLEVEL; ++n )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
pFmt = new SwNumFmt;
|
2001-02-23 11:45:30 +00:00
|
|
|
pFmt->SetIncludeUpperLevels( 1 );
|
|
|
|
pFmt->SetStart( 1 );
|
2000-09-18 23:08:29 +00:00
|
|
|
pFmt->SetLSpace( lNumIndent );
|
2004-07-05 13:39:02 +00:00
|
|
|
pFmt->SetAbsLSpace( lNumIndent + SwNumRule::GetNumIndent( n ) );
|
2000-09-18 23:08:29 +00:00
|
|
|
pFmt->SetFirstLineOffset( lNumFirstLineOffset );
|
2001-02-23 11:45:30 +00:00
|
|
|
pFmt->SetSuffix( aDotStr );
|
2005-02-22 09:02:55 +00:00
|
|
|
pFmt->SetBulletChar( GetBulletChar(n));
|
2000-09-18 23:08:29 +00:00
|
|
|
SwNumRule::aBaseFmts[ NUM_RULE ][ n ] = pFmt;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Gliederung:
|
|
|
|
for( n = 0; n < MAXLEVEL; ++n )
|
|
|
|
{
|
|
|
|
pFmt = new SwNumFmt;
|
2001-02-23 11:45:30 +00:00
|
|
|
pFmt->SetNumberingType(SVX_NUM_NUMBER_NONE);
|
2002-10-08 12:51:25 +00:00
|
|
|
pFmt->SetIncludeUpperLevels( MAXLEVEL );
|
2001-02-23 11:45:30 +00:00
|
|
|
pFmt->SetStart( 1 );
|
2005-03-23 10:51:45 +00:00
|
|
|
pFmt->SetCharTextDistance( lOutlineMinTextDistance );
|
2005-02-22 09:02:55 +00:00
|
|
|
pFmt->SetBulletChar( GetBulletChar(n));
|
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 ),
|
2004-10-22 07:12:03 +00:00
|
|
|
pList(0),
|
2004-05-17 15:14:02 +00:00
|
|
|
aMarkedLevels( MAXLEVEL ), // #i27615#
|
2004-11-27 10:41:31 +00:00
|
|
|
pNumRuleMap(0),
|
2000-09-18 23:08:29 +00:00
|
|
|
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 ];
|
|
|
|
|
2004-11-27 10:41:31 +00:00
|
|
|
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;
|
2003-12-01 15:36:27 +00:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
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
|
2004-08-12 11:19:02 +00:00
|
|
|
#ifndef NUM_RELSPACE
|
2000-09-18 23:08:29 +00:00
|
|
|
BOOL SwNumRule::IsRuleLSpace( SwTxtNode& rNd ) const
|
|
|
|
{
|
|
|
|
const SfxPoolItem* pItem;
|
|
|
|
BYTE nLvl;
|
|
|
|
const SwAttrSet* pASet = rNd.GetpSwAttrSet();
|
2004-03-08 11:24:46 +00:00
|
|
|
|
|
|
|
BOOL bRet = FALSE;
|
|
|
|
if (rNd.GetNum() && pASet &&
|
|
|
|
SFX_ITEM_SET == pASet->GetItemState(RES_LR_SPACE, FALSE, &pItem ))
|
|
|
|
{
|
|
|
|
nLvl = rNd.GetNum()->GetRealLevel();
|
|
|
|
|
|
|
|
if (nLvl < MAXLEVEL)
|
|
|
|
bRet = Get( nLvl ).GetAbsLSpace() == ((SvxLRSpaceItem*)pItem)->GetTxtLeft();
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
return bRet;
|
|
|
|
}
|
2004-08-12 11:19:02 +00:00
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
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;
|
2005-02-22 09:02:55 +00:00
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
2004-03-08 11:24:46 +00:00
|
|
|
if (rNum.IsShowNum())
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
const SwNumFmt& rMyNFmt = Get( rNum.GetLevel() );
|
2001-02-23 11:45:30 +00:00
|
|
|
if( SVX_NUM_NUMBER_NONE != rMyNFmt.GetNumberingType() )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
BYTE i = rNum.GetLevel();
|
|
|
|
|
|
|
|
if( !IsContinusNum() &&
|
2004-11-26 12:24:48 +00:00
|
|
|
rMyNFmt.GetIncludeUpperLevels() ) // nur der eigene Level ?
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-23 11:45:30 +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 );
|
2001-02-23 11:45:30 +00:00
|
|
|
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 &&
|
2001-02-23 11:45:30 +00:00
|
|
|
SVX_NUM_CHAR_SPECIAL != rMyNFmt.GetNumberingType() &&
|
|
|
|
SVX_NUM_BITMAP != rMyNFmt.GetNumberingType() )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
aStr.Insert( rMyNFmt.GetPrefix(), 0 );
|
2001-02-23 11:45:30 +00:00
|
|
|
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 )
|
|
|
|
{
|
2001-07-09 12:35:49 +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;
|
|
|
|
}
|
|
|
|
|
2004-10-22 07:12:03 +00:00
|
|
|
void SwNumRule::SetInvalidRule(BOOL bFlag)
|
|
|
|
{
|
|
|
|
if (bFlag && pList)
|
|
|
|
{
|
|
|
|
delete pList;
|
|
|
|
pList = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
bInvalidRuleFlag = bFlag;
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2003-06-10 12:17:29 +00:00
|
|
|
/* #109308# */
|
|
|
|
void SwNumRule::SetNumAdjust(SvxAdjust eNumAdjust)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < MAXLEVEL; i++)
|
|
|
|
aFmts[i]->SetNumAdjust(eNumAdjust);
|
|
|
|
}
|
2004-04-07 11:43:33 +00:00
|
|
|
|
2004-05-17 15:14:02 +00:00
|
|
|
// #i27615#
|
|
|
|
SwBitArray SwNumRule::SetLevelMarked(BYTE nLvl, BOOL bVal)
|
|
|
|
{
|
|
|
|
SwBitArray aTmpMarkedLevels(aMarkedLevels);
|
|
|
|
|
|
|
|
aMarkedLevels.Set(nLvl, bVal);
|
|
|
|
|
|
|
|
aTmpMarkedLevels = aTmpMarkedLevels ^ aMarkedLevels;
|
|
|
|
|
|
|
|
return aTmpMarkedLevels;
|
|
|
|
}
|
|
|
|
|
2004-04-07 11:43:33 +00:00
|
|
|
// #i23725#, #i23726#
|
|
|
|
void SwNumRule::Indent(short nAmount, int nLevel, int nReferenceLevel,
|
|
|
|
BOOL bRelative, BOOL bFirstLine, BOOL bCheckGtZero)
|
|
|
|
{
|
|
|
|
int nStartLevel = 0;
|
|
|
|
int nEndLevel = MAXLEVEL - 1;
|
|
|
|
BOOL bGotInvalid = FALSE;
|
|
|
|
|
|
|
|
if (nLevel >= 0)
|
|
|
|
nStartLevel = nEndLevel = nLevel;
|
|
|
|
|
|
|
|
int i;
|
|
|
|
short nRealAmount = nAmount;
|
|
|
|
|
|
|
|
if (! bRelative)
|
|
|
|
{
|
|
|
|
if (bFirstLine)
|
|
|
|
{
|
|
|
|
if (nReferenceLevel >= 0)
|
|
|
|
nAmount -= Get(nReferenceLevel).GetFirstLineOffset();
|
|
|
|
else
|
|
|
|
nAmount -= Get(nStartLevel).GetFirstLineOffset();
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL bFirst = TRUE;
|
|
|
|
|
|
|
|
if (nReferenceLevel >= 0)
|
|
|
|
nRealAmount = nAmount - Get(nReferenceLevel).GetAbsLSpace();
|
|
|
|
else
|
|
|
|
for (i = nStartLevel; i < nEndLevel + 1; i++)
|
|
|
|
{
|
|
|
|
short nTmp = nAmount - Get(i).GetAbsLSpace();
|
|
|
|
|
|
|
|
if (bFirst || nTmp > nRealAmount)
|
|
|
|
{
|
|
|
|
nRealAmount = nTmp;
|
|
|
|
bFirst = FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (nRealAmount < 0)
|
|
|
|
for (i = nStartLevel; i < nEndLevel + 1; i++)
|
|
|
|
if (Get(i).GetAbsLSpace() + nRealAmount < 0)
|
|
|
|
nRealAmount = -Get(i).GetAbsLSpace();
|
|
|
|
|
|
|
|
for (i = nStartLevel; i < nEndLevel + 1; i++)
|
|
|
|
{
|
|
|
|
short nNew = Get(i).GetAbsLSpace() + nRealAmount;
|
|
|
|
|
|
|
|
if (bCheckGtZero && nNew < 0)
|
|
|
|
nNew = 0;
|
|
|
|
|
|
|
|
SwNumFmt aTmpNumFmt(Get(i));
|
|
|
|
aTmpNumFmt.SetAbsLSpace(nNew);
|
|
|
|
|
|
|
|
Set(i, aTmpNumFmt);
|
|
|
|
|
|
|
|
bGotInvalid = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bGotInvalid)
|
|
|
|
SetInvalidRule(bGotInvalid);
|
|
|
|
}
|
2005-02-22 09:02:55 +00:00
|
|
|
|
|
|
|
sal_Unicode GetBulletChar(BYTE nLevel)
|
|
|
|
{
|
|
|
|
static sal_Unicode nLevelChars[MAXLEVEL] =
|
|
|
|
{ 0x25cf, 0x25cb, 0x25a0, 0x25cf, 0x25cb,
|
|
|
|
0x25a0, 0x25cf, 0x25cb, 0x25a0, 0x25cf };
|
|
|
|
|
|
|
|
if (nLevel > MAXLEVEL)
|
|
|
|
nLevel = MAXLEVEL;
|
|
|
|
|
|
|
|
return nLevelChars[nLevel];
|
|
|
|
}
|