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 _COM_SUN_STAR_UNO_GENFUNC_H_ 24cdf0e10cSrcweir #define _COM_SUN_STAR_UNO_GENFUNC_H_ 25cdf0e10cSrcweir 26cdf0e10cSrcweir #include "sal/types.h" 27cdf0e10cSrcweir 28cdf0e10cSrcweir typedef struct _typelib_TypeDescriptionReference typelib_TypeDescriptionReference; 29cdf0e10cSrcweir 30cdf0e10cSrcweir namespace com 31cdf0e10cSrcweir { 32cdf0e10cSrcweir namespace sun 33cdf0e10cSrcweir { 34cdf0e10cSrcweir namespace star 35cdf0e10cSrcweir { 36cdf0e10cSrcweir namespace uno 37cdf0e10cSrcweir { 38cdf0e10cSrcweir 39cdf0e10cSrcweir /** Function to acquire a C++ interface. 40cdf0e10cSrcweir 41cdf0e10cSrcweir @param pCppI C++ interface pointer 42cdf0e10cSrcweir */ 43cdf0e10cSrcweir inline void SAL_CALL cpp_acquire( void * pCppI ) 44cdf0e10cSrcweir SAL_THROW( () ); 45cdf0e10cSrcweir /** Function to release a C++ interface. 46cdf0e10cSrcweir 47cdf0e10cSrcweir @param pCppI C++ interface pointer 48cdf0e10cSrcweir */ 49cdf0e10cSrcweir inline void SAL_CALL cpp_release( void * pCppI ) 50cdf0e10cSrcweir SAL_THROW( () ); 51cdf0e10cSrcweir /** Function to query for a C++ interface. 52cdf0e10cSrcweir 53cdf0e10cSrcweir @param pCppI C++ interface pointer 54cdf0e10cSrcweir @param pType demanded interface type 55cdf0e10cSrcweir @return acquired C++ interface pointer or null 56cdf0e10cSrcweir */ 57cdf0e10cSrcweir inline void * SAL_CALL cpp_queryInterface( void * pCppI, typelib_TypeDescriptionReference * pType ) 58cdf0e10cSrcweir SAL_THROW( () ); 59cdf0e10cSrcweir 60cdf0e10cSrcweir } 61cdf0e10cSrcweir } 62cdf0e10cSrcweir } 63cdf0e10cSrcweir } 64cdf0e10cSrcweir 65cdf0e10cSrcweir #endif 66