Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
5 : * This Source Code Form is subject to the terms of the Mozilla Public
6 : * License, v. 2.0. If a copy of the MPL was not distributed with this
7 : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
11 : * Licensed to the Apache Software Foundation (ASF) under one or more
12 : * contributor license agreements. See the NOTICE file distributed
13 : * with this work for additional information regarding copyright
14 : * ownership. The ASF licenses this file to you under the Apache
15 : * License, Version 2.0 (the "License"); you may not use this file
16 : * except in compliance with the License. You may obtain a copy of
17 : * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 : */
19 :
20 : #include "XMLSectionFootnoteConfigExport.hxx"
21 : #include <xmloff/xmlexp.hxx>
22 : #include <xmloff/xmlprmap.hxx>
23 : #include <com/sun/star/style/NumberingType.hpp>
24 : #include <sax/tools/converter.hxx>
25 : #include <xmloff/maptype.hxx>
26 :
27 : #include <xmloff/txtprmap.hxx>
28 : #include <xmloff/nmspmap.hxx>
29 : #include <xmloff/xmlnmspe.hxx>
30 : #include <xmloff/xmluconv.hxx>
31 : #include <xmloff/xmltoken.hxx>
32 : #include <xmloff/xmlnume.hxx>
33 : #include <tools/debug.hxx>
34 : #include <rtl/ustring.hxx>
35 : #include <rtl/ustrbuf.hxx>
36 :
37 : #include <vector>
38 :
39 :
40 : using namespace ::xmloff::token;
41 :
42 : using ::std::vector;
43 : using ::com::sun::star::style::NumberingType::ARABIC;
44 :
45 :
46 0 : void XMLSectionFootnoteConfigExport::exportXML(
47 : SvXMLExport& rExport,
48 : bool bEndnote,
49 : const vector<XMLPropertyState> *pProperties,
50 : sal_uInt32
51 : #ifdef DBG_UTIL
52 : nIdx
53 : #endif
54 : ,
55 : const rtl::Reference<XMLPropertySetMapper> & rMapper)
56 : {
57 : // store and initialize the values
58 0 : bool bNumOwn = false;
59 0 : bool bNumRestart = false;
60 0 : sal_Int16 nNumRestartAt = 0;
61 0 : sal_Int16 nNumberingType = ARABIC;
62 0 : OUString sNumPrefix;
63 0 : OUString sNumSuffix;
64 0 : bool bEnd = false;
65 :
66 : // find entries in property states vector
67 0 : sal_uInt32 nCount = pProperties->size();
68 0 : for(sal_uInt32 i = 0; i < nCount; i++)
69 : {
70 0 : const XMLPropertyState& rState = (*pProperties)[i];
71 :
72 0 : sal_Int16 nContextId = rMapper->GetEntryContextId(rState.mnIndex);
73 0 : if (!bEndnote)
74 : {
75 0 : switch (nContextId)
76 : {
77 : case CTF_SECTION_FOOTNOTE_NUM_OWN:
78 0 : rState.maValue >>= bNumOwn;
79 0 : break;
80 : case CTF_SECTION_FOOTNOTE_NUM_RESTART:
81 0 : rState.maValue >>= bNumRestart;
82 0 : break;
83 : case CTF_SECTION_FOOTNOTE_NUM_RESTART_AT:
84 0 : rState.maValue >>= nNumRestartAt;
85 0 : break;
86 : case CTF_SECTION_FOOTNOTE_NUM_TYPE:
87 0 : rState.maValue >>= nNumberingType;
88 0 : break;
89 : case CTF_SECTION_FOOTNOTE_NUM_PREFIX:
90 0 : rState.maValue >>= sNumPrefix;
91 0 : break;
92 : case CTF_SECTION_FOOTNOTE_NUM_SUFFIX:
93 0 : rState.maValue >>= sNumSuffix;
94 0 : break;
95 : case CTF_SECTION_FOOTNOTE_END:
96 : DBG_ASSERT( i == nIdx,
97 : "received wrong property state index" );
98 0 : rState.maValue >>= bEnd;
99 0 : break;
100 : }
101 : }
102 : else
103 : {
104 0 : switch (nContextId)
105 : {
106 : case CTF_SECTION_ENDNOTE_NUM_OWN:
107 0 : rState.maValue >>= bNumOwn;
108 0 : break;
109 : case CTF_SECTION_ENDNOTE_NUM_RESTART:
110 0 : rState.maValue >>= bNumRestart;
111 0 : break;
112 : case CTF_SECTION_ENDNOTE_NUM_RESTART_AT:
113 0 : rState.maValue >>= nNumRestartAt;
114 0 : break;
115 : case CTF_SECTION_ENDNOTE_NUM_TYPE:
116 0 : rState.maValue >>= nNumberingType;
117 0 : break;
118 : case CTF_SECTION_ENDNOTE_NUM_PREFIX:
119 0 : rState.maValue >>= sNumPrefix;
120 0 : break;
121 : case CTF_SECTION_ENDNOTE_NUM_SUFFIX:
122 0 : rState.maValue >>= sNumSuffix;
123 0 : break;
124 : case CTF_SECTION_ENDNOTE_END:
125 : DBG_ASSERT( i == nIdx,
126 : "received wrong property state index" );
127 0 : rState.maValue >>= bEnd;
128 0 : break;
129 : }
130 : }
131 : }
132 :
133 : // we only make an element if we have an own footnote/endnote numbering
134 0 : if (bEnd)
135 : {
136 : rExport.AddAttribute(XML_NAMESPACE_TEXT, XML_NOTE_CLASS,
137 : GetXMLToken( bEndnote ? XML_ENDNOTE
138 0 : : XML_FOOTNOTE ) );
139 : // start numbering
140 0 : OUStringBuffer sBuf;
141 0 : if (bNumRestart)
142 : {
143 : // restart number is stored as 0.., but interpreted as 1..
144 : ::sax::Converter::convertNumber(sBuf,
145 0 : (sal_Int32)(nNumRestartAt+1));
146 : rExport.AddAttribute(XML_NAMESPACE_TEXT, XML_START_VALUE,
147 0 : sBuf.makeStringAndClear());
148 : }
149 :
150 0 : if (bNumOwn)
151 : {
152 : // prefix and suffix
153 0 : if (!sNumPrefix.isEmpty())
154 : {
155 : rExport.AddAttribute(XML_NAMESPACE_STYLE, XML_NUM_PREFIX,
156 0 : sNumPrefix);
157 : }
158 0 : if (!sNumSuffix.isEmpty())
159 : {
160 : rExport.AddAttribute(XML_NAMESPACE_STYLE, XML_NUM_SUFFIX,
161 0 : sNumSuffix);
162 : }
163 :
164 : // number type: num format
165 0 : rExport.GetMM100UnitConverter().convertNumFormat( sBuf,
166 0 : nNumberingType );
167 : rExport.AddAttribute(XML_NAMESPACE_STYLE, XML_NUM_FORMAT,
168 0 : sBuf.makeStringAndClear());
169 :
170 : // and letter sync, if applicable
171 : SvXMLUnitConverter::convertNumLetterSync(
172 0 : sBuf, nNumberingType );
173 0 : if (!sBuf.isEmpty())
174 : {
175 : rExport.AddAttribute(XML_NAMESPACE_STYLE,
176 : XML_NUM_LETTER_SYNC,
177 0 : sBuf.makeStringAndClear());
178 : }
179 : }
180 :
181 : // and finally, the element
182 : SvXMLElementExport rElem(rExport, XML_NAMESPACE_TEXT,
183 : XML_NOTES_CONFIGURATION,
184 0 : true, true);
185 0 : }
186 0 : }
187 :
188 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|