LibreOffice Module xmloff (master)  1
undlihdl.cxx
Go to the documentation of this file.
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 "undlihdl.hxx"
21 #include <xmloff/xmltoken.hxx>
22 #include <xmloff/xmluconv.hxx>
23 #include <xmloff/xmlement.hxx>
24 #include <rtl/ustrbuf.hxx>
25 #include <osl/diagnose.h>
26 
27 #include <com/sun/star/uno/Any.hxx>
28 #include <com/sun/star/awt/FontUnderline.hpp>
29 
30 using namespace ::com::sun::star;
31 using namespace ::com::sun::star::awt;
32 using namespace ::xmloff::token;
33 
35 {
36  { XML_NONE, awt::FontUnderline::NONE },
37  { XML_SINGLE, awt::FontUnderline::SINGLE },
38  { XML_DOUBLE, awt::FontUnderline::DOUBLE },
39  { XML_SINGLE, awt::FontUnderline::DOTTED },
40  { XML_SINGLE, awt::FontUnderline::DASH },
41  { XML_SINGLE, awt::FontUnderline::LONGDASH },
42  { XML_SINGLE, awt::FontUnderline::DASHDOT },
43  { XML_SINGLE, awt::FontUnderline::DASHDOTDOT },
44  { XML_SINGLE, awt::FontUnderline::WAVE },
45  { XML_SINGLE, awt::FontUnderline::BOLD },
46  { XML_SINGLE, awt::FontUnderline::BOLDDOTTED },
47  { XML_SINGLE, awt::FontUnderline::BOLDDASH },
48  { XML_SINGLE, awt::FontUnderline::BOLDLONGDASH },
49  { XML_SINGLE, awt::FontUnderline::BOLDDASHDOT },
50  { XML_SINGLE, awt::FontUnderline::BOLDDASHDOTDOT },
51  { XML_SINGLE, awt::FontUnderline::BOLDWAVE },
52  { XML_DOUBLE, awt::FontUnderline::DOUBLEWAVE },
53  { XML_SINGLE, awt::FontUnderline::SMALLWAVE },
54  { XML_TOKEN_INVALID, 0 }
55 };
56 
58 {
59  { XML_NONE, awt::FontUnderline::NONE },
60  { XML_SOLID, awt::FontUnderline::SINGLE },
61  { XML_SOLID, awt::FontUnderline::DOUBLE },
62  { XML_DOTTED, awt::FontUnderline::DOTTED },
63  { XML_DASH, awt::FontUnderline::DASH },
64  { XML_LONG_DASH, awt::FontUnderline::LONGDASH },
65  { XML_DOT_DASH, awt::FontUnderline::DASHDOT },
66  { XML_DOT_DOT_DASH, awt::FontUnderline::DASHDOTDOT },
67  { XML_WAVE, awt::FontUnderline::WAVE },
68  { XML_SOLID, awt::FontUnderline::BOLD },
69  { XML_DOTTED, awt::FontUnderline::BOLDDOTTED },
70  { XML_DASH, awt::FontUnderline::BOLDDASH },
71  { XML_LONG_DASH, awt::FontUnderline::BOLDLONGDASH },
72  { XML_DOT_DASH, awt::FontUnderline::BOLDDASHDOT },
73  { XML_DOT_DOT_DASH, awt::FontUnderline::BOLDDASHDOTDOT },
74  { XML_WAVE, awt::FontUnderline::BOLDWAVE },
75  { XML_WAVE, awt::FontUnderline::DOUBLEWAVE },
76  { XML_SMALL_WAVE, awt::FontUnderline::SMALLWAVE },
77  { XML_TOKEN_INVALID, 0 }
78 };
79 
81 {
82  { XML_AUTO, awt::FontUnderline::NONE },
83  { XML_AUTO, awt::FontUnderline::SINGLE },
84  { XML_AUTO, awt::FontUnderline::DOUBLE },
85  { XML_AUTO, awt::FontUnderline::DOTTED },
86  { XML_AUTO, awt::FontUnderline::DASH },
87  { XML_AUTO, awt::FontUnderline::LONGDASH },
88  { XML_AUTO, awt::FontUnderline::DASHDOT },
89  { XML_AUTO, awt::FontUnderline::DASHDOTDOT },
90  { XML_AUTO, awt::FontUnderline::WAVE },
91  { XML_BOLD, awt::FontUnderline::BOLD },
92  { XML_BOLD, awt::FontUnderline::BOLDDOTTED },
93  { XML_BOLD, awt::FontUnderline::BOLDDASH },
94  { XML_BOLD, awt::FontUnderline::BOLDLONGDASH },
95  { XML_BOLD, awt::FontUnderline::BOLDDASHDOT },
96  { XML_BOLD, awt::FontUnderline::BOLDDASHDOTDOT },
97  { XML_BOLD, awt::FontUnderline::BOLDWAVE },
98  { XML_AUTO, awt::FontUnderline::DOUBLEWAVE },
99  { XML_THIN, awt::FontUnderline::NONE },
100  { XML_MEDIUM, awt::FontUnderline::NONE },
101  { XML_THICK, awt::FontUnderline::BOLD},
102  { XML_TOKEN_INVALID, 0 }
103 };
104 
105 
106 
107 
109 {
110  // nothing to do
111 }
112 
113 bool XMLUnderlineTypePropHdl::importXML( const OUString& rStrImpValue, uno::Any& rValue, const SvXMLUnitConverter& ) const
114 {
115  sal_uInt16 eNewUnderline(0);
117  eNewUnderline, rStrImpValue, pXML_UnderlineType_Enum );
118  if( bRet )
119  {
120  // multi property: style and width might be set already.
121  // If the old value is NONE, the new is used unchanged.
122  sal_Int16 eUnderline = sal_Int16();
123  if( (rValue >>= eUnderline) && awt::FontUnderline::NONE!=eUnderline )
124  {
125  switch( eNewUnderline )
126  {
127  case awt::FontUnderline::NONE:
128  case awt::FontUnderline::SINGLE:
129  // keep existing line style
130  eNewUnderline = eUnderline;
131  break;
132  case awt::FontUnderline::DOUBLE:
133  // A double line style has priority over a bold line style,
134  // but not over the line style itself.
135  switch( eUnderline )
136  {
137  case awt::FontUnderline::SINGLE:
138  case awt::FontUnderline::BOLD:
139  break;
140  case awt::FontUnderline::WAVE:
141  case awt::FontUnderline::BOLDWAVE:
142  eNewUnderline = awt::FontUnderline::DOUBLEWAVE;
143  break;
144  default:
145  // If a double line style is not supported for the existing
146  // value, keep the new one
147  eNewUnderline = eUnderline;
148  break;
149  }
150  break;
151  default:
152  OSL_ENSURE( bRet, "unexpected line type value" );
153  break;
154  }
155  if( eNewUnderline != eUnderline )
156  rValue <<= static_cast<sal_Int16>(eNewUnderline);
157  }
158  else
159  {
160  rValue <<= static_cast<sal_Int16>(eNewUnderline);
161  }
162  }
163 
164  return bRet;
165 }
166 
167 bool XMLUnderlineTypePropHdl::exportXML( OUString& rStrExpValue, const uno::Any& rValue, const SvXMLUnitConverter& ) const
168 {
169  bool bRet = false;
170  sal_uInt16 nValue = sal_uInt16();
171 
172  if( (rValue >>= nValue) &&
173  (awt::FontUnderline::DOUBLE == nValue ||
174  awt::FontUnderline::DOUBLEWAVE == nValue) )
175  {
176  OUStringBuffer aOut;
178  aOut, nValue, pXML_UnderlineType_Enum );
179  if( bRet )
180  rStrExpValue = aOut.makeStringAndClear();
181  }
182 
183  return bRet;
184 }
185 
186 
187 
188 
190 {
191  // nothing to do
192 }
193 
194 bool XMLUnderlineStylePropHdl::importXML( const OUString& rStrImpValue, uno::Any& rValue, const SvXMLUnitConverter& ) const
195 {
196  sal_uInt16 eNewUnderline(0);
198  eNewUnderline, rStrImpValue, pXML_UnderlineStyle_Enum );
199  if( bRet )
200  {
201  // multi property: style and width might be set already.
202  // If the old value is NONE, the new is used unchanged.
203  sal_Int16 eUnderline = sal_Int16();
204  if( (rValue >>= eUnderline) && awt::FontUnderline::NONE!=eUnderline )
205  {
206  switch( eNewUnderline )
207  {
208  case awt::FontUnderline::NONE:
209  case awt::FontUnderline::SINGLE:
210  // keep double or bold line style
211  eNewUnderline = eUnderline;
212  break;
213  case awt::FontUnderline::DOTTED:
214  // The line style has priority over a double type.
215  if( awt::FontUnderline::BOLD == eUnderline )
216  eNewUnderline = awt::FontUnderline::BOLDDOTTED;
217  break;
218  case awt::FontUnderline::DASH:
219  if( awt::FontUnderline::BOLD == eUnderline )
220  eNewUnderline = awt::FontUnderline::BOLDDASH;
221  break;
222  case awt::FontUnderline::LONGDASH:
223  if( awt::FontUnderline::BOLD == eUnderline )
224  eNewUnderline = awt::FontUnderline::BOLDLONGDASH;
225  break;
226  case awt::FontUnderline::DASHDOT:
227  if( awt::FontUnderline::BOLD == eUnderline )
228  eNewUnderline = awt::FontUnderline::BOLDDASHDOT;
229  break;
230  case awt::FontUnderline::DASHDOTDOT:
231  if( awt::FontUnderline::BOLD == eUnderline )
232  eNewUnderline = awt::FontUnderline::BOLDDASHDOTDOT;
233  break;
234  case awt::FontUnderline::WAVE:
235  if( awt::FontUnderline::DOUBLE == eUnderline )
236  eNewUnderline = awt::FontUnderline::DOUBLEWAVE;
237  else if( awt::FontUnderline::BOLD == eUnderline )
238  eNewUnderline = awt::FontUnderline::BOLDWAVE;
239  break;
240  case awt::FontUnderline::SMALLWAVE:
241  // SMALLWAVE is not used
242  default:
243  OSL_ENSURE( bRet, "unexpected line style value" );
244  break;
245  }
246  if( eNewUnderline != eUnderline )
247  rValue <<= static_cast<sal_Int16>(eNewUnderline);
248  }
249  else
250  {
251  rValue <<= static_cast<sal_Int16>(eNewUnderline);
252  }
253  }
254 
255  return bRet;
256 }
257 
258 bool XMLUnderlineStylePropHdl::exportXML( OUString& rStrExpValue, const uno::Any& rValue, const SvXMLUnitConverter& ) const
259 {
260  bool bRet = false;
261  sal_uInt16 nValue = sal_uInt16();
262 
263  if( rValue >>= nValue )
264  {
265  OUStringBuffer aOut;
267  aOut, nValue, pXML_UnderlineStyle_Enum );
268  if( bRet )
269  rStrExpValue = aOut.makeStringAndClear();
270  }
271 
272  return bRet;
273 }
274 
275 
276 
277 
279 {
280  // nothing to do
281 }
282 
283 bool XMLUnderlineWidthPropHdl::importXML( const OUString& rStrImpValue, uno::Any& rValue, const SvXMLUnitConverter& ) const
284 {
285  sal_uInt16 eNewUnderline(0);
287  eNewUnderline, rStrImpValue, pXML_UnderlineWidth_Enum );
288  if( bRet )
289  {
290  // multi property: style and width might be set already.
291  // If the old value is NONE, the new is used unchanged.
292  sal_Int16 eUnderline = sal_Int16();
293  if( (rValue >>= eUnderline) && awt::FontUnderline::NONE!=eUnderline )
294  {
295  switch( eNewUnderline )
296  {
297  case awt::FontUnderline::NONE:
298  // keep existing line style
299  eNewUnderline = eUnderline;
300  break;
301  case awt::FontUnderline::BOLD:
302  // A double line style has priority over a bold line style,
303  // but not over the line style itself.
304  switch( eUnderline )
305  {
306  case awt::FontUnderline::SINGLE:
307  break;
308  case awt::FontUnderline::DOTTED:
309  eNewUnderline = awt::FontUnderline::BOLDDOTTED;
310  break;
311  case awt::FontUnderline::DASH:
312  eNewUnderline = awt::FontUnderline::BOLDDASH;
313  break;
314  case awt::FontUnderline::LONGDASH:
315  eNewUnderline = awt::FontUnderline::BOLDLONGDASH;
316  break;
317  case awt::FontUnderline::DASHDOT:
318  eNewUnderline = awt::FontUnderline::BOLDDASHDOT;
319  break;
320  case awt::FontUnderline::DASHDOTDOT:
321  eNewUnderline = awt::FontUnderline::BOLDDASHDOTDOT;
322  break;
323  case awt::FontUnderline::WAVE:
324  eNewUnderline = awt::FontUnderline::BOLDWAVE;
325  break;
326  default:
327  // a double line style overwrites a bold one
328  eNewUnderline = eUnderline;
329  break;
330  }
331  break;
332  default:
333  OSL_ENSURE( bRet, "unexpected line width value" );
334  break;
335  }
336  if( eNewUnderline != eUnderline )
337  rValue <<= static_cast<sal_Int16>(eNewUnderline);
338  }
339  else
340  {
341  rValue <<= static_cast<sal_Int16>(eNewUnderline);
342  }
343  }
344 
345  return bRet;
346 }
347 
348 bool XMLUnderlineWidthPropHdl::exportXML( OUString& rStrExpValue, const uno::Any& rValue, const SvXMLUnitConverter& ) const
349 {
350  bool bRet = false;
351  sal_uInt16 nValue = sal_uInt16();
352 
353  if( (rValue >>= nValue) && (awt::FontUnderline::NONE != nValue) )
354  {
355  OUStringBuffer aOut;
357  aOut, nValue, pXML_UnderlineWidth_Enum );
358  if( bRet )
359  rStrExpValue = aOut.makeStringAndClear();
360  }
361 
362  return bRet;
363 }
364 
365 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
static bool convertEnum(EnumT &rEnum, const OUString &rValue, const SvXMLEnumMapEntry< EnumT > *pMap)
convert string to enum using given enum map, if the enum is not found in the map, this method will re...
Definition: xmluconv.hxx:128
the SvXMLTypeConverter converts values of various types from their internal representation to the tex...
Definition: xmluconv.hxx:77
virtual ~XMLUnderlineStylePropHdl() override
Definition: undlihdl.cxx:189
css::uno::Any const & rValue
Definition: ImageStyle.hxx:38
virtual bool exportXML(OUString &rStrExpValue, const css::uno::Any &rValue, const SvXMLUnitConverter &rUnitConverter) const override
Exports the given value according to the XML-data-type corresponding to the derived class...
Definition: undlihdl.cxx:167
virtual bool importXML(const OUString &rStrImpValue, css::uno::Any &rValue, const SvXMLUnitConverter &rUnitConverter) const override
Imports the given value according to the XML-data-type corresponding to the derived class...
Definition: undlihdl.cxx:194
virtual ~XMLUnderlineWidthPropHdl() override
Definition: undlihdl.cxx:278
virtual ~XMLUnderlineTypePropHdl() override
Definition: undlihdl.cxx:108
virtual bool importXML(const OUString &rStrImpValue, css::uno::Any &rValue, const SvXMLUnitConverter &rUnitConverter) const override
Imports the given value according to the XML-data-type corresponding to the derived class...
Definition: undlihdl.cxx:283
virtual bool exportXML(OUString &rStrExpValue, const css::uno::Any &rValue, const SvXMLUnitConverter &rUnitConverter) const override
Exports the given value according to the XML-data-type corresponding to the derived class...
Definition: undlihdl.cxx:258
SvXMLEnumMapEntry< sal_uInt16 > const pXML_UnderlineWidth_Enum[]
Definition: undlihdl.cxx:80
SvXMLEnumMapEntry< sal_uInt16 > const pXML_UnderlineType_Enum[]
Definition: undlihdl.cxx:34
Handling of tokens in XML:
virtual bool importXML(const OUString &rStrImpValue, css::uno::Any &rValue, const SvXMLUnitConverter &rUnitConverter) const override
Imports the given value according to the XML-data-type corresponding to the derived class...
Definition: undlihdl.cxx:113
virtual bool exportXML(OUString &rStrExpValue, const css::uno::Any &rValue, const SvXMLUnitConverter &rUnitConverter) const override
Exports the given value according to the XML-data-type corresponding to the derived class...
Definition: undlihdl.cxx:348
SvXMLEnumMapEntry< sal_uInt16 > const pXML_UnderlineStyle_Enum[]
Definition: undlihdl.cxx:57
sal_Int16 nValue