diff options
author | Daniel Boelzle <dbo@openoffice.org> | 2001-03-07 12:55:53 +0000 |
---|---|---|
committer | Daniel Boelzle <dbo@openoffice.org> | 2001-03-07 12:55:53 +0000 |
commit | f65546ea32e7645f3a15d6015998c6904853a1f1 (patch) | |
tree | 6f77a5e5bf613b28fc9d1571928f765e222d121c /comphelper/inc/comphelper/extract.hxx | |
parent | 496dd5d78dd759eb2002ef24fb8ca1ccca41a24c (diff) |
moved from cppuhelper
Diffstat (limited to 'comphelper/inc/comphelper/extract.hxx')
-rw-r--r-- | comphelper/inc/comphelper/extract.hxx | 208 |
1 files changed, 208 insertions, 0 deletions
diff --git a/comphelper/inc/comphelper/extract.hxx b/comphelper/inc/comphelper/extract.hxx new file mode 100644 index 000000000000..1b3d5a3e9410 --- /dev/null +++ b/comphelper/inc/comphelper/extract.hxx @@ -0,0 +1,208 @@ +/************************************************************************* + * + * $RCSfile: extract.hxx,v $ + * + * $Revision: 1.1 $ + * + * last change: $Author: dbo $ $Date: 2001-03-07 13:55:53 $ + * + * The Contents of this file are made available subject to the terms of + * either of the following licenses + * + * - GNU Lesser General Public License Version 2.1 + * - Sun Industry Standards Source License Version 1.1 + * + * Sun Microsystems Inc., October, 2000 + * + * GNU Lesser General Public License Version 2.1 + * ============================================= + * Copyright 2000 by Sun Microsystems, Inc. + * 901 San Antonio Road, Palo Alto, CA 94303, USA + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License version 2.1, as published by the Free Software Foundation. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + * + * + * Sun Industry Standards Source License Version 1.1 + * ================================================= + * The contents of this file are subject to the Sun Industry Standards + * Source License Version 1.1 (the "License"); You may not use this file + * except in compliance with the License. You may obtain a copy of the + * License at http://www.openoffice.org/license.html. + * + * Software provided under this License is provided on an "AS IS" basis, + * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, + * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, + * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. + * See the License for the specific provisions governing your rights and + * obligations concerning the Software. + * + * The Initial Developer of the Original Code is: Sun Microsystems, Inc. + * + * Copyright: 2000 by Sun Microsystems, Inc. + * + * All Rights Reserved. + * + * Contributor(s): _______________________________________ + * + * + ************************************************************************/ +#ifndef _COMPHELPER_EXTRACT_HXX_ +#define _COMPHELPER_EXTRACT_HXX_ + +#ifndef _COM_SUN_STAR_LANG_ILLEGALARGUMENTEXCEPTION_HPP_ +#include <com/sun/star/lang/IllegalArgumentException.hpp> +#endif +#ifndef _COM_SUN_STAR_UNO_XINTERFACE_HPP_ +#include <com/sun/star/uno/XInterface.hpp> +#endif +#ifndef _COM_SUN_STAR_UNO_TYPECLASS_HPP_ +#include <com/sun/star/uno/TypeClass.hpp> +#endif +#ifndef _COM_SUN_STAR_UNO_TYPE_HXX_ +#include <com/sun/star/uno/Type.hxx> +#endif +#ifndef _COM_SUN_STAR_UNO_ANY_HXX_ +#include <com/sun/star/uno/Any.hxx> +#endif + + +namespace cppu +{ + +/** + * Sets enum from int32 value. This function does NOT check for valid enum values! + *<BR> + * @param nEnum int32 enum value + * @param rType enum type + * @return enum or emoty any. + */ +inline ::com::sun::star::uno::Any SAL_CALL int2enum( + sal_Int32 nEnum, const ::com::sun::star::uno::Type & rType ) +{ + if (rType.getTypeClass() == ::com::sun::star::uno::TypeClass_ENUM) + { + int nVal = nEnum; + return ::com::sun::star::uno::Any( &nVal, rType ); + } + return ::com::sun::star::uno::Any(); +} + +/** + * Sets int32 from enum or int in any. + *<BR> + * @param rnEnum [out] int32 enum value + * @param rAny enum or int + * @param sal_True if enum or int value was set else sal_False. + */ +inline sal_Bool SAL_CALL enum2int( sal_Int32 & rnEnum, const ::com::sun::star::uno::Any & rAny ) +{ + if (rAny.getValueTypeClass() == ::com::sun::star::uno::TypeClass_ENUM) + { + rnEnum = * reinterpret_cast< const int * >( rAny.getValue() ); + return sal_True; + } + + return rAny >>= rnEnum; +} + +/** + * Sets int32 from enum or int in any with additional typecheck + * <BR> + * @param rAny enum or int + * @param eRet the enum value as int. If there is not enum of the given type or + * a ::com::sun::star::lang::IllegalArgumentException is thrown + */ +template< typename E > +inline void SAL_CALL any2enum( E & eRet, const ::com::sun::star::uno::Any & rAny ) + throw( ::com::sun::star::lang::IllegalArgumentException ) +{ + // check for type save enum + if (! (rAny >>= eRet)) + { + // if not enum, maybe integer? + sal_Int32 nValue; + if (! (rAny >>= nValue)) + throw ::com::sun::star::lang::IllegalArgumentException(); + + eRet = (E)nValue; + } +} + +/** + * Template function to create an uno::Any from an enum + * + * @DEPRECATED : use makeAny< E >() + * + */ +template< typename E > +inline ::com::sun::star::uno::Any SAL_CALL enum2any( E eEnum ) +{ + return ::com::sun::star::uno::Any( &eEnum, ::getCppuType((const E*)0) ); +} + +/** + * Extracts interface from an any. If given any does not hold the demanded interface, + * it will be queried for it. + * If no interface is available, the out ref will be cleared. + *<BR> + * @param rxOut [out] demanded interface + * @param rAny interface + * @return sal_True if any reference (including the null ref) was retrieved from any else sal_False. + */ +template< class T > +inline sal_Bool SAL_CALL extractInterface( + ::com::sun::star::uno::Reference< T > & rxOut, + const ::com::sun::star::uno::Any & rAny ) +{ + rxOut.clear(); + return (rAny >>= rxOut); +} + +/** + * extracts a boolean either as a sal_Bool or an integer from + * an any. If there is no sal_Bool or integer inside the any + * a ::com::sun::star::lang::IllegalArgumentException is thrown + * + */ +inline sal_Bool SAL_CALL any2bool( const ::com::sun::star::uno::Any & rAny ) + throw( ::com::sun::star::lang::IllegalArgumentException ) +{ + if (rAny.getValueTypeClass() == ::com::sun::star::uno::TypeClass_BOOLEAN) + { + return *(sal_Bool *)rAny.getValue(); + } + else + { + sal_Int32 nValue; + if (! (rAny >>= nValue)) + throw ::com::sun::star::lang::IllegalArgumentException(); + return nValue != 0; + } +} + +/** + * Puts a boolean in an any. + * + * @DEPRECATED : use makeAny< sal_Bool >() + * + */ +inline ::com::sun::star::uno::Any SAL_CALL bool2any( sal_Bool bBool ) +{ + return ::com::sun::star::uno::Any( &bBool, ::getCppuBooleanType() ); +} + +} + +#endif |