1*24f6443dSAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*24f6443dSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*24f6443dSAndrew Rist * or more contributor license agreements. See the NOTICE file 5*24f6443dSAndrew Rist * distributed with this work for additional information 6*24f6443dSAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*24f6443dSAndrew Rist * to you under the Apache License, Version 2.0 (the 8*24f6443dSAndrew Rist * "License"); you may not use this file except in compliance 9*24f6443dSAndrew Rist * with the License. You may obtain a copy of the License at 10*24f6443dSAndrew Rist * 11*24f6443dSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*24f6443dSAndrew Rist * 13*24f6443dSAndrew Rist * Unless required by applicable law or agreed to in writing, 14*24f6443dSAndrew Rist * software distributed under the License is distributed on an 15*24f6443dSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*24f6443dSAndrew Rist * KIND, either express or implied. See the License for the 17*24f6443dSAndrew Rist * specific language governing permissions and limitations 18*24f6443dSAndrew Rist * under the License. 19*24f6443dSAndrew Rist * 20*24f6443dSAndrew Rist *************************************************************/ 21*24f6443dSAndrew Rist 22*24f6443dSAndrew Rist 23cdf0e10cSrcweir #ifndef _UNO_ANY2_H_ 24cdf0e10cSrcweir #define _UNO_ANY2_H_ 25cdf0e10cSrcweir 26cdf0e10cSrcweir #include <sal/types.h> 27cdf0e10cSrcweir #include <uno/data.h> 28cdf0e10cSrcweir 29cdf0e10cSrcweir #ifdef __cplusplus 30cdf0e10cSrcweir extern "C" 31cdf0e10cSrcweir { 32cdf0e10cSrcweir #endif 33cdf0e10cSrcweir 34cdf0e10cSrcweir #if defined( SAL_W32) 35cdf0e10cSrcweir #pragma pack(push, 8) 36cdf0e10cSrcweir #elif defined(SAL_OS2) 37cdf0e10cSrcweir #pragma pack(push, 8) 38cdf0e10cSrcweir #endif 39cdf0e10cSrcweir 40cdf0e10cSrcweir struct _typelib_TypeDescriptionReference; 41cdf0e10cSrcweir struct _typelib_TypeDescription; 42cdf0e10cSrcweir struct _uno_Mapping; 43cdf0e10cSrcweir 44cdf0e10cSrcweir /** This is the binary specification of an UNO any. 45cdf0e10cSrcweir */ 46cdf0e10cSrcweir typedef struct _uno_Any 47cdf0e10cSrcweir { 48cdf0e10cSrcweir /** type of value 49cdf0e10cSrcweir */ 50cdf0e10cSrcweir struct _typelib_TypeDescriptionReference * pType; 51cdf0e10cSrcweir /** pointer to value; this may point to pReserved and thus the uno_Any is not anytime 52cdf0e10cSrcweir mem-copyable! You may have to correct the pData pointer to pReserved. Otherwise you need 53cdf0e10cSrcweir not, because the data is stored in heap space. 54cdf0e10cSrcweir */ 55cdf0e10cSrcweir void * pData; 56cdf0e10cSrcweir /** reserved space for storing value 57cdf0e10cSrcweir */ 58cdf0e10cSrcweir void * pReserved; 59cdf0e10cSrcweir } uno_Any; 60cdf0e10cSrcweir 61cdf0e10cSrcweir #if defined( SAL_W32) || defined(SAL_OS2) 62cdf0e10cSrcweir #pragma pack(pop) 63cdf0e10cSrcweir #endif 64cdf0e10cSrcweir 65cdf0e10cSrcweir /** Assign an any with a given value. Interfaces are acquired or released by the given callback 66cdf0e10cSrcweir functions. 67cdf0e10cSrcweir 68cdf0e10cSrcweir @param pDest pointer memory of destination any 69cdf0e10cSrcweir @param pSource pointer to source value; defaults (0) to default constructed value 70cdf0e10cSrcweir @param pTypeDescr type description of value; defaults (0) to void 71cdf0e10cSrcweir @param acquire function called each time an interface needs to be acquired; 72cdf0e10cSrcweir defaults (0) to uno 73cdf0e10cSrcweir @param release function called each time an interface needs to be released; 74cdf0e10cSrcweir defaults (0) to uno 75cdf0e10cSrcweir */ 76cdf0e10cSrcweir void SAL_CALL uno_any_assign( 77cdf0e10cSrcweir uno_Any * pDest, void * pSource, 78cdf0e10cSrcweir struct _typelib_TypeDescription * pTypeDescr, 79cdf0e10cSrcweir uno_AcquireFunc acquire, uno_ReleaseFunc release ) 80cdf0e10cSrcweir SAL_THROW_EXTERN_C(); 81cdf0e10cSrcweir /** Assign an any with a given value. Interfaces are acquired or released by the given callback 82cdf0e10cSrcweir functions. 83cdf0e10cSrcweir 84cdf0e10cSrcweir @param pDest pointer memory of destination any 85cdf0e10cSrcweir @param pSource pointer to source value; defaults (0) to default constructed value 86cdf0e10cSrcweir @param pTypeDescr type description of value; defaults (0) to void 87cdf0e10cSrcweir @param acquire function called each time an interface needs to be acquired; 88cdf0e10cSrcweir defaults (0) to uno 89cdf0e10cSrcweir @param release function called each time an interface needs to be released; 90cdf0e10cSrcweir defaults (0) to uno 91cdf0e10cSrcweir */ 92cdf0e10cSrcweir void SAL_CALL uno_type_any_assign( 93cdf0e10cSrcweir uno_Any * pDest, void * pSource, 94cdf0e10cSrcweir struct _typelib_TypeDescriptionReference * pType, 95cdf0e10cSrcweir uno_AcquireFunc acquire, uno_ReleaseFunc release ) 96cdf0e10cSrcweir SAL_THROW_EXTERN_C(); 97cdf0e10cSrcweir 98cdf0e10cSrcweir /** Constructs an any with a given value. Interfaces are acquired by the given callback function. 99cdf0e10cSrcweir 100cdf0e10cSrcweir @param pDest pointer memory of destination any 101cdf0e10cSrcweir @param pSource pointer to source value; defaults (0) to default constructed value 102cdf0e10cSrcweir @param pTypeDescr type description of value; defaults (0) to void 103cdf0e10cSrcweir @param acquire function called each time an interface needs to be acquired; 104cdf0e10cSrcweir defaults (0) to uno 105cdf0e10cSrcweir */ 106cdf0e10cSrcweir void SAL_CALL uno_any_construct( 107cdf0e10cSrcweir uno_Any * pDest, void * pSource, 108cdf0e10cSrcweir struct _typelib_TypeDescription * pTypeDescr, 109cdf0e10cSrcweir uno_AcquireFunc acquire ) 110cdf0e10cSrcweir SAL_THROW_EXTERN_C(); 111cdf0e10cSrcweir /** Constructs an any with a given value. Interfaces are acquired by the given callback function. 112cdf0e10cSrcweir 113cdf0e10cSrcweir @param pDest pointer memory of destination any 114cdf0e10cSrcweir @param pSource pointer to source value; defaults (0) to default constructed value 115cdf0e10cSrcweir @param pType type of value; defaults (0) to void 116cdf0e10cSrcweir @param acquire function called each time an interface needs to be acquired; 117cdf0e10cSrcweir defaults (0) to uno 118cdf0e10cSrcweir */ 119cdf0e10cSrcweir void SAL_CALL uno_type_any_construct( 120cdf0e10cSrcweir uno_Any * pDest, void * pSource, 121cdf0e10cSrcweir struct _typelib_TypeDescriptionReference * pType, 122cdf0e10cSrcweir uno_AcquireFunc acquire ) 123cdf0e10cSrcweir SAL_THROW_EXTERN_C(); 124cdf0e10cSrcweir 125cdf0e10cSrcweir /** Constructs an any with a given value and converts/ maps interfaces. 126cdf0e10cSrcweir 127cdf0e10cSrcweir @param pDest pointer memory of destination any 128cdf0e10cSrcweir @param pSource pointer to source value; defaults (0) to default constructed value 129cdf0e10cSrcweir @param pTypeDescr type description of value; defaults (0) to void 130cdf0e10cSrcweir @param mapping mapping to convert/ map interfaces 131cdf0e10cSrcweir */ 132cdf0e10cSrcweir void SAL_CALL uno_any_constructAndConvert( 133cdf0e10cSrcweir uno_Any * pDest, void * pSource, 134cdf0e10cSrcweir struct _typelib_TypeDescription * pTypeDescr, 135cdf0e10cSrcweir struct _uno_Mapping * mapping ) 136cdf0e10cSrcweir SAL_THROW_EXTERN_C(); 137cdf0e10cSrcweir /** Constructs an any with a given value and converts/ maps interfaces. 138cdf0e10cSrcweir 139cdf0e10cSrcweir @param pDest pointer memory of destination any 140cdf0e10cSrcweir @param pSource pointer to source value; defaults (0) to default constructed value 141cdf0e10cSrcweir @param pType type of value; defaults (0) to void 142cdf0e10cSrcweir @param mapping mapping to convert/ map interfaces 143cdf0e10cSrcweir */ 144cdf0e10cSrcweir void SAL_CALL uno_type_any_constructAndConvert( 145cdf0e10cSrcweir uno_Any * pDest, void * pSource, 146cdf0e10cSrcweir struct _typelib_TypeDescriptionReference * pType, 147cdf0e10cSrcweir struct _uno_Mapping * mapping ) 148cdf0e10cSrcweir SAL_THROW_EXTERN_C(); 149cdf0e10cSrcweir 150cdf0e10cSrcweir /** Destructs an any. 151cdf0e10cSrcweir 152cdf0e10cSrcweir @param pValue pointer to any 153cdf0e10cSrcweir @param release function called each time an interface needs to be released; 154cdf0e10cSrcweir defaults (0) to uno 155cdf0e10cSrcweir */ 156cdf0e10cSrcweir void SAL_CALL uno_any_destruct( 157cdf0e10cSrcweir uno_Any * pValue, uno_ReleaseFunc release ) 158cdf0e10cSrcweir SAL_THROW_EXTERN_C(); 159cdf0e10cSrcweir 160cdf0e10cSrcweir /** Sets value to void. 161cdf0e10cSrcweir 162cdf0e10cSrcweir @param pValue pointer to any 163cdf0e10cSrcweir @param release function called each time an interface needs to be released; 164cdf0e10cSrcweir defaults (0) to uno 165cdf0e10cSrcweir */ 166cdf0e10cSrcweir void SAL_CALL uno_any_clear( 167cdf0e10cSrcweir uno_Any * pValue, uno_ReleaseFunc release ) 168cdf0e10cSrcweir SAL_THROW_EXTERN_C(); 169cdf0e10cSrcweir 170cdf0e10cSrcweir #ifdef __cplusplus 171cdf0e10cSrcweir } 172cdf0e10cSrcweir #endif 173cdf0e10cSrcweir 174cdf0e10cSrcweir #endif 175