Files
libreoffice/cppu/source/uno/prim.hxx
Vladimir Glazounov 51bcdaa465 INTEGRATION: CWS dbgmacros1 (1.11.4); FILE MERGED
2003/04/09 10:38:54 kso 1.11.4.1: #108413# - debug macro unification.
2003-04-15 15:38:04 +00:00

242 lines
7.4 KiB
C++

/*************************************************************************
*
* $RCSfile: prim.hxx,v $
*
* $Revision: 1.12 $
*
* last change: $Author: vg $ $Date: 2003-04-15 16:38:04 $
*
* 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 PRIM_HXX
#define PRIM_HXX
#ifndef _TYPELIB_TYPEDESCRIPTION_H_
#include "typelib/typedescription.h"
#endif
#ifndef _typelib_TypeClass_H_
#include "typelib/typeclass.h"
#endif
#ifndef _UNO_SEQUENCE2_H_
#include "uno/sequence2.h"
#endif
#ifndef _UNO_ANY2_H_
#include "uno/any2.h"
#endif
#ifndef _UNO_DATA_H_
#include "uno/data.h"
#endif
#ifndef _UNO_MAPPING_H_
#include "uno/mapping.h"
#endif
#ifndef _UNO_DISPATCHER_H_
#include "uno/dispatcher.h"
#endif
#ifndef _OSL_INTERLCK_H
#include "osl/interlck.h"
#endif
#ifndef _OSL_DIAGNOSE_H_
#include "osl/diagnose.h"
#endif
#ifndef _RTL_USTRING_HXX
#include "rtl/ustring.hxx"
#endif
#ifndef _RTL_ALLOC_H_
#include "rtl/alloc.h"
#endif
#if OSL_DEBUG_LEVEL > 1
#include "rtl/ustrbuf.hxx"
#include "rtl/string.hxx"
#endif
namespace cppu
{
extern uno_Sequence g_emptySeq;
extern typelib_TypeDescriptionReference * g_pVoidType;
//--------------------------------------------------------------------------------------------------
inline void * _map(
void * p,
typelib_TypeDescriptionReference * pType, typelib_TypeDescription * pTypeDescr,
uno_Mapping * mapping )
SAL_THROW( () )
{
void * pRet = 0;
if (p)
{
if (pTypeDescr)
{
(*mapping->mapInterface)(
mapping, &pRet, p, (typelib_InterfaceTypeDescription *)pTypeDescr );
}
else
{
TYPELIB_DANGER_GET( &pTypeDescr, pType );
(*mapping->mapInterface)(
mapping, &pRet, p, (typelib_InterfaceTypeDescription *)pTypeDescr );
TYPELIB_DANGER_RELEASE( pTypeDescr );
}
}
return pRet;
}
//--------------------------------------------------------------------------------------------------
inline void _acquire( void * p, uno_AcquireFunc acquire ) SAL_THROW( () )
{
if (p)
{
if (acquire)
{
(*acquire)( p );
}
else
{
(*((uno_Interface *)p)->acquire)( (uno_Interface *)p );
}
}
}
//--------------------------------------------------------------------------------------------------
inline void _release( void * p, uno_ReleaseFunc release ) SAL_THROW( () )
{
if (p)
{
if (release)
{
(*release)( p );
}
else
{
(*((uno_Interface *)p)->release)( (uno_Interface *)p );
}
}
}
//--------------------------------------------------------------------------------------------------
inline uno_Sequence * _getEmptySequence() SAL_THROW( () )
{
::osl_incrementInterlockedCount( &g_emptySeq.nRefCount );
return &g_emptySeq;
}
//--------------------------------------------------------------------------------------------------
inline typelib_TypeDescriptionReference * _getVoidType()
SAL_THROW( () )
{
if (! g_pVoidType)
{
g_pVoidType = * ::typelib_static_type_getByTypeClass( typelib_TypeClass_VOID );
}
::typelib_typedescriptionreference_acquire( g_pVoidType );
return g_pVoidType;
}
//--------------------------------------------------------------------------------------------------
#if OSL_DEBUG_LEVEL > 0
#define CONSTRUCT_EMPTY_ANY( pAny ) \
(pAny)->pType = _getVoidType(); \
(pAny)->pData = (void *)0xdeadbeef;
#else
#define CONSTRUCT_EMPTY_ANY( pAny ) \
(pAny)->pType = _getVoidType(); \
(pAny)->pData = (pAny);
#endif
//--------------------------------------------------------------------------------------------------
#define TYPE_ACQUIRE( pType ) \
::osl_incrementInterlockedCount( &(pType)->nRefCount );
//--------------------------------------------------------------------------------------------------
void * binuno_queryInterface( void * pUnoI, typelib_TypeDescriptionReference * pDestType );
//--------------------------------------------------------------------------------------------------
inline typelib_TypeDescriptionReference * _unionGetSetType(
void * pUnion, typelib_TypeDescription * pTD )
SAL_THROW( () )
{
typelib_TypeDescriptionReference * pRet;
sal_Int64 * pDiscr = ((typelib_UnionTypeDescription *)pTD)->pDiscriminants;
sal_Int64 nDiscr = *(sal_Int64 *)pUnion;
for ( sal_Int32 nPos = ((typelib_UnionTypeDescription *)pTD)->nMembers; nPos--; )
{
if (pDiscr[nPos] == nDiscr)
{
pRet = ((typelib_UnionTypeDescription *)pTD)->ppTypeRefs[nPos];
break;
}
}
if (nPos >= 0)
{
// default
pRet = ((typelib_UnionTypeDescription *)pTD)->pDefaultTypeRef;
}
typelib_typedescriptionreference_acquire( pRet );
return pRet;
}
//--------------------------------------------------------------------------------------------------
inline sal_Bool _type_equals(
typelib_TypeDescriptionReference * pType1, typelib_TypeDescriptionReference * pType2 )
SAL_THROW( () )
{
return (pType1 == pType2 ||
(pType1->eTypeClass == pType2->eTypeClass &&
pType1->pTypeName->length == pType2->pTypeName->length &&
::rtl_ustr_compare( pType1->pTypeName->buffer, pType2->pTypeName->buffer ) == 0));
}
}
#endif