1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
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/.
9 * This file incorporates work covered by the following license notice:
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 .
22 #include <osl/diagnose.h>
23 #include <rtl/ustrbuf.hxx>
24 #include <cppuhelper/servicefactory.hxx>
26 #include <com/sun/star/lang/XComponent.hpp>
27 #include <com/sun/star/lang/XServiceInfo.hpp>
28 #include <com/sun/star/script/XTypeConverter.hpp>
29 #include <com/sun/star/reflection/FieldAccessMode.hpp>
30 #include <com/sun/star/registry/XImplementationRegistration.hpp>
38 using namespace com::sun::star::uno
;
39 using namespace com::sun::star::lang
;
40 using namespace com::sun::star::script
;
41 using namespace com::sun::star::reflection
;
42 using namespace com::sun::star::registry
;
45 const double MIN_DOUBLE
= -DBL_MAX
;
46 const double MAX_DOUBLE
= DBL_MAX
;
47 const double MIN_FLOAT
= -FLT_MAX
;
48 const double MAX_FLOAT
= FLT_MAX
;
50 //==================================================================================================
51 static void printValue( const Any
& rVal
)
54 OString
aStr( OUStringToOString( rVal
.getValueType().getTypeName(), RTL_TEXTENCODING_ISO_8859_1
) );
55 printf( "(%s)", aStr
.getStr() );
57 switch (rVal
.getValueTypeClass())
64 printValue( *(Any
*)rVal
.getValue() );
66 case TypeClass_BOOLEAN
:
67 printf( "%s", (*(sal_Bool
*)rVal
.getValue() ? "true" : "false") );
72 ar
[0] = (char)*(sal_Unicode
*)rVal
.getValue();
78 printf( "%x", (int)*(sal_Int8
*)rVal
.getValue() );
81 printf( "%x", *(sal_Int16
*)rVal
.getValue() );
83 case TypeClass_UNSIGNED_SHORT
:
84 printf( "%x", *(sal_uInt16
*)rVal
.getValue() );
87 printf( "%lx", static_cast<long>(*(sal_Int32
*)rVal
.getValue()) );
89 case TypeClass_UNSIGNED_LONG
:
90 printf( "%lx", static_cast<unsigned long>(*(sal_uInt32
*)rVal
.getValue()) );
93 printf( "%lx", (long)*(sal_Int64
*)rVal
.getValue() );
95 case TypeClass_UNSIGNED_HYPER
:
96 printf( "%lx", (unsigned long)*(sal_uInt64
*)rVal
.getValue() );
99 printf( "%f", *(float *)rVal
.getValue() );
101 case TypeClass_DOUBLE
:
102 printf( "%g", *(double *)rVal
.getValue() );
104 case TypeClass_STRING
:
106 OString
aStr2( OUStringToOString( *(OUString
*)rVal
.getValue(), RTL_TEXTENCODING_ISO_8859_1
) );
107 printf( aStr2
.getStr() );
112 typelib_EnumTypeDescription
* pEnumTD
= 0;
113 TYPELIB_DANGER_GET( (typelib_TypeDescription
**)&pEnumTD
, rVal
.getValueTypeRef() );
115 for ( sal_Int32 nPos
= pEnumTD
->nEnumValues
; nPos
--; )
117 if (pEnumTD
->pEnumValues
[nPos
] == *(int *)rVal
.getValue())
119 printf( OUStringToOString(pEnumTD
->ppEnumNames
[nPos
]->buffer
, RTL_TEXTENCODING_ASCII_US
).getStr() );
120 TYPELIB_DANGER_RELEASE( (typelib_TypeDescription
*)pEnumTD
);
124 TYPELIB_DANGER_RELEASE( (typelib_TypeDescription
*)pEnumTD
);
125 printf( ">ENUM not found!<" );
128 case TypeClass_SEQUENCE
:
130 uno_Sequence
* pSeq
= *(uno_Sequence
**)rVal
.getValue();
131 typelib_TypeDescription
* pSeqTD
= 0;
132 TYPELIB_DANGER_GET( &pSeqTD
, rVal
.getValueTypeRef() );
133 typelib_TypeDescription
* pElemTD
= 0;
134 TYPELIB_DANGER_GET( &pElemTD
, ((typelib_IndirectTypeDescription
*)pSeqTD
)->pType
);
136 sal_Int32 nLen
= pSeq
->nElements
;
140 for ( sal_Int32 nPos
= 0; nPos
< nLen
; ++nPos
)
142 printValue( Any( ((char *)pSeq
->elements
) + (nPos
* pElemTD
->nSize
), pElemTD
) );
149 TYPELIB_DANGER_RELEASE( pElemTD
);
150 TYPELIB_DANGER_RELEASE( pSeqTD
);
155 printf( ">not printable<" );
160 static Reference
< XTypeConverter
> s_xConverter
;
162 //==================================================================================================
163 static sal_Bool
convertTo( const Type
& rDestType
, const Any
& rVal
, sal_Bool bExpectSuccess
)
165 sal_Bool bCanConvert
= sal_False
;
172 aRet
= s_xConverter
->convertTo( rVal
, rDestType
);
173 bCanConvert
= sal_True
;
175 catch (const Exception
& rExc
)
177 aExcMsg
= OUStringToOString( rExc
.Message
, RTL_TEXTENCODING_ASCII_US
);
180 if (bExpectSuccess
&& !bCanConvert
)
182 printf( "# conversion of " );
185 printf( OUStringToOString(rDestType
.getTypeName(), RTL_TEXTENCODING_ASCII_US
).getStr() );
186 printf( " failed, but success was expected! [" );
187 printf( aExcMsg
.getStr() );
189 aRet
= s_xConverter
->convertTo( rVal
, rDestType
);
190 #if OSL_DEBUG_LEVEL > 1
191 // for debugging, to trace again
194 aRet
= s_xConverter
->convertTo( rVal
, rDestType
);
202 if (!bExpectSuccess
&& bCanConvert
)
204 printf( "# conversion of " );
208 printf( " was successful, but was not expected to be!\n" );
209 #if OSL_DEBUG_LEVEL > 1
210 // for debugging, to trace again
211 aRet
= s_xConverter
->convertTo( rVal
, rDestType
);
216 #ifdef __RECONVERSION_OUTPUT__
217 //= re-conversion output =
220 // re convert to original type
221 sal_Bool bReConvert
= sal_False
;
226 aRet2
= s_xConverter
->convertTo( aRet
, rVal
.getValueType() );
227 bReConvert
= sal_True
;
229 catch (const Exception
& rExc
)
231 aExcMsg
= OUStringToOString( rExc
.Message
, RTL_TEXTENCODING_ISO_8859_1
);
238 printf( "# re-conversion of " );
244 printf( ": first and last do not match!\n" );
249 printf( "# re-conversion of " );
252 printf( rVal
.getValueType().getTypeName().getStr() );
253 printf( " failed! [" );
254 printf( aExcMsg
.getStr() );
264 //==================================================================================================
265 typedef struct _ConvBlock
268 sal_Bool _toString
, _toDouble
, _toFloat
;
269 sal_Bool _toUINT32
, _toINT32
, _toUINT16
, _toINT16
, _toBYTE
, _toBOOL
, _toChar
;
270 sal_Bool _toTypeClass
, _toSeqINT16
, _toSeqAny
;
275 _ConvBlock( const Any
& rValue_
,
276 sal_Bool toString_
, sal_Bool toDouble_
, sal_Bool toFloat_
,
277 sal_Bool toUINT32_
, sal_Bool toINT32_
, sal_Bool toUINT16_
, sal_Bool toINT16_
,
278 sal_Bool toBYTE_
, sal_Bool toBOOL_
, sal_Bool toChar_
,
279 sal_Bool toTypeClass_
, sal_Bool toSeqINT16_
, sal_Bool toSeqAny_
)
281 , _toString( toString_
), _toDouble( toDouble_
), _toFloat( toFloat_
)
282 , _toUINT32( toUINT32_
), _toINT32( toINT32_
), _toUINT16( toUINT16_
), _toINT16( toINT16_
)
283 , _toBYTE( toBYTE_
), _toBOOL( toBOOL_
), _toChar( toChar_
)
284 , _toTypeClass( toTypeClass_
), _toSeqINT16( toSeqINT16_
), _toSeqAny( toSeqAny_
)
290 //==================================================================================================
291 static sal_Int32
initBlocks( ConvBlock
* pTestBlocks
)
295 sal_uInt32 nElems
= 0;
298 aVal
<<= OUString("0xff");
299 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
300 aVal
<<= OUString("255");
301 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
302 aVal
<<= (sal_Int8
)0xffu
;
303 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0 );
304 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
305 aVal
<<= OUString("0x80");
306 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
307 aVal
<<= OUString("128");
308 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
309 aVal
<<= (sal_Int8
)( 0x80u
);
310 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0 );
311 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
312 aVal
<<= OUString("0x7f");
313 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
314 aVal
<<= OUString("127");
315 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
316 aVal
<<= (sal_Int8
)( 0x7f );
317 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0 );
318 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
319 aVal
<<= OUString("5");
320 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0 );
321 aVal
<<= OUString("+5");
322 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
323 aVal
<<= (sal_Int8
)( 5 );
324 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
325 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
326 aVal
<<= OUString("-5");
327 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0 );
328 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
329 aVal
<<= (sal_Int8
)( -5 );
330 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0 );
331 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
332 aVal
<<= OUString("256");
333 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
334 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
336 aVal
<<= OUString("65535");
337 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0 );
338 aVal
<<= OUString("0xffff");
339 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0 );
340 aVal
<<= (sal_uInt16
)( 0xffff );
341 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0 );
342 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
343 aVal
<<= OUString("32768");
344 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0 );
345 aVal
<<= (sal_uInt16
)( 0x8000 );
346 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0 );
347 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
348 aVal
<<= OUString("32767");
349 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
350 aVal
<<= OUString("0x7fff");
351 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
352 aVal
<<= (sal_uInt16
)( 0x7fff );
353 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0 );
354 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
355 aVal
<<= OUString("256");
356 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
357 aVal
<<= OUString("0x100");
358 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0 );
359 aVal
<<= (sal_uInt16
)( 0x100 );
360 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0 );
361 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
362 aVal
<<= (sal_uInt16
)( 5 );
363 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
364 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
365 aVal
<<= (sal_uInt16
)( -5 ); // is 0xfffb
366 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0 );
367 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
369 aVal
<<= (sal_Int16
)( -1 );
370 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0 );
371 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
372 aVal
<<= (sal_Int16
)( -0x8000 );
373 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0 );
374 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
375 aVal
<<= (sal_Int16
)( 0x7fff );
376 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0 );
377 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
378 aVal
<<= (sal_Int16
)( 0x100 );
379 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 0, 0 );
380 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
381 aVal
<<= (sal_Int16
)( 5 );
382 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
383 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
384 aVal
<<= (sal_Int16
)( -5 );
385 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0 );
386 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
388 aVal
<<= OUString("+4294967295");
389 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
390 aVal
<<= OUString("4294967295");
391 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
392 aVal
<<= OUString("0xffffffff");
393 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
394 aVal
<<= (sal_uInt32
)( 0xffffffff );
395 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
396 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
397 aVal
<<= OUString("-2147483648");
398 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0 );
399 aVal
<<= OUString("-0x80000000");
400 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0 );
401 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
402 aVal
<<= (sal_uInt32
)( 0x80000000 );
403 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
404 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
405 aVal
<<= OUString("2147483647");
406 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0 );
407 aVal
<<= OUString("0x7fffffff");
408 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0 );
409 aVal
<<= (sal_uInt32
)( 0x7fffffff );
410 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0 );
411 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
412 aVal
<<= OUString("65536");
413 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0 );
414 aVal
<<= OUString("0x10000");
415 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0 );
416 aVal
<<= (sal_uInt32
)( 0x10000 );
417 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0 );
418 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
419 aVal
<<= (sal_uInt32
)( 0x8000 );
420 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0 );
421 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
422 aVal
<<= (sal_uInt32
)( 5 );
423 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
424 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
425 aVal
<<= OUString("0xfffffffb");
426 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
427 aVal
<<= (sal_uInt32
)( -5 ); // is 0xfffffffb
428 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
429 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
431 aVal
<<= (sal_Int32
)( 0xffffffff ); // is -1
432 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0 );
433 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
434 aVal
<<= (sal_Int32
)( 0x80000000 );
435 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0 );
436 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
437 aVal
<<= (sal_Int32
)( 0x7fffffff );
438 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0 );
439 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
440 aVal
<<= (sal_Int32
)( 0x10000 );
441 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0 );
442 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
443 aVal
<<= (sal_Int32
)( -0x8001 );
444 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0 );
445 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
446 aVal
<<= (sal_Int32
)( 5 );
447 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
448 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
449 aVal
<<= (sal_Int32
)( -5 );
450 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0 );
451 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
453 aVal
<<= OUString("-3.4e+38");
454 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
455 aVal
<<= (float)( MIN_FLOAT
);
456 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
457 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
458 aVal
<<= OUString("+3.4e+38");
459 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
460 aVal
<<= (float)( MAX_FLOAT
);
461 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
462 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
463 aVal
<<= OUString("9e-20");
464 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
465 aVal
<<= (float)( 9e-20 );
466 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
467 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
468 aVal
<<= OUString("+.7071067811865");
469 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
470 aVal
<<= (float)( .7071067811865 );
471 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
472 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
473 aVal
<<= OUString("3.14159265359");
474 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
475 aVal
<<= (float)( 3.14159265359 );
476 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
477 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
478 aVal
<<= (float)( 5 );
479 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
480 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
482 aVal
<<= OUString("-1.7976931348623155e+308");
483 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
484 aVal
<<= (double)( MIN_DOUBLE
);
485 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
486 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
487 aVal
<<= OUString("1.7976931348623155e+308");
488 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
489 aVal
<<= (double)( MAX_DOUBLE
);
490 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
491 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
492 aVal
<<= (double)( MIN_FLOAT
);
493 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
494 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
495 aVal
<<= (double)( MAX_FLOAT
);
496 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
497 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
498 aVal
<<= (double)( -((double)0x80000000) );
499 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0 );
500 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
501 aVal
<<= (double)( -((double)0x80000001) );
502 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
503 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
504 aVal
<<= (double)( 0x7fffffff );
505 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0 );
506 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
507 aVal
<<= (double)( 0x80000000 );
508 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
509 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
510 aVal
<<= (double)( 0xffffffff );
511 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
512 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
513 aVal
<<= OUString("0x100000000");
514 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
515 aVal
<<= (double)( SAL_CONST_INT64(0x100000000) );
516 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
517 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
518 aVal
<<= (double)( 5 );
519 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 );
520 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
523 aVal
.setValue( &c
, ::getCharCppuType() );
524 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0 );
525 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
526 aVal
<<= OUString("A");
527 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0 );
528 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
530 aVal
<<= OUString("0");
531 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0 );
532 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
533 aVal
<<= OUString("1");
534 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0 );
535 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
536 aVal
<<= OUString("False");
537 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
538 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
539 aVal
<<= OUString("true");
540 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0 );
541 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
543 sal_Bool bTmp
= sal_True
;
544 aVal
.setValue( &bTmp
, getBooleanCppuType() );
545 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0 );
546 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
549 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
550 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
551 aVal
<<= OUString("-");
552 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 0, 0 );
553 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
554 aVal
<<= OUString("-0");
555 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
556 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
557 // ==TYPECLASS ENUM==
558 aVal
<<= OUString("eNuM");
559 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0 );
560 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
561 aVal
<<= OUString("DOUBLE");
562 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0 );
563 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
565 aVal
.setValue( &e
, ::getCppuType( (const TypeClass
*)0 ) );
566 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0 );
567 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
568 aVal
.setValue( &e
, ::getCppuType( (const FieldAccessMode
*)0 ) );
569 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 );
570 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
572 Sequence
< sal_Int32
> aINT32Seq( 3 ), aINT32Seq2( 3 );
573 sal_Int32
* pINT32Seq
= aINT32Seq
.getArray();
574 pINT32Seq
[0] = -32768;
576 pINT32Seq
[2] = 32767;
578 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1 );
579 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
580 pINT32Seq
= aINT32Seq2
.getArray();
581 pINT32Seq
[0] = -32768;
582 pINT32Seq
[1] = -32769;
583 pINT32Seq
[2] = 32767;
585 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 );
586 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
588 Sequence
< Any
> aAnySeq( 2 ), aAnySeq2( 2 ), aAnySeq3( 2 );
589 Any
* pAnySeq
= aAnySeq
.getArray();
590 pAnySeq
[0] = makeAny( aINT32Seq
);
591 pAnySeq
[1] = makeAny( OUString("lala") );
593 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 );
594 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
595 pAnySeq
= aAnySeq2
.getArray();
596 pAnySeq
[0] <<= (sal_Int32
)4711;
597 pAnySeq
[1] <<= OUString("0815");
599 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1 );
600 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
601 pAnySeq
= aAnySeq3
.getArray();
602 pAnySeq
[0] <<= OUString("TypeClass_UNION");
603 pAnySeq
[1] <<= OUString("TypeClass_ENUM");
605 pTestBlocks
[nElems
++] = ConvBlock( aVal
, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 );
606 // st,do,fl,u3,i3,u1,i1,by,bo,ch,tc,si,sa
610 //==================================================================================================
611 static void test_Conversion( const Reference
< XMultiServiceFactory
> & xMgr
)
613 printf( "test_Conversion(): start...\n" );
615 Reference
< XTypeConverter
> xConverter( xMgr
->createInstance(
616 OUString("com.sun.star.script.Converter") ), UNO_QUERY
);
618 ConvBlock
* pTestBlocks
= new ConvBlock
[256];
619 sal_Int32 nPos
= initBlocks( pTestBlocks
);
621 s_xConverter
= xConverter
;
624 const ConvBlock
& rBlock
= pTestBlocks
[nPos
];
625 const Any
& rVal
= rBlock
._value
;
627 convertTo( ::getCppuType( (const OUString
*)0 ), rVal
, rBlock
._toString
);
628 convertTo( ::getCppuType( (const float *)0 ), rVal
, rBlock
._toFloat
);
629 convertTo( ::getCppuType( (const double *)0 ), rVal
, rBlock
._toDouble
);
630 convertTo( ::getCppuType( (const sal_uInt32
*)0 ), rVal
, rBlock
._toUINT32
);
631 convertTo( ::getCppuType( (const sal_Int32
*)0 ), rVal
, rBlock
._toINT32
);
632 convertTo( ::getCppuType( (const sal_uInt16
*)0 ), rVal
, rBlock
._toUINT16
);
633 convertTo( ::getCppuType( (const sal_Int16
*)0 ), rVal
, rBlock
._toINT16
);
634 convertTo( ::getCppuType( (const sal_Int8
*)0 ), rVal
, rBlock
._toBYTE
);
635 convertTo( ::getBooleanCppuType(), rVal
, rBlock
._toBOOL
);
636 convertTo( ::getCharCppuType(), rVal
, rBlock
._toChar
);
637 convertTo( ::getCppuType( (const TypeClass
*)0 ), rVal
, rBlock
._toTypeClass
);
638 convertTo( ::getCppuType( (const Sequence
< sal_Int16
> *)0 ), rVal
, rBlock
._toSeqINT16
);
639 convertTo( ::getCppuType( (const Sequence
< Any
> *)0 ), rVal
, rBlock
._toSeqAny
);
641 convertTo( ::getVoidCppuType(), rVal
, sal_True
); // anything converts to void
643 s_xConverter
.clear();
645 delete [] pTestBlocks
;
648 aRet
= xConverter
->convertTo( Any( &xMgr
, ::getCppuType( (const Reference
< XMultiServiceFactory
> *)0 ) ),
649 ::getCppuType( (const Reference
< XServiceInfo
> *)0 ) );
650 aRet
= xConverter
->convertTo( aRet
, ::getCppuType( (const Reference
< XMultiServiceFactory
> *)0 ) );
651 aRet
= xConverter
->convertTo( aRet
, ::getCppuType( (const Reference
< XServiceInfo
> *)0 ) );
652 aRet
<<= SAL_CONST_INT64(0x7fffffffffffffff);
653 aRet
= xConverter
->convertTo( aRet
, ::getCppuType( (const sal_uInt64
*)0 ) );
654 OSL_ASSERT( *(const sal_uInt64
*)aRet
.getValue() == SAL_CONST_UINT64(0x7fffffffffffffff) );
655 aRet
<<= SAL_CONST_UINT64(0xffffffffffffffff);
656 aRet
= xConverter
->convertTo( aRet
, ::getCppuType( (const sal_uInt64
*)0 ) );
657 OSL_ASSERT( *(const sal_uInt64
*)aRet
.getValue() == SAL_CONST_UINT64(0xffffffffffffffff) );
658 aRet
<<= SAL_CONST_INT64(-1);
659 aRet
= xConverter
->convertTo( aRet
, ::getCppuType( (const sal_Int8
*)0 ) );
660 OSL_ASSERT( *(const sal_Int8
*)aRet
.getValue() == (-1) );
661 printf( "test_Conversion(): end.\n" );
666 Reference
< XMultiServiceFactory
> xMgr( createRegistryServiceFactory( OUString("stoctest.rdb") ) );
670 Reference
< XImplementationRegistration
> xImplReg(
671 xMgr
->createInstance( OUString("com.sun.star.registry.ImplementationRegistration") ), UNO_QUERY
);
672 OSL_ENSURE( xImplReg
.is(), "### no impl reg!" );
675 RTL_CONSTASCII_USTRINGPARAM("stocservices.uno" SAL_DLLEXTENSION
) );
676 xImplReg
->registerImplementation(
677 OUString("com.sun.star.loader.SharedLibrary"),
678 aLibName
, Reference
< XSimpleRegistry
>() );
680 test_Conversion( xMgr
);
682 catch (const Exception
& rExc
)
684 OSL_FAIL( "### exception occurred!" );
685 OString
aMsg( OUStringToOString( rExc
.Message
, RTL_TEXTENCODING_ASCII_US
) );
686 OSL_TRACE( "### exception occurred: " );
687 OSL_TRACE( "%s", aMsg
.getStr() );
691 Reference
< XComponent
>( xMgr
, UNO_QUERY
)->dispose();
695 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */