blob: 04fbb54f05ddfd7918c11468f404d3a5dfd16c14 [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
#ifndef _HTMLNUM_HXX
#define _HTMLNUM_HXX
#include <swtypes.hxx>
#include <string.h>
#define HTML_NUMBUL_MARGINLEFT (MM50*2 + MM50/2)
#define HTML_NUMBUL_INDENT (-MM50)
class SwTxtNode;
class SwNumRule;
class SwHTMLNumRuleInfo
{
sal_uInt16 aNumStarts[MAXLEVEL];
SwNumRule * pNumRule; // Aktuelle Numerierung
sal_uInt16 nDeep; // aktuelle Num-Tiefe (1, 2, 3, ...)
sal_Bool bRestart : 1; // Export: Numerierung neu starten
sal_Bool bNumbered : 1; // Export: Absatz ist numeriert
public:
inline void Set( const SwHTMLNumRuleInfo& rInf );
void Set( const SwTxtNode& rTxtNd );
SwHTMLNumRuleInfo() :
pNumRule( 0 ), nDeep( 0 ),
bRestart( sal_False ), bNumbered( sal_False )
{
memset( &aNumStarts, 0xff, sizeof( aNumStarts ) );
}
SwHTMLNumRuleInfo( const SwHTMLNumRuleInfo& rInf ) :
pNumRule( rInf.pNumRule ), nDeep( rInf.nDeep ),
bRestart( rInf.bRestart ), bNumbered( rInf.bNumbered )
{
memcpy( &aNumStarts, &rInf.aNumStarts, sizeof( aNumStarts ) );
}
SwHTMLNumRuleInfo( const SwTxtNode& rTxtNd ) { Set( rTxtNd ); }
inline SwHTMLNumRuleInfo& operator=( const SwHTMLNumRuleInfo& rInf );
inline void Clear();
void SetNumRule( const SwNumRule *pRule ) { pNumRule = (SwNumRule *)pRule; }
SwNumRule *GetNumRule() { return pNumRule; }
const SwNumRule *GetNumRule() const { return pNumRule; }
void SetDepth( sal_uInt16 nDepth ) { nDeep = nDepth; }
sal_uInt16 GetDepth() const { return nDeep; }
sal_uInt16 IncDepth() { return ++nDeep; }
sal_uInt16 DecDepth() { return nDeep==0 ? 0 : --nDeep; }
inline sal_uInt8 GetLevel() const;
void SetRestart( sal_Bool bSet ) { bRestart = bSet; }
sal_Bool IsRestart() const { return bRestart; }
void SetNumbered( sal_Bool bSet ) { bNumbered = bSet; }
sal_Bool IsNumbered() const { return bNumbered; }
inline void SetNodeStartValue( sal_uInt8 nLvl, sal_uInt16 nVal=USHRT_MAX );
sal_uInt16 GetNodeStartValue( sal_uInt8 nLvl ) const { return aNumStarts[nLvl]; }
};
inline SwHTMLNumRuleInfo& SwHTMLNumRuleInfo::operator=(
const SwHTMLNumRuleInfo& rInf )
{
Set( rInf );
return *this;
}
inline void SwHTMLNumRuleInfo::Set( const SwHTMLNumRuleInfo& rInf )
{
pNumRule = rInf.pNumRule;
nDeep = rInf.nDeep;
bRestart = rInf.bRestart;
bNumbered = rInf.bNumbered;
memcpy( &aNumStarts, &rInf.aNumStarts, sizeof( aNumStarts ) );
}
inline void SwHTMLNumRuleInfo::Clear()
{
pNumRule = 0;
nDeep = 0;
bRestart = bNumbered = sal_False;
memset( &aNumStarts, 0xff, sizeof( aNumStarts ) );
}
inline sal_uInt8 SwHTMLNumRuleInfo::GetLevel() const
{
return
(sal_uInt8)( pNumRule!=0 && nDeep != 0
? ( nDeep<=MAXLEVEL ? nDeep-1 : MAXLEVEL - 1 )
: 0 );
}
inline void SwHTMLNumRuleInfo::SetNodeStartValue( sal_uInt8 nLvl, sal_uInt16 nVal )
{
aNumStarts[nLvl] = nVal;
}
#endif