Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*************************************************************************
3 : *
4 : * The Contents of this file are made available subject to the terms of
5 : * either of the following licenses
6 : *
7 : * - GNU Lesser General Public License Version 2.1
8 : * - Sun Industry Standards Source License Version 1.1
9 : *
10 : * Sun Microsystems Inc., October, 2000
11 : *
12 : * GNU Lesser General Public License Version 2.1
13 : * =============================================
14 : * Copyright 2000 by Sun Microsystems, Inc.
15 : * 901 San Antonio Road, Palo Alto, CA 94303, USA
16 : *
17 : * This library is free software; you can redistribute it and/or
18 : * modify it under the terms of the GNU Lesser General Public
19 : * License version 2.1, as published by the Free Software Foundation.
20 : *
21 : * This library is distributed in the hope that it will be useful,
22 : * but WITHOUT ANY WARRANTY; without even the implied warranty of
23 : * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24 : * Lesser General Public License for more details.
25 : *
26 : * You should have received a copy of the GNU Lesser General Public
27 : * License along with this library; if not, write to the Free Software
28 : * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
29 : * MA 02111-1307 USA
30 : *
31 : *
32 : * Sun Industry Standards Source License Version 1.1
33 : * =================================================
34 : * The contents of this file are subject to the Sun Industry Standards
35 : * Source License Version 1.1 (the "License"); You may not use this file
36 : * except in compliance with the License. You may obtain a copy of the
37 : * License at http://www.openoffice.org/license.html.
38 : *
39 : * Software provided under this License is provided on an "AS IS" basis,
40 : * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
41 : * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
42 : * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
43 : * See the License for the specific provisions governing your rights and
44 : * obligations concerning the Software.
45 : *
46 : * The Initial Developer of the Original Code is: IBM Corporation
47 : *
48 : * Copyright: 2008 by IBM Corporation
49 : *
50 : * All Rights Reserved.
51 : *
52 : * Contributor(s): _______________________________________
53 : *
54 : *
55 : ************************************************************************/
56 : /*************************************************************************
57 : * @file
58 : * Number format. a),A),i),1),(1)
59 : ************************************************************************/
60 : #ifndef INCLUDED_LOTUSWORDPRO_SOURCE_FILTER_XFILTER_XFNUMFMT_HXX
61 : #define INCLUDED_LOTUSWORDPRO_SOURCE_FILTER_XFILTER_XFNUMFMT_HXX
62 :
63 : #include "xfglobal.hxx"
64 :
65 : /**
66 : * @brief
67 : * Bullet number format.
68 : */
69 648 : class XFNumFmt
70 : {
71 : public:
72 391 : XFNumFmt()
73 391 : {
74 391 : m_nStartValue = 0;
75 391 : }
76 :
77 : public:
78 : /**********************************************************************
79 : * @descr: set the prefix of the number format,that the '(' of output
80 : (1 item1
81 : (2 item2
82 : * @param: prefix
83 : *********************************************************************/
84 13 : void SetPrefix(const OUString& prefix)
85 : {
86 13 : m_strPrefix = prefix;
87 13 : }
88 :
89 : /**********************************************************************
90 : * @descr: set the suffix of the number format,that the ')' of output
91 : 1) item1
92 : 2) item2
93 : * @param: prefix
94 : *********************************************************************/
95 54 : void SetSuffix(const OUString& suffix)
96 : {
97 54 : m_strSuffix = suffix;
98 54 : }
99 :
100 : /**********************************************************************
101 : * @descr: set the display value. ie. if you set format to '1',then
102 : the output would be:
103 : 1 item1
104 : 2 item2
105 : or if you set the format to 'a', then the output would be:
106 : a item1
107 : b item2
108 : some sepecial, if you set the format to a sequence,ie. "一,二,三,..."
109 : the output would be:
110 : 一 item1
111 : 二 item2
112 : 三 item3
113 :
114 : Of cource, for unordered-list, you can also set the format to
115 : be a bullet char,ie:
116 : '','','','','',
117 : * @param: prefix
118 : *********************************************************************/
119 134 : void SetFormat(const OUString& format)
120 : {
121 134 : m_strFormat = format;
122 134 : }
123 :
124 117 : void SetStartValue(sal_Int16 start)
125 : {
126 117 : m_nStartValue = start;
127 117 : }
128 :
129 112 : void ToXml(IXFStream *pStrm)
130 : {
131 112 : IXFAttrList *pAttrList = pStrm->GetAttrList();
132 :
133 112 : if( !m_strPrefix.isEmpty() )
134 3 : pAttrList->AddAttribute( "style:num-prefix", m_strPrefix );
135 112 : if( !m_strSuffix.isEmpty() )
136 50 : pAttrList->AddAttribute( "style:num-suffix", m_strSuffix );
137 112 : pAttrList->AddAttribute( "style:num-format", m_strFormat );
138 112 : if( m_nStartValue != 0 )
139 90 : pAttrList->AddAttribute( "text:start-value", OUString::number((sal_Int32)m_nStartValue) );
140 112 : }
141 : private:
142 : OUString m_strPrefix;
143 : OUString m_strSuffix;
144 : OUString m_strFormat;
145 : sal_Int16 m_nStartValue;
146 : };
147 :
148 : #endif
149 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|