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 1430 : 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 1430 : , msBitmapTableURL( "BitmapTableURL" )
57 : {
58 1430 : }
59 :
60 1430 : XMLSettingsExportHelper::~XMLSettingsExportHelper()
61 : {
62 1430 : }
63 :
64 87310 : void XMLSettingsExportHelper::CallTypeFunction(const uno::Any& rAny,
65 : const OUString& rName) const
66 : {
67 87310 : uno::Any aAny( rAny );
68 87310 : ManipulateSetting( aAny, rName );
69 :
70 87310 : uno::TypeClass eClass = aAny.getValueTypeClass();
71 87310 : 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 5600 : break;
83 : case uno::TypeClass_BOOLEAN:
84 : {
85 24618 : exportBool(::cppu::any2bool(aAny), rName);
86 : }
87 24618 : 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 36284 : sal_Int16 nInt16 = 0;
98 36284 : aAny >>= nInt16;
99 36284 : exportShort(nInt16, rName);
100 : }
101 36284 : break;
102 : case uno::TypeClass_LONG:
103 : {
104 2202 : sal_Int32 nInt32 = 0;
105 2202 : aAny >>= nInt32;
106 2202 : exportInt(nInt32, rName);
107 : }
108 2202 : break;
109 : case uno::TypeClass_HYPER:
110 : {
111 4990 : sal_Int64 nInt64 = 0;
112 4990 : aAny >>= nInt64;
113 4990 : exportLong(nInt64, rName);
114 : }
115 4990 : 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 9618 : OUString sString;
126 9618 : aAny >>= sString;
127 9618 : exportString(sString, rName);
128 : }
129 9618 : break;
130 : default:
131 : {
132 3998 : uno::Type aType = aAny.getValueType();
133 3998 : if (aType.equals(getCppuType( (uno::Sequence<beans::PropertyValue> *)0 ) ) )
134 : {
135 1258 : uno::Sequence< beans::PropertyValue> aProps;
136 1258 : aAny >>= aProps;
137 1258 : exportSequencePropertyValue(aProps, rName);
138 : }
139 2740 : else if( aType.equals(getCppuType( (uno::Sequence<sal_Int8> *)0 ) ) )
140 : {
141 216 : uno::Sequence< sal_Int8 > aProps;
142 216 : aAny >>= aProps;
143 216 : exportbase64Binary(aProps, rName);
144 : }
145 5038 : else if (aType.equals(cppu::UnoType<container::XNameContainer>::get()) ||
146 2514 : aType.equals(cppu::UnoType<container::XNameAccess>::get()))
147 : {
148 10 : uno::Reference< container::XNameAccess> aNamed;
149 10 : aAny >>= aNamed;
150 10 : exportNameAccess(aNamed, rName);
151 : }
152 4936 : else if (aType.equals(cppu::UnoType<container::XIndexAccess>::get()) ||
153 2422 : aType.equals(cppu::UnoType<container::XIndexContainer>::get()) )
154 : {
155 150 : uno::Reference<container::XIndexAccess> aIndexed;
156 150 : aAny >>= aIndexed;
157 150 : exportIndexAccess(aIndexed, rName);
158 : }
159 2364 : 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 2364 : else if( aType.equals(cppu::UnoType<i18n::XForbiddenCharacters>::get()) )
166 : {
167 128 : exportForbiddenCharacters( aAny, rName );
168 : }
169 2236 : else if( aType.equals(getCppuType( (uno::Sequence<formula::SymbolDescriptor> *)0 ) ) )
170 : {
171 2236 : uno::Sequence< formula::SymbolDescriptor > aProps;
172 2236 : aAny >>= aProps;
173 2236 : exportSymbolDescriptors(aProps, rName);
174 : }
175 : else {
176 : OSL_FAIL("this type is not implemented now");
177 3998 : }
178 : }
179 3998 : break;
180 87310 : }
181 87310 : }
182 :
183 24618 : void XMLSettingsExportHelper::exportBool(const bool bValue, const OUString& rName) const
184 : {
185 : DBG_ASSERT(!rName.isEmpty(), "no name");
186 24618 : m_rContext.AddAttribute( XML_NAME, rName );
187 24618 : m_rContext.AddAttribute( XML_TYPE, XML_BOOLEAN );
188 24618 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
189 24618 : OUString sValue;
190 24618 : if (bValue)
191 3480 : sValue = GetXMLToken(XML_TRUE);
192 : else
193 21138 : sValue = GetXMLToken(XML_FALSE);
194 24618 : m_rContext.Characters( sValue );
195 24618 : m_rContext.EndElement( false );
196 24618 : }
197 :
198 0 : void XMLSettingsExportHelper::exportByte(const sal_Int8 nValue, const OUString& rName) const
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 36284 : void XMLSettingsExportHelper::exportShort(const sal_Int16 nValue, const OUString& rName) const
207 : {
208 : DBG_ASSERT(!rName.isEmpty(), "no name");
209 36284 : m_rContext.AddAttribute( XML_NAME, rName );
210 36284 : m_rContext.AddAttribute( XML_TYPE, XML_SHORT );
211 36284 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
212 36284 : OUStringBuffer sBuffer;
213 36284 : ::sax::Converter::convertNumber(sBuffer, sal_Int32(nValue));
214 36284 : m_rContext.Characters( sBuffer.makeStringAndClear() );
215 36284 : m_rContext.EndElement( false );
216 36284 : }
217 :
218 2202 : void XMLSettingsExportHelper::exportInt(const sal_Int32 nValue, const OUString& rName) const
219 : {
220 : DBG_ASSERT(!rName.isEmpty(), "no name");
221 2202 : m_rContext.AddAttribute( XML_NAME, rName );
222 2202 : m_rContext.AddAttribute( XML_TYPE, XML_INT );
223 2202 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
224 2202 : OUStringBuffer sBuffer;
225 2202 : ::sax::Converter::convertNumber(sBuffer, nValue);
226 2202 : m_rContext.Characters( sBuffer.makeStringAndClear() );
227 2202 : m_rContext.EndElement( false );
228 2202 : }
229 :
230 4990 : void XMLSettingsExportHelper::exportLong(const sal_Int64 nValue, const OUString& rName) const
231 : {
232 : DBG_ASSERT(!rName.isEmpty(), "no name");
233 4990 : m_rContext.AddAttribute( XML_NAME, rName );
234 4990 : m_rContext.AddAttribute( XML_TYPE, XML_LONG );
235 4990 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
236 4990 : OUString sValue(OUString::number(nValue));
237 4990 : m_rContext.Characters( sValue );
238 4990 : m_rContext.EndElement( false );
239 4990 : }
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 9618 : void XMLSettingsExportHelper::exportString(const OUString& sValue, const OUString& rName) const
254 : {
255 : DBG_ASSERT(!rName.isEmpty(), "no name");
256 9618 : m_rContext.AddAttribute( XML_NAME, rName );
257 9618 : m_rContext.AddAttribute( XML_TYPE, XML_STRING );
258 9618 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
259 9618 : if (!sValue.isEmpty())
260 8210 : m_rContext.Characters( sValue );
261 9618 : m_rContext.EndElement( false );
262 9618 : }
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 3756 : void XMLSettingsExportHelper::exportSequencePropertyValue(
277 : const uno::Sequence<beans::PropertyValue>& aProps,
278 : const OUString& rName) const
279 : {
280 : DBG_ASSERT(!rName.isEmpty(), "no name");
281 3756 : sal_Int32 nLength(aProps.getLength());
282 3756 : if(nLength)
283 : {
284 2504 : m_rContext.AddAttribute( XML_NAME, rName );
285 2504 : m_rContext.StartElement( XML_CONFIG_ITEM_SET, true );
286 88458 : for (sal_Int32 i = 0; i < nLength; i++)
287 85954 : CallTypeFunction(aProps[i].Value, aProps[i].Name);
288 2504 : m_rContext.EndElement( true );
289 : }
290 3756 : }
291 2236 : void XMLSettingsExportHelper::exportSymbolDescriptors(
292 : const uno::Sequence < formula::SymbolDescriptor > &rProps,
293 : const OUString& rName) const
294 : {
295 2236 : uno::Reference< container::XIndexContainer > xBox = document::IndexedPropertyValues::create(m_rContext.GetComponentContext());
296 :
297 4472 : const OUString sName ( "Name" );
298 4472 : const OUString sExportName ( "ExportName" );
299 4472 : const OUString sSymbolSet ( "SymbolSet" );
300 4472 : const OUString sCharacter ( "Character" );
301 4472 : const OUString sFontName ( "FontName" );
302 4472 : const OUString sCharSet ( "CharSet" );
303 4472 : const OUString sFamily ( "Family" );
304 4472 : const OUString sPitch ( "Pitch" );
305 4472 : const OUString sWeight ( "Weight" );
306 4472 : const OUString sItalic ( "Italic" );
307 :
308 2236 : sal_Int32 nCount = rProps.getLength();
309 2236 : const formula::SymbolDescriptor *pDescriptor = rProps.getConstArray();
310 :
311 2236 : 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 4472 : uno::Reference< container::XIndexAccess > xIA( xBox, uno::UNO_QUERY );
341 4472 : exportIndexAccess( xIA, rName );
342 2236 : }
343 216 : void XMLSettingsExportHelper::exportbase64Binary(
344 : const uno::Sequence<sal_Int8>& aProps,
345 : const OUString& rName) const
346 : {
347 : DBG_ASSERT(!rName.isEmpty(), "no name");
348 216 : sal_Int32 nLength(aProps.getLength());
349 216 : m_rContext.AddAttribute( XML_NAME, rName );
350 216 : m_rContext.AddAttribute( XML_TYPE, XML_BASE64BINARY );
351 216 : m_rContext.StartElement( XML_CONFIG_ITEM, true );
352 216 : if(nLength)
353 : {
354 60 : OUStringBuffer sBuffer;
355 60 : ::sax::Converter::encodeBase64(sBuffer, aProps);
356 60 : m_rContext.Characters( sBuffer.makeStringAndClear() );
357 : }
358 216 : m_rContext.EndElement( false );
359 216 : }
360 :
361 114 : 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 114 : uno::Sequence<beans::PropertyValue> aProps;
367 114 : rAny >>= aProps;
368 114 : sal_Int32 nLength = aProps.getLength();
369 114 : if (nLength)
370 : {
371 114 : if (bNameAccess)
372 10 : m_rContext.AddAttribute( XML_NAME, rName );
373 114 : m_rContext.StartElement( XML_CONFIG_ITEM_MAP_ENTRY, true );
374 1470 : for (sal_Int32 i = 0; i < nLength; i++)
375 1356 : CallTypeFunction(aProps[i].Value, aProps[i].Name);
376 114 : m_rContext.EndElement( true );
377 114 : }
378 114 : }
379 :
380 10 : 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(getCppuType( (uno::Sequence<beans::PropertyValue> *)0 ) ),
386 : "wrong NameAccess" );
387 10 : if(aNamed->hasElements())
388 : {
389 10 : m_rContext.AddAttribute( XML_NAME, rName );
390 10 : m_rContext.StartElement( XML_CONFIG_ITEM_MAP_NAMED, true );
391 10 : uno::Sequence< OUString > aNames(aNamed->getElementNames());
392 20 : for (sal_Int32 i = 0; i < aNames.getLength(); i++)
393 10 : exportMapEntry(aNamed->getByName(aNames[i]), aNames[i], true);
394 10 : m_rContext.EndElement( true );
395 : }
396 10 : }
397 :
398 2514 : void XMLSettingsExportHelper::exportIndexAccess(
399 : const uno::Reference<container::XIndexAccess> aIndexed,
400 : const OUString& rName) const
401 : {
402 : DBG_ASSERT(!rName.isEmpty(), "no name");
403 : DBG_ASSERT(aIndexed->getElementType().equals(getCppuType( (uno::Sequence<beans::PropertyValue> *)0 ) ),
404 : "wrong IndexAccess" );
405 2514 : OUString sEmpty;
406 2514 : if(aIndexed->hasElements())
407 : {
408 104 : m_rContext.AddAttribute( XML_NAME, rName );
409 104 : m_rContext.StartElement( XML_CONFIG_ITEM_MAP_INDEXED, true );
410 104 : sal_Int32 nCount = aIndexed->getCount();
411 208 : for (sal_Int32 i = 0; i < nCount; i++)
412 : {
413 104 : exportMapEntry(aIndexed->getByIndex(i), sEmpty, false);
414 : }
415 104 : m_rContext.EndElement( true );
416 2514 : }
417 2514 : }
418 :
419 128 : void XMLSettingsExportHelper::exportForbiddenCharacters(
420 : const uno::Any &rAny,
421 : const OUString& rName) const
422 : {
423 128 : uno::Reference<i18n::XForbiddenCharacters> xForbChars;
424 256 : uno::Reference<linguistic2::XSupportedLocales> xLocales;
425 :
426 128 : rAny >>= xForbChars;
427 128 : rAny >>= xLocales;
428 :
429 : DBG_ASSERT( xForbChars.is() && xLocales.is(),"XMLSettingsExportHelper::exportForbiddenCharacters: got illegal forbidden characters!" );
430 :
431 128 : if( !xForbChars.is() || !xLocales.is() )
432 128 : return;
433 :
434 256 : uno::Reference< container::XIndexContainer > xBox = document::IndexedPropertyValues::create(m_rContext.GetComponentContext());
435 256 : const uno::Sequence< lang::Locale > aLocales( xLocales->getLocales() );
436 128 : const lang::Locale* pLocales = aLocales.getConstArray();
437 :
438 128 : 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 256 : const OUString sLanguage ( "Language" );
445 256 : const OUString sCountry ( "Country" );
446 256 : const OUString sVariant ( "Variant" );
447 256 : const OUString sBeginLine ( "BeginLine" );
448 256 : const OUString sEndLine ( "EndLine" );
449 :
450 128 : sal_Int32 nPos = 0;
451 140 : for( sal_Int32 nIndex = 0; nIndex < nCount; nIndex++, pLocales++ )
452 : {
453 12 : if( xForbChars->hasForbiddenCharacters( *pLocales ) )
454 : {
455 12 : const i18n::ForbiddenCharacters aChars( xForbChars->getForbiddenCharacters( *pLocales ) );
456 :
457 :
458 24 : uno::Sequence < beans::PropertyValue > aSequence ( XML_FORBIDDEN_CHARACTER_MAX );
459 12 : beans::PropertyValue *pForChar = aSequence.getArray();
460 :
461 12 : pForChar[XML_FORBIDDEN_CHARACTER_LANGUAGE].Name = sLanguage;
462 12 : pForChar[XML_FORBIDDEN_CHARACTER_LANGUAGE].Value <<= pLocales->Language;
463 12 : pForChar[XML_FORBIDDEN_CHARACTER_COUNTRY].Name = sCountry;
464 12 : pForChar[XML_FORBIDDEN_CHARACTER_COUNTRY].Value <<= pLocales->Country;
465 12 : pForChar[XML_FORBIDDEN_CHARACTER_VARIANT].Name = sVariant;
466 12 : pForChar[XML_FORBIDDEN_CHARACTER_VARIANT].Value <<= pLocales->Variant;
467 12 : pForChar[XML_FORBIDDEN_CHARACTER_BEGIN_LINE].Name = sBeginLine;
468 12 : pForChar[XML_FORBIDDEN_CHARACTER_BEGIN_LINE].Value <<= aChars.beginLine;
469 12 : pForChar[XML_FORBIDDEN_CHARACTER_END_LINE].Name = sEndLine;
470 12 : pForChar[XML_FORBIDDEN_CHARACTER_END_LINE].Value <<= aChars.endLine;
471 24 : xBox->insertByIndex(nPos++, uno::makeAny( aSequence ));
472 : }
473 : }
474 :
475 256 : uno::Reference< container::XIndexAccess > xIA( xBox, uno::UNO_QUERY );
476 256 : exportIndexAccess( xIA, rName );
477 : }
478 :
479 2498 : void XMLSettingsExportHelper::exportAllSettings(
480 : const uno::Sequence<beans::PropertyValue>& aProps,
481 : const OUString& rName) const
482 : {
483 : DBG_ASSERT(!rName.isEmpty(), "no name");
484 2498 : exportSequencePropertyValue(aProps, rName);
485 2498 : }
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 87310 : void XMLSettingsExportHelper::ManipulateSetting( uno::Any& rAny, const OUString& rName ) const
493 : {
494 87310 : if( rName == msPrinterIndependentLayout )
495 : {
496 80 : sal_Int16 nTmp = sal_Int16();
497 80 : if( rAny >>= nTmp )
498 : {
499 80 : if( nTmp == document::PrinterIndependentLayout::LOW_RESOLUTION )
500 22 : rAny <<= OUString("low-resolution");
501 58 : else if( nTmp == document::PrinterIndependentLayout::DISABLED )
502 2 : rAny <<= OUString("disabled");
503 56 : else if( nTmp == document::PrinterIndependentLayout::HIGH_RESOLUTION )
504 56 : rAny <<= OUString("high-resolution");
505 : }
506 : }
507 348832 : else if( (rName == msColorTableURL) || (rName == msLineEndTableURL) || (rName == msHatchTableURL) ||
508 261536 : (rName == msDashTableURL) || (rName == msGradientTableURL) || (rName == msBitmapTableURL ) )
509 : {
510 132 : if( !mxStringSubsitution.is() )
511 : {
512 : try
513 : {
514 66 : const_cast< XMLSettingsExportHelper* >(this)->mxStringSubsitution =
515 44 : util::PathSubstitution::create( m_rContext.GetComponentContext() );
516 : }
517 0 : catch( uno::Exception& )
518 : {
519 : DBG_UNHANDLED_EXCEPTION();
520 : }
521 : }
522 :
523 132 : if( mxStringSubsitution.is() )
524 : {
525 132 : OUString aURL;
526 132 : rAny >>= aURL;
527 132 : aURL = mxStringSubsitution->reSubstituteVariables( aURL );
528 132 : rAny <<= aURL;
529 : }
530 : }
531 87310 : }
532 :
533 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|