summaryrefslogtreecommitdiffstats
path: root/include/cppuhelper
diff options
context:
space:
mode:
authorStephan Bergmann <sbergman@redhat.com>2016-10-20 16:46:50 +0200
committerStephan Bergmann <sbergman@redhat.com>2016-10-20 16:46:50 +0200
commit0b04e8f80ea1b0ae0603d79b2c80d669f16375d3 (patch)
tree74a8473cadf764b11534854fd8a29c911f36300b /include/cppuhelper
parentsw: Avoid inheritance from std::vector (diff)
downloadcore-0b04e8f80ea1b0ae0603d79b2c80d669f16375d3.tar.gz
core-0b04e8f80ea1b0ae0603d79b2c80d669f16375d3.zip
Some clean-up
Change-Id: Ifd36b0f364dd1d5d38095d32409f8587b0662ace
Diffstat (limited to 'include/cppuhelper')
-rw-r--r--include/cppuhelper/proptypehlp.hxx667
1 files changed, 261 insertions, 406 deletions
diff --git a/include/cppuhelper/proptypehlp.hxx b/include/cppuhelper/proptypehlp.hxx
index 9f3dcf41caf5..1e1c7805478a 100644
--- a/include/cppuhelper/proptypehlp.hxx
+++ b/include/cppuhelper/proptypehlp.hxx
@@ -16,6 +16,7 @@
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
+
#ifndef INCLUDED_CPPUHELPER_PROPTYPEHLP_HXX
#define INCLUDED_CPPUHELPER_PROPTYPEHLP_HXX
@@ -26,13 +27,6 @@
namespace cppu
{
-/** Converts the value stored in an any to a concrete C++ type.
- The function does the same as the operator >>= () at the
- Any class, except that it throws an IllegalArgumentException in case of
- failures (the value cannot be extracted without data loss )
-
- @exception css::lang::IllegalArgumentException when the type could not be converted.
- */
template < class target >
inline void SAL_CALL convertPropertyValue( target &value , const css::uno::Any & a)
{
@@ -42,48 +36,54 @@ inline void SAL_CALL convertPropertyValue( target &value , const css::uno::Any
}
}
-
-/**
- conversion of basic types
-*/
inline void SAL_CALL convertPropertyValue( sal_Bool & b , const css::uno::Any & a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if( css::uno::TypeClass_LONG == tc ) {
- sal_Int32 i32 = 0;
- a >>= i32;
- b = i32 != 0;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c = *static_cast<sal_Unicode const *>(a.getValue());
- b = c != 0;
- }
- else if ( css::uno::TypeClass_SHORT == tc ) {
- sal_Int16 i16 = 0;
- a >>= i16;
- b = i16 != 0;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- a >>= b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8 = 0;
- a >>= i8;
- b = i8 != 0;
- }
- else if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- sal_uInt16 i16 = 0;
- a >>= i16;
- b = i16 != 0;
- }
- else if ( css::uno::TypeClass_UNSIGNED_LONG == tc ) {
- sal_uInt32 i32 = 0;
- a >>= i32;
- b = i32 != 0;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= b) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BYTE:
+ {
+ sal_Int8 i8 = 0;
+ a >>= i8;
+ b = i8 != 0;
+ break;
+ }
+ case css::uno::TypeClass_SHORT:
+ {
+ sal_Int16 i16 = 0;
+ a >>= i16;
+ b = i16 != 0;
+ break;
+ }
+ case css::uno::TypeClass_UNSIGNED_SHORT:
+ {
+ sal_uInt16 i16 = 0;
+ a >>= i16;
+ b = i16 != 0;
+ break;
+ }
+ case css::uno::TypeClass_LONG:
+ {
+ sal_Int32 i32 = 0;
+ a >>= i32;
+ b = i32 != 0;
+ break;
+ }
+ case css::uno::TypeClass_UNSIGNED_LONG:
+ {
+ sal_uInt32 i32 = 0;
+ a >>= i32;
+ b = i32 != 0;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c = *static_cast<sal_Unicode const *>(a.getValue());
+ b = c != 0;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
@@ -95,410 +95,266 @@ void convertPropertyValue(bool & target, css::uno::Any const & source) {
inline void SAL_CALL convertPropertyValue( sal_Int64 & i , const css::uno::Any & a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if( css::uno::TypeClass_HYPER == tc ) {
- a >>= i;
- }
- else if( css::uno::TypeClass_UNSIGNED_HYPER == tc ) {
- sal_uInt64 i64 = 0;
- a >>= i64;
- i = ( sal_Int64 ) i64;
- }
- else if( css::uno::TypeClass_LONG == tc ) {
- sal_Int32 i32 = 0;
- a >>= i32;
- i = ( sal_Int64 )i32;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c;
- c = *static_cast<sal_Unicode const *>(a.getValue());
- i = ( sal_Int64 ) c;
- }
- else if ( css::uno::TypeClass_SHORT == tc ) {
- sal_Int16 i16 = 0;
- a >>= i16;
- i = ( sal_Int64 ) i16;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- i = ( sal_Int64 ) b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8 = 0;
- a >>= i8;
- i = ( sal_Int64 ) i8;
- }
- else if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- sal_uInt16 i16 = 0;
- a >>= i16;
- i = ( sal_Int64 ) i16;
- }
- else if ( css::uno::TypeClass_UNSIGNED_LONG == tc ) {
- sal_uInt32 i32 = 0;
- a >>= i32;
- i = ( sal_Int64 ) i32;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= i) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ i = ( sal_Int64 ) b;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c;
+ c = *static_cast<sal_Unicode const *>(a.getValue());
+ i = ( sal_Int64 ) c;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
inline void SAL_CALL convertPropertyValue( sal_uInt64 & i , const css::uno::Any & a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if( css::uno::TypeClass_UNSIGNED_HYPER == tc ) {
- a >>= i;
- }
- if( css::uno::TypeClass_HYPER == tc ) {
- sal_Int64 i64;
- a >>= i64;
- i = ( sal_uInt64 ) i64;
- }
- else if( css::uno::TypeClass_LONG == tc ) {
- sal_Int32 i32;
- a >>= i32;
- i = ( sal_uInt64 )i32;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c;
- c = *static_cast<sal_Unicode const *>(a.getValue());
- i = ( sal_uInt64 ) c;
- }
- else if ( css::uno::TypeClass_SHORT == tc ) {
- sal_Int16 i16;
- a >>= i16;
- i = ( sal_uInt64 ) i16;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- i = ( sal_uInt64 ) b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8;
- a >>= i8;
- i = ( sal_uInt64 ) i8;
- }
- else if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- sal_uInt16 i16;
- a >>= i16;
- i = ( sal_uInt64 ) i16;
- }
- else if ( css::uno::TypeClass_UNSIGNED_LONG == tc ) {
- sal_uInt32 i32;
- a >>= i32;
- i = ( sal_uInt64 ) i32;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= i) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ i = ( sal_uInt64 ) b;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c;
+ c = *static_cast<sal_Unicode const *>(a.getValue());
+ i = ( sal_uInt64 ) c;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
-// the basic types
-// sal_Int32
inline void SAL_CALL convertPropertyValue( sal_Int32 & i , const css::uno::Any & a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if( css::uno::TypeClass_LONG == tc ) {
- a >>= i;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c;
- c = *static_cast<sal_Unicode const *>(a.getValue());
- i = ( sal_Int32 ) c;
- }
- else if ( css::uno::TypeClass_SHORT == tc ) {
- sal_Int16 i16 = 0;
- a >>= i16;
- i = ( sal_Int32 ) i16;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- i = ( sal_Int32 ) b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8 = 0;
- a >>= i8;
- i = ( sal_Int32 ) i8;
- }
- else if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- sal_uInt16 i16 = 0;
- a >>= i16;
- i = ( sal_Int32 ) i16;
- }
- else if ( css::uno::TypeClass_UNSIGNED_LONG == tc ) {
- sal_uInt32 i32 = 0;
- a >>= i32;
- i = ( sal_Int32 ) i32;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= i) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ i = ( sal_Int32 ) b;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c;
+ c = *static_cast<sal_Unicode const *>(a.getValue());
+ i = ( sal_Int32 ) c;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
inline void SAL_CALL convertPropertyValue( sal_uInt32 & i , const css::uno::Any & a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if ( css::uno::TypeClass_UNSIGNED_LONG == tc ) {
- a >>= i;
- }
- else if( css::uno::TypeClass_LONG == tc ) {
- sal_Int32 i32;
- a >>= i32;
- i = (sal_uInt32 ) i32;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c;
- c = *static_cast<sal_Unicode const *>(a.getValue());
- i = ( sal_uInt32 ) c;
- }
- else if ( css::uno::TypeClass_SHORT == tc ) {
- sal_Int16 i16;
- a >>= i16;
- i = ( sal_uInt32 ) i16;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- i = ( sal_uInt32 ) b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8;
- a >>= i8;
- i = ( sal_uInt32 ) i8;
- }
- else if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- sal_uInt16 i16;
- a >>= i16;
- i = ( sal_uInt32 ) i16;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= i) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ i = ( sal_uInt32 ) b;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c;
+ c = *static_cast<sal_Unicode const *>(a.getValue());
+ i = ( sal_uInt32 ) c;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
-
inline void SAL_CALL convertPropertyValue( sal_Int16 & i , const css::uno::Any & a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if ( css::uno::TypeClass_SHORT == tc ) {
- a >>= i;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c;
- c = *static_cast<sal_Unicode const *>(a.getValue());
- i = ( sal_Int16 ) c;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- i = ( sal_Int16 ) b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8 = 0;
- a >>= i8;
- i = ( sal_Int16 ) i8;
- }
- else if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- sal_uInt16 i16 = 0;
- a >>= i16;
- i = ( sal_Int16 ) i16;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= i) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ i = ( sal_Int16 ) b;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c;
+ c = *static_cast<sal_Unicode const *>(a.getValue());
+ i = ( sal_Int16 ) c;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
inline void SAL_CALL convertPropertyValue( sal_uInt16 & i , const css::uno::Any & a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- a >>= i;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c;
- c = *static_cast<sal_Unicode const *>(a.getValue());
- i = ( sal_Int16 ) c;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- i = ( sal_Int16 ) b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8 = 0;
- a >>= i8;
- i = ( sal_Int16 ) i8;
- }
- else if ( css::uno::TypeClass_SHORT == tc ) {
- sal_Int16 i16 = 0;
- a >>= i16;
- i = ( sal_Int16 ) i16;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= i) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ i = ( sal_Int16 ) b;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c;
+ c = *static_cast<sal_Unicode const *>(a.getValue());
+ i = ( sal_Int16 ) c;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
inline void SAL_CALL convertPropertyValue( sal_Int8 & i , const css::uno::Any & a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if ( css::uno::TypeClass_BYTE == tc ) {
- a >>= i;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- i = ( sal_Int8 ) b;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= i) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ i = ( sal_Int8 ) b;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
inline void SAL_CALL convertPropertyValue( float &f , const css::uno::Any &a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if ( css::uno::TypeClass_FLOAT == tc ) {
- a >>= f;
- }
- else if( css::uno::TypeClass_DOUBLE == tc ) {
- double d = 0;
- a >>= d;
- f = ( float ) d;
- }
- else if( css::uno::TypeClass_HYPER == tc ) {
- sal_Int64 i64 = 0;
- a >>= i64;
- f = ( float ) i64;
- }
- else if( css::uno::TypeClass_UNSIGNED_HYPER == tc ) {
- sal_uInt64 i64 = 0;
- a >>= i64;
- f = ( float ) i64;
- }
- else if( css::uno::TypeClass_LONG == tc ) {
- sal_Int32 i32 = 0;
- a >>= i32;
- f = ( float )i32;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c;
- c = *static_cast<sal_Unicode const *>(a.getValue());
- f = ( float ) c;
- }
- else if ( css::uno::TypeClass_SHORT == tc ) {
- sal_Int16 i16 = 0;
- a >>= i16;
- f = ( float ) i16;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- f = ( float ) b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8 = 0;
- a >>= i8;
- f = ( float ) i8;
- }
- else if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- sal_uInt16 i16 = 0;
- a >>= i16;
- f = ( float ) i16;
- }
- else if ( css::uno::TypeClass_UNSIGNED_LONG == tc ) {
- sal_uInt32 i32 = 0;
- a >>= i32;
- f = ( float ) i32;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= f) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ f = ( float ) b;
+ break;
+ }
+ case css::uno::TypeClass_LONG:
+ {
+ sal_Int32 i32 = 0;
+ a >>= i32;
+ f = ( float )i32;
+ break;
+ }
+ case css::uno::TypeClass_UNSIGNED_LONG:
+ {
+ sal_uInt32 i32 = 0;
+ a >>= i32;
+ f = ( float ) i32;
+ break;
+ }
+ case css::uno::TypeClass_HYPER:
+ {
+ sal_Int64 i64 = 0;
+ a >>= i64;
+ f = ( float ) i64;
+ break;
+ }
+ case css::uno::TypeClass_UNSIGNED_HYPER:
+ {
+ sal_uInt64 i64 = 0;
+ a >>= i64;
+ f = ( float ) i64;
+ break;
+ }
+ case css::uno::TypeClass_DOUBLE:
+ {
+ double d = 0;
+ a >>= d;
+ f = ( float ) d;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c;
+ c = *static_cast<sal_Unicode const *>(a.getValue());
+ f = ( float ) c;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
-
inline void SAL_CALL convertPropertyValue( double &d , const css::uno::Any &a )
{
- const enum css::uno::TypeClass tc = a.getValueType().getTypeClass();
-
- if( css::uno::TypeClass_DOUBLE == tc ) {
- float f;
- a >>= f;
- d = ( double ) f;
- }
- else if ( css::uno::TypeClass_FLOAT == tc ) {
- float f;
- a >>= f;
- d = (double) f;
- }
- else if( css::uno::TypeClass_HYPER == tc ) {
- sal_Int64 i64;
- a >>= i64;
- d = (double) i64;
- }
- else if( css::uno::TypeClass_UNSIGNED_HYPER == tc ) {
- sal_uInt64 i64 = 0;
- a >>= i64;
- d = (double) i64;
- }
- else if( css::uno::TypeClass_LONG == tc ) {
- sal_Int32 i32;
- a >>= i32;
- d = (double)i32;
- }
- else if ( css::uno::TypeClass_CHAR == tc ) {
- sal_Unicode c;
- c = *static_cast<sal_Unicode const *>(a.getValue());
- d = (double) c;
- }
- else if ( css::uno::TypeClass_SHORT == tc ) {
- sal_Int16 i16;
- a >>= i16;
- d = (double) i16;
- }
- else if ( css::uno::TypeClass_BOOLEAN == tc ) {
- bool b;
- a >>= b;
- d = (double) b;
- }
- else if ( css::uno::TypeClass_BYTE == tc ) {
- sal_Int8 i8;
- a >>= i8;
- d = (double) i8;
- }
- else if ( css::uno::TypeClass_UNSIGNED_SHORT == tc ) {
- sal_uInt16 i16;
- a >>= i16;
- d = (double) i16;
- }
- else if ( css::uno::TypeClass_UNSIGNED_LONG == tc ) {
- sal_uInt32 i32;
- a >>= i32;
- d = (double) i32;
- }
- else {
- throw css::lang::IllegalArgumentException();
+ if( !(a >>= d) ) {
+ switch( a.getValueType().getTypeClass() ) {
+ case css::uno::TypeClass_BOOLEAN:
+ {
+ bool b;
+ a >>= b;
+ d = (double) b;
+ break;
+ }
+ case css::uno::TypeClass_HYPER:
+ {
+ sal_Int64 i64;
+ a >>= i64;
+ d = (double) i64;
+ break;
+ }
+ case css::uno::TypeClass_UNSIGNED_HYPER:
+ {
+ sal_uInt64 i64 = 0;
+ a >>= i64;
+ d = (double) i64;
+ break;
+ }
+ case css::uno::TypeClass_CHAR:
+ {
+ sal_Unicode c;
+ c = *static_cast<sal_Unicode const *>(a.getValue());
+ d = (double) c;
+ break;
+ }
+ default:
+ throw css::lang::IllegalArgumentException();
+ }
}
}
inline void SAL_CALL convertPropertyValue( ::rtl::OUString &ow , const css::uno::Any &a )
{
- if( css::uno::TypeClass_STRING == a.getValueType().getTypeClass() ) {
- a >>= ow;
- }
- else {
+ if( !(a >>= ow) ) {
throw css::lang::IllegalArgumentException();
}
}
@@ -507,5 +363,4 @@ inline void SAL_CALL convertPropertyValue( ::rtl::OUString &ow , const css::uno:
#endif
-
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */