summaryrefslogtreecommitdiffstats
path: root/sw/source/filter/html/htmlnum.hxx
blob: 670f08229df2a882cd1440535435e9b0ad6daac2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   Licensed to the Apache Software Foundation (ASF) under one or more
 *   contributor license agreements. See the NOTICE file distributed
 *   with this work for additional information regarding copyright
 *   ownership. The ASF licenses this file to you under the Apache
 *   License, Version 2.0 (the "License"); you may not use this file
 *   except in compliance with the License. You may obtain a copy of
 *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
 */
#ifndef INCLUDED_SW_SOURCE_FILTER_HTML_HTMLNUM_HXX
#define INCLUDED_SW_SOURCE_FILTER_HTML_HTMLNUM_HXX

#include <swtypes.hxx>
#include <string.h>

#define HTML_NUMBER_BULLET_MARGINLEFT  (o3tl::toTwips(125, o3tl::Length::mm10))
#define HTML_NUMBER_BULLET_INDENT      (-o3tl::toTwips(5, o3tl::Length::mm))

class SwTextNode;
class SwNumRule;

// TODO: Unicode: Are these characters the correct ones?
#define HTML_BULLETCHAR_DISC    (0xe008)
#define HTML_BULLETCHAR_CIRCLE  (0xe009)
#define HTML_BULLETCHAR_SQUARE  (0xe00b)

class SwHTMLNumRuleInfo
{
    sal_uInt16      m_aNumStarts[MAXLEVEL];
    SwNumRule   *   m_pNumRule;       // current numbering
    sal_uInt16      m_nDeep;          // current numbering depth (1, 2, 3, ...)
    bool        m_bRestart;   // Export: restart numbering
    bool        m_bNumbered;  // Export: paragraph is numbered

public:

    inline void Set( const SwHTMLNumRuleInfo& rInf );
    void Set( const SwTextNode& rTextNd );

    SwHTMLNumRuleInfo() :
        m_pNumRule( nullptr ), m_nDeep( 0 ),
        m_bRestart( false ), m_bNumbered( false )
    {
        memset( &m_aNumStarts, 0xff, sizeof( m_aNumStarts ) );
    }

    SwHTMLNumRuleInfo( const SwHTMLNumRuleInfo& rInf ) :
        m_pNumRule( rInf.m_pNumRule ), m_nDeep( rInf.m_nDeep ),
        m_bRestart( rInf.m_bRestart ), m_bNumbered( rInf.m_bNumbered )
    {
        memcpy( &m_aNumStarts, &rInf.m_aNumStarts, sizeof( m_aNumStarts ) );
    }

    explicit SwHTMLNumRuleInfo( const SwTextNode& rTextNd ) { Set( rTextNd ); }
    inline SwHTMLNumRuleInfo& operator=( const SwHTMLNumRuleInfo& rInf );

    inline void Clear();

    void SetNumRule( const SwNumRule *pRule ) { m_pNumRule = const_cast<SwNumRule *>(pRule); }
    SwNumRule *GetNumRule() { return m_pNumRule; }
    const SwNumRule *GetNumRule() const { return m_pNumRule; }

    void SetDepth( sal_uInt16 nDepth ) { m_nDeep = nDepth; }
    sal_uInt16 GetDepth() const { return m_nDeep; }
    void IncDepth() { ++m_nDeep; }
    void DecDepth() { if (m_nDeep!=0) --m_nDeep; }
    inline sal_uInt8 GetLevel() const;

    bool IsRestart(const SwHTMLNumRuleInfo& rPrev) const;

    bool IsNumbered() const { return m_bNumbered; }

    inline void SetNodeStartValue( sal_uInt8 nLvl, sal_uInt16 nVal=USHRT_MAX );
    sal_uInt16 GetNodeStartValue( sal_uInt8 nLvl ) const { return m_aNumStarts[nLvl]; }
};

inline SwHTMLNumRuleInfo& SwHTMLNumRuleInfo::operator=(
    const SwHTMLNumRuleInfo& rInf )
{
    Set( rInf );
    return *this;
}

inline void SwHTMLNumRuleInfo::Set( const SwHTMLNumRuleInfo& rInf )
{
    m_pNumRule = rInf.m_pNumRule;
    m_nDeep = rInf.m_nDeep;
    m_bRestart = rInf.m_bRestart;
    m_bNumbered = rInf.m_bNumbered;
    memcpy( &m_aNumStarts, &rInf.m_aNumStarts, sizeof( m_aNumStarts ) );
}

inline void SwHTMLNumRuleInfo::Clear()
{
    m_pNumRule = nullptr;
    m_nDeep = 0;
    m_bRestart = m_bNumbered = false;
    memset( &m_aNumStarts, 0xff, sizeof( m_aNumStarts ) );
}

inline sal_uInt8 SwHTMLNumRuleInfo::GetLevel() const
{
    return
        static_cast<sal_uInt8>( m_pNumRule!=nullptr && m_nDeep != 0
            ? ( m_nDeep<=MAXLEVEL ? m_nDeep-1 : MAXLEVEL - 1 )
            : 0 );
}

inline void SwHTMLNumRuleInfo::SetNodeStartValue( sal_uInt8 nLvl, sal_uInt16 nVal )
{
    m_aNumStarts[nLvl] = nVal;
}

#endif

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */