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 :
21 : #include <sax/tools/converter.hxx>
22 :
23 : #include <xmloff/SettingsExportHelper.hxx>
24 : #include <xmloff/xmlnmspe.hxx>
25 : #include <xmloff/xmltoken.hxx>
26 : #include <tools/debug.hxx>
27 : #include <tools/diagnose_ex.h>
28 : #include <comphelper/extract.hxx>
29 : #include <comphelper/processfactory.hxx>
30 :
31 : #include <com/sun/star/linguistic2/XSupportedLocales.hpp>
32 : #include <com/sun/star/i18n/XForbiddenCharacters.hpp>
33 : #include <com/sun/star/container/XNameAccess.hpp>
34 : #include <com/sun/star/container/XNameContainer.hpp>
35 : #include <com/sun/star/container/XIndexContainer.hpp>
36 : #include <com/sun/star/util/PathSubstitution.hpp>
37 : #include <com/sun/star/util/DateTime.hpp>
38 : #include <com/sun/star/lang/XMultiServiceFactory.hpp>
39 : #include <com/sun/star/formula/SymbolDescriptor.hpp>
40 : #include <com/sun/star/document/PrinterIndependentLayout.hpp>
41 : #include <com/sun/star/document/IndexedPropertyValues.hpp>
42 : #include <xmloff/XMLSettingsExportContext.hxx>
43 : #include <xmlenums.hxx>
44 :
45 : using namespace ::com::sun::star;
46 : using namespace ::xmloff::token;
47 :
48 773 : XMLSettingsExportHelper::XMLSettingsExportHelper( ::xmloff::XMLSettingsExportContext& i_rContext )
49 : : m_rContext( i_rContext )
50 : , msPrinterIndependentLayout( "PrinterIndependentLayout" )
51 : , msColorTableURL( "ColorTableURL" )
52 : , msLineEndTableURL( "LineEndTableURL" )
53 : , msHatchTableURL( "HatchTableURL" )
54 : , msDashTableURL( "DashTableURL" )
55 : , msGradientTableURL( "GradientTableURL" )
56 773 : , msBitmapTableURL( "BitmapTableURL" )
57 : {
58 773 : }
59 :
60 773 : XMLSettingsExportHelper::~XMLSettingsExportHelper()
61 : {
62 773 : }
63 :
64 48462 : void XMLSettingsExportHelper::CallTypeFunction(const uno::Any& rAny,
65 : const OUString& rName) const
66 : {
67 48462 : uno::Any aAny( rAny );
68 48462 : ManipulateSetting( aAny, rName );
69 :
70 48462 : uno::TypeClass eClass = aAny.getValueTypeClass();
71 48462 : switch (eClass)
72 : {
73 : case uno::TypeClass_VOID:
74 : {
75 : /*
76 : * This assertion pops up when exporting values which are set to:
77 : * PropertyAttribute::MAYBEVOID, and thus are _supposed_ to have
78 : * a VOID value...so I'm removing it ...mtg
79 : * OSL_FAIL("no type");
80 : */
81 : }
82 2810 : break;
83 : case uno::TypeClass_BOOLEAN:
84 : {
85 15619 : exportBool(::cppu::any2bool(aAny), rName);
86 : }
87 15619 : break;
88 : case uno::TypeClass_BYTE:
89 : {
90 0 : sal_Int8 nInt8 = 0;
91 0 : aAny >>= nInt8;
92 0 : exportByte(nInt8, rName);
93 : }
94 0 : break;
95 : case uno::TypeClass_SHORT:
96 : {
97 18407 : sal_Int16 nInt16 = 0;
98 18407 : aAny >>= nInt16;
99 18407 : exportShort(nInt16, rName);
100 : }
101 18407 : break;
102 : case uno::TypeClass_LONG:
103 : {
104 1368 : sal_Int32 nInt32 = 0;
105 1368 : aAny >>= nInt32;
106 1368 : exportInt(nInt32, rName);
107 : }
108 1368 : break;
109 : case uno::TypeClass_HYPER:
110 : {
111 2764 : sal_Int64 nInt64 = 0;
112 2764 : aAny >>= nInt64;
113 2764 : exportLong(nInt64, rName);
114 : }
115 2764 : break;
116 : case uno::TypeClass_DOUBLE:
117 : {
118 0 : double fDouble = 0.0;
119 0 : aAny >>= fDouble;
120 0 : exportDouble(fDouble, rName);
121 : }
122 0 : break;
123 : case uno::TypeClass_STRING:
124 : {
125 5210 : OUString sString;
126 5210 : aAny >>= sString;
127 5210 : exportString(sString, rName);
128 : }
129 5210 : break;
130 : default:
131 : {
132 2284 : uno::Type aType = aAny.getValueType();
133 2284 : if (aType.equals(cppu::UnoType<uno::Sequence<beans::PropertyValue>>::get() ) )
134 : {
135 683 : uno::Sequence< beans::PropertyValue> aProps;
136 683 : aAny >>= aProps;
137 683 : exportSequencePropertyValue(aProps, rName);
138 : }
139 1601 : else if( aType.equals(cppu::UnoType<uno::Sequence<sal_Int8>>::get() ) )
140 : {
141 215 : uno::Sequence< sal_Int8 > aProps;
142 215 : aAny >>= aProps;
143 215 : exportbase64Binary(aProps, rName);
144 : }
145 2767 : else if (aType.equals(cppu::UnoType<container::XNameContainer>::get()) ||
146 1381 : aType.equals(cppu::UnoType<container::XNameAccess>::get()))
147 : {
148 5 : uno::Reference< container::XNameAccess> aNamed;
149 5 : aAny >>= aNamed;
150 5 : exportNameAccess(aNamed, rName);
151 : }
152 2691 : else if (aType.equals(cppu::UnoType<container::XIndexAccess>::get()) ||
153 1310 : aType.equals(cppu::UnoType<container::XIndexContainer>::get()) )
154 : {
155 143 : uno::Reference<container::XIndexAccess> aIndexed;
156 143 : aAny >>= aIndexed;
157 143 : exportIndexAccess(aIndexed, rName);
158 : }
159 1238 : else if (aType.equals(cppu::UnoType<util::DateTime>::get()) )
160 : {
161 0 : util::DateTime aDateTime;
162 0 : aAny >>= aDateTime;
163 0 : exportDateTime(aDateTime, rName);
164 : }
165 1238 : else if( aType.equals(cppu::UnoType<i18n::XForbiddenCharacters>::get()) )
166 : {
167 116 : exportForbiddenCharacters( aAny, rName );
168 : }
169 1122 : else if( aType.equals(cppu::UnoType<uno::Sequence<formula::SymbolDescriptor>>::get() ) )
170 : {
171 1122 : uno::Sequence< formula::SymbolDescriptor > aProps;
172 1122 : aAny >>= aProps;
173 1122 : exportSymbolDescriptors(aProps, rName);
174 : }
175 : else {
176 : OSL_FAIL("this type is not implemented now");
177 2284 : }
178 : }
179 2284 : break;
180 48462 : }
181 48462 : }
182 :
183 15619 : void XMLSettingsExportHelper::exportBool(const bool bValue, const OUString& rName) const
184 : {
185 : DBG_ASSERT(!rName.isEmpty(), "no name");
186 15619 : m_rContext.AddAttribute( XML_NAME, rName );
187 15619 : m_rContext.AddAttribute( XML_TYPE, XML_BOOLEAN );
188 15619 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
189 15619 : OUString sValue;
190 15619 : if (bValue)
191 2949 : sValue = GetXMLToken(XML_TRUE);
192 : else
193 12670 : sValue = GetXMLToken(XML_FALSE);
194 15619 : m_rContext.Characters( sValue );
195 15619 : m_rContext.EndElement( false );
196 15619 : }
197 :
198 0 : void XMLSettingsExportHelper::exportByte(const sal_Int8 nValue, const OUString& rName)
199 : {
200 : (void) nValue; (void) rName;
201 : OSL_ENSURE(false, "XMLSettingsExportHelper::exportByte(): #i114162#:\n"
202 : "config-items of type \"byte\" are not valid ODF, "
203 : "so storing them is disabled!\n"
204 : "Use a different type instead (e.g. \"short\").");
205 0 : }
206 18407 : void XMLSettingsExportHelper::exportShort(const sal_Int16 nValue, const OUString& rName) const
207 : {
208 : DBG_ASSERT(!rName.isEmpty(), "no name");
209 18407 : m_rContext.AddAttribute( XML_NAME, rName );
210 18407 : m_rContext.AddAttribute( XML_TYPE, XML_SHORT );
211 18407 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
212 18407 : OUStringBuffer sBuffer;
213 18407 : ::sax::Converter::convertNumber(sBuffer, sal_Int32(nValue));
214 18407 : m_rContext.Characters( sBuffer.makeStringAndClear() );
215 18407 : m_rContext.EndElement( false );
216 18407 : }
217 :
218 1368 : void XMLSettingsExportHelper::exportInt(const sal_Int32 nValue, const OUString& rName) const
219 : {
220 : DBG_ASSERT(!rName.isEmpty(), "no name");
221 1368 : m_rContext.AddAttribute( XML_NAME, rName );
222 1368 : m_rContext.AddAttribute( XML_TYPE, XML_INT );
223 1368 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
224 1368 : OUStringBuffer sBuffer;
225 1368 : ::sax::Converter::convertNumber(sBuffer, nValue);
226 1368 : m_rContext.Characters( sBuffer.makeStringAndClear() );
227 1368 : m_rContext.EndElement( false );
228 1368 : }
229 :
230 2764 : void XMLSettingsExportHelper::exportLong(const sal_Int64 nValue, const OUString& rName) const
231 : {
232 : DBG_ASSERT(!rName.isEmpty(), "no name");
233 2764 : m_rContext.AddAttribute( XML_NAME, rName );
234 2764 : m_rContext.AddAttribute( XML_TYPE, XML_LONG );
235 2764 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
236 2764 : OUString sValue(OUString::number(nValue));
237 2764 : m_rContext.Characters( sValue );
238 2764 : m_rContext.EndElement( false );
239 2764 : }
240 :
241 0 : void XMLSettingsExportHelper::exportDouble(const double fValue, const OUString& rName) const
242 : {
243 : DBG_ASSERT(!rName.isEmpty(), "no name");
244 0 : m_rContext.AddAttribute( XML_NAME, rName );
245 0 : m_rContext.AddAttribute( XML_TYPE, XML_DOUBLE );
246 0 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
247 0 : OUStringBuffer sBuffer;
248 0 : ::sax::Converter::convertDouble(sBuffer, fValue);
249 0 : m_rContext.Characters( sBuffer.makeStringAndClear() );
250 0 : m_rContext.EndElement( false );
251 0 : }
252 :
253 5210 : void XMLSettingsExportHelper::exportString(const OUString& sValue, const OUString& rName) const
254 : {
255 : DBG_ASSERT(!rName.isEmpty(), "no name");
256 5210 : m_rContext.AddAttribute( XML_NAME, rName );
257 5210 : m_rContext.AddAttribute( XML_TYPE, XML_STRING );
258 5210 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
259 5210 : if (!sValue.isEmpty())
260 4292 : m_rContext.Characters( sValue );
261 5210 : m_rContext.EndElement( false );
262 5210 : }
263 :
264 0 : void XMLSettingsExportHelper::exportDateTime(const util::DateTime& aValue, const OUString& rName) const
265 : {
266 : DBG_ASSERT(!rName.isEmpty(), "no name");
267 0 : m_rContext.AddAttribute( XML_NAME, rName );
268 0 : m_rContext.AddAttribute( XML_TYPE, XML_DATETIME );
269 0 : OUStringBuffer sBuffer;
270 0 : ::sax::Converter::convertDateTime(sBuffer, aValue, 0);
271 0 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
272 0 : m_rContext.Characters( sBuffer.makeStringAndClear() );
273 0 : m_rContext.EndElement( false );
274 0 : }
275 :
276 2040 : void XMLSettingsExportHelper::exportSequencePropertyValue(
277 : const uno::Sequence<beans::PropertyValue>& aProps,
278 : const OUString& rName) const
279 : {
280 : DBG_ASSERT(!rName.isEmpty(), "no name");
281 2040 : sal_Int32 nLength(aProps.getLength());
282 2040 : if(nLength)
283 : {
284 1360 : m_rContext.AddAttribute( XML_NAME, rName );
285 1360 : m_rContext.StartElement( XML_CONFIG_ITEM_SET, true );
286 48764 : for (sal_Int32 i = 0; i < nLength; i++)
287 47404 : CallTypeFunction(aProps[i].Value, aProps[i].Name);
288 1360 : m_rContext.EndElement( true );
289 : }
290 2040 : }
291 1122 : void XMLSettingsExportHelper::exportSymbolDescriptors(
292 : const uno::Sequence < formula::SymbolDescriptor > &rProps,
293 : const OUString& rName) const
294 : {
295 1122 : uno::Reference< container::XIndexContainer > xBox = document::IndexedPropertyValues::create(m_rContext.GetComponentContext());
296 :
297 2244 : const OUString sName ( "Name" );
298 2244 : const OUString sExportName ( "ExportName" );
299 2244 : const OUString sSymbolSet ( "SymbolSet" );
300 2244 : const OUString sCharacter ( "Character" );
301 2244 : const OUString sFontName ( "FontName" );
302 2244 : const OUString sCharSet ( "CharSet" );
303 2244 : const OUString sFamily ( "Family" );
304 2244 : const OUString sPitch ( "Pitch" );
305 2244 : const OUString sWeight ( "Weight" );
306 2244 : const OUString sItalic ( "Italic" );
307 :
308 1122 : sal_Int32 nCount = rProps.getLength();
309 1122 : const formula::SymbolDescriptor *pDescriptor = rProps.getConstArray();
310 :
311 1122 : for( sal_Int32 nIndex = 0; nIndex < nCount; nIndex++, pDescriptor++ )
312 : {
313 0 : uno::Sequence < beans::PropertyValue > aSequence ( XML_SYMBOL_DESCRIPTOR_MAX );
314 0 : beans::PropertyValue *pSymbol = aSequence.getArray();
315 :
316 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_NAME].Name = sName;
317 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_NAME].Value <<= pDescriptor->sName;
318 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_EXPORT_NAME].Name = sExportName;
319 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_EXPORT_NAME].Value<<= pDescriptor->sExportName;
320 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_FONT_NAME].Name = sFontName;
321 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_FONT_NAME].Value <<= pDescriptor->sFontName;
322 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_CHAR_SET].Name = sCharSet;
323 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_CHAR_SET].Value <<= pDescriptor->nCharSet;
324 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_FAMILY].Name = sFamily;
325 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_FAMILY].Value <<= pDescriptor->nFamily;
326 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_PITCH].Name = sPitch;
327 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_PITCH].Value <<= pDescriptor->nPitch;
328 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_WEIGHT].Name = sWeight;
329 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_WEIGHT].Value <<= pDescriptor->nWeight;
330 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_ITALIC].Name = sItalic;
331 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_ITALIC].Value <<= pDescriptor->nItalic;
332 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_SYMBOL_SET].Name = sSymbolSet;
333 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_SYMBOL_SET].Value <<= pDescriptor->sSymbolSet;
334 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_CHARACTER].Name = sCharacter;
335 0 : pSymbol[XML_SYMBOL_DESCRIPTOR_CHARACTER].Value <<= pDescriptor->nCharacter;
336 :
337 0 : xBox->insertByIndex(nIndex, uno::makeAny( aSequence ));
338 0 : }
339 :
340 2244 : uno::Reference< container::XIndexAccess > xIA( xBox, uno::UNO_QUERY );
341 2244 : exportIndexAccess( xIA, rName );
342 1122 : }
343 215 : void XMLSettingsExportHelper::exportbase64Binary(
344 : const uno::Sequence<sal_Int8>& aProps,
345 : const OUString& rName) const
346 : {
347 : DBG_ASSERT(!rName.isEmpty(), "no name");
348 215 : sal_Int32 nLength(aProps.getLength());
349 215 : m_rContext.AddAttribute( XML_NAME, rName );
350 215 : m_rContext.AddAttribute( XML_TYPE, XML_BASE64BINARY );
351 215 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
352 215 : if(nLength)
353 : {
354 48 : OUStringBuffer sBuffer;
355 48 : ::sax::Converter::encodeBase64(sBuffer, aProps);
356 48 : m_rContext.Characters( sBuffer.makeStringAndClear() );
357 : }
358 215 : m_rContext.EndElement( false );
359 215 : }
360 :
361 90 : void XMLSettingsExportHelper::exportMapEntry(const uno::Any& rAny,
362 : const OUString& rName,
363 : const bool bNameAccess) const
364 : {
365 : DBG_ASSERT((bNameAccess && !rName.isEmpty()) || !bNameAccess, "no name");
366 90 : uno::Sequence<beans::PropertyValue> aProps;
367 90 : rAny >>= aProps;
368 90 : sal_Int32 nLength = aProps.getLength();
369 90 : if (nLength)
370 : {
371 90 : if (bNameAccess)
372 5 : m_rContext.AddAttribute( XML_NAME, rName );
373 90 : m_rContext.StartElement( XML_CONFIG_ITEM_MAP_ENTRY, true );
374 1148 : for (sal_Int32 i = 0; i < nLength; i++)
375 1058 : CallTypeFunction(aProps[i].Value, aProps[i].Name);
376 90 : m_rContext.EndElement( true );
377 90 : }
378 90 : }
379 :
380 5 : void XMLSettingsExportHelper::exportNameAccess(
381 : const uno::Reference<container::XNameAccess>& aNamed,
382 : const OUString& rName) const
383 : {
384 : DBG_ASSERT(!rName.isEmpty(), "no name");
385 : DBG_ASSERT(aNamed->getElementType().equals(cppu::UnoType<uno::Sequence<beans::PropertyValue>>::get() ),
386 : "wrong NameAccess" );
387 5 : if(aNamed->hasElements())
388 : {
389 5 : m_rContext.AddAttribute( XML_NAME, rName );
390 5 : m_rContext.StartElement( XML_CONFIG_ITEM_MAP_NAMED, true );
391 5 : uno::Sequence< OUString > aNames(aNamed->getElementNames());
392 10 : for (sal_Int32 i = 0; i < aNames.getLength(); i++)
393 5 : exportMapEntry(aNamed->getByName(aNames[i]), aNames[i], true);
394 5 : m_rContext.EndElement( true );
395 : }
396 5 : }
397 :
398 1381 : void XMLSettingsExportHelper::exportIndexAccess(
399 : const uno::Reference<container::XIndexAccess>& rIndexed,
400 : const OUString& rName) const
401 : {
402 : DBG_ASSERT(!rName.isEmpty(), "no name");
403 : DBG_ASSERT(rIndexed->getElementType().equals(cppu::UnoType<uno::Sequence<beans::PropertyValue>>::get() ),
404 : "wrong IndexAccess" );
405 1381 : OUString sEmpty;
406 1381 : if (rIndexed->hasElements())
407 : {
408 82 : m_rContext.AddAttribute( XML_NAME, rName );
409 82 : m_rContext.StartElement( XML_CONFIG_ITEM_MAP_INDEXED, true );
410 82 : sal_Int32 nCount = rIndexed->getCount();
411 167 : for (sal_Int32 i = 0; i < nCount; i++)
412 : {
413 85 : exportMapEntry(rIndexed->getByIndex(i), sEmpty, false);
414 : }
415 82 : m_rContext.EndElement( true );
416 1381 : }
417 1381 : }
418 :
419 116 : void XMLSettingsExportHelper::exportForbiddenCharacters(
420 : const uno::Any &rAny,
421 : const OUString& rName) const
422 : {
423 116 : uno::Reference<i18n::XForbiddenCharacters> xForbChars;
424 232 : uno::Reference<linguistic2::XSupportedLocales> xLocales;
425 :
426 116 : rAny >>= xForbChars;
427 116 : rAny >>= xLocales;
428 :
429 : DBG_ASSERT( xForbChars.is() && xLocales.is(),"XMLSettingsExportHelper::exportForbiddenCharacters: got illegal forbidden characters!" );
430 :
431 116 : if( !xForbChars.is() || !xLocales.is() )
432 116 : return;
433 :
434 232 : uno::Reference< container::XIndexContainer > xBox = document::IndexedPropertyValues::create(m_rContext.GetComponentContext());
435 232 : const uno::Sequence< lang::Locale > aLocales( xLocales->getLocales() );
436 116 : const lang::Locale* pLocales = aLocales.getConstArray();
437 :
438 116 : const sal_Int32 nCount = aLocales.getLength();
439 :
440 : /* FIXME-BCP47: this stupid and counterpart in
441 : * xmloff/source/core/DocumentSettingsContext.cxx
442 : * XMLConfigItemMapIndexedContext::EndElement() */
443 :
444 232 : const OUString sLanguage ( "Language" );
445 232 : const OUString sCountry ( "Country" );
446 232 : const OUString sVariant ( "Variant" );
447 232 : const OUString sBeginLine ( "BeginLine" );
448 232 : const OUString sEndLine ( "EndLine" );
449 :
450 116 : sal_Int32 nPos = 0;
451 130 : for( sal_Int32 nIndex = 0; nIndex < nCount; nIndex++, pLocales++ )
452 : {
453 14 : if( xForbChars->hasForbiddenCharacters( *pLocales ) )
454 : {
455 14 : const i18n::ForbiddenCharacters aChars( xForbChars->getForbiddenCharacters( *pLocales ) );
456 :
457 :
458 28 : uno::Sequence < beans::PropertyValue > aSequence ( XML_FORBIDDEN_CHARACTER_MAX );
459 14 : beans::PropertyValue *pForChar = aSequence.getArray();
460 :
461 14 : pForChar[XML_FORBIDDEN_CHARACTER_LANGUAGE].Name = sLanguage;
462 14 : pForChar[XML_FORBIDDEN_CHARACTER_LANGUAGE].Value <<= pLocales->Language;
463 14 : pForChar[XML_FORBIDDEN_CHARACTER_COUNTRY].Name = sCountry;
464 14 : pForChar[XML_FORBIDDEN_CHARACTER_COUNTRY].Value <<= pLocales->Country;
465 14 : pForChar[XML_FORBIDDEN_CHARACTER_VARIANT].Name = sVariant;
466 14 : pForChar[XML_FORBIDDEN_CHARACTER_VARIANT].Value <<= pLocales->Variant;
467 14 : pForChar[XML_FORBIDDEN_CHARACTER_BEGIN_LINE].Name = sBeginLine;
468 14 : pForChar[XML_FORBIDDEN_CHARACTER_BEGIN_LINE].Value <<= aChars.beginLine;
469 14 : pForChar[XML_FORBIDDEN_CHARACTER_END_LINE].Name = sEndLine;
470 14 : pForChar[XML_FORBIDDEN_CHARACTER_END_LINE].Value <<= aChars.endLine;
471 28 : xBox->insertByIndex(nPos++, uno::makeAny( aSequence ));
472 : }
473 : }
474 :
475 232 : uno::Reference< container::XIndexAccess > xIA( xBox, uno::UNO_QUERY );
476 232 : exportIndexAccess( xIA, rName );
477 : }
478 :
479 1357 : void XMLSettingsExportHelper::exportAllSettings(
480 : const uno::Sequence<beans::PropertyValue>& aProps,
481 : const OUString& rName) const
482 : {
483 : DBG_ASSERT(!rName.isEmpty(), "no name");
484 1357 : exportSequencePropertyValue(aProps, rName);
485 1357 : }
486 :
487 :
488 : /** For some settings we may want to change their API representation
489 : * from their XML settings representation. This is your chance to do
490 : * so!
491 : */
492 48462 : void XMLSettingsExportHelper::ManipulateSetting( uno::Any& rAny, const OUString& rName ) const
493 : {
494 48462 : if( rName == msPrinterIndependentLayout )
495 : {
496 87 : sal_Int16 nTmp = sal_Int16();
497 87 : if( rAny >>= nTmp )
498 : {
499 87 : if( nTmp == document::PrinterIndependentLayout::LOW_RESOLUTION )
500 15 : rAny <<= OUString("low-resolution");
501 72 : else if( nTmp == document::PrinterIndependentLayout::DISABLED )
502 3 : rAny <<= OUString("disabled");
503 69 : else if( nTmp == document::PrinterIndependentLayout::HIGH_RESOLUTION )
504 69 : rAny <<= OUString("high-resolution");
505 : }
506 : }
507 193440 : else if( (rName == msColorTableURL) || (rName == msLineEndTableURL) || (rName == msHatchTableURL) ||
508 145020 : (rName == msDashTableURL) || (rName == msGradientTableURL) || (rName == msBitmapTableURL ) )
509 : {
510 90 : if( !mxStringSubsitution.is() )
511 : {
512 : try
513 : {
514 45 : const_cast< XMLSettingsExportHelper* >(this)->mxStringSubsitution =
515 30 : util::PathSubstitution::create( m_rContext.GetComponentContext() );
516 : }
517 0 : catch( uno::Exception& )
518 : {
519 : DBG_UNHANDLED_EXCEPTION();
520 : }
521 : }
522 :
523 90 : if( mxStringSubsitution.is() )
524 : {
525 90 : OUString aURL;
526 90 : rAny >>= aURL;
527 90 : aURL = mxStringSubsitution->reSubstituteVariables( aURL );
528 90 : rAny <<= aURL;
529 : }
530 : }
531 48462 : }
532 :
533 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|