1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
19 #ifndef INCLUDED_TYPELIB_TYPEDESCRIPTION_H
20 #define INCLUDED_TYPELIB_TYPEDESCRIPTION_H
22 #include "cppu/cppudllapi.h"
23 #include "typelib/uik.h"
24 #include "typelib/typeclass.h"
25 #include "rtl/ustring.h"
32 struct _typelib_TypeDescription
;
38 /** Holds a weak reference to a type description.
40 typedef struct SAL_DLLPUBLIC_RTTI _typelib_TypeDescriptionReference
42 /** reference count of type; don't ever modify this by yourself, use
43 typelib_typedescriptionreference_acquire() and typelib_typedescriptionreference_release()
46 /** number of static references of type, because of the fact that some types are needed
47 until program termination and are commonly held static.
49 sal_Int32 nStaticRefCount
;
50 /** type class of type
52 typelib_TypeClass eTypeClass
;
53 /** fully qualified name of type
55 rtl_uString
* pTypeName
;
56 /** pointer to full typedescription; this value is only valid if the type is never swapped out
58 struct _typelib_TypeDescription
* pType
;
59 /** pointer to optimize the runtime; not for public use
61 void * pUniqueIdentifier
;
62 /** reserved for future use; 0 if not used
65 } typelib_TypeDescriptionReference
;
67 /** Full type description of a type. Memory layout of this struct is identical to the
68 typelib_TypeDescriptionReference for the first six members.
69 So a typedescription can be used as type reference.
71 typedef struct SAL_DLLPUBLIC_RTTI _typelib_TypeDescription
73 /** reference count; don't ever modify this by yourself, use
74 typelib_typedescription_acquire() and typelib_typedescription_release()
77 /** number of static references of type, because of the fact that some types are needed
78 until program termination and are commonly held static.
80 sal_Int32 nStaticRefCount
;
81 /** type class of type
83 typelib_TypeClass eTypeClass
;
84 /** fully qualified name of type
86 rtl_uString
* pTypeName
;
87 /** pointer to self to distinguish reference from description; for internal use only
89 struct _typelib_TypeDescription
* pSelf
;
90 /** pointer to optimize the runtime; not for public use
92 void * pUniqueIdentifier
;
93 /** reserved for future use; 0 if not used
97 /** flag to determine whether the description is complete:
98 compound types lack of member names, enums lack of member types and names,
99 interfaces lack of members and table init.
100 Call typelib_typedescription_complete() if false.
106 /** alignment of type
108 sal_Int32 nAlignment
;
109 /** pointer to weak reference
111 typelib_TypeDescriptionReference
* pWeakRef
;
112 /** determines, if type can be unloaded (and it is possible to reloaded it)
115 } typelib_TypeDescription
;
117 /** Type description for exception types.
119 typedef struct _typelib_CompoundTypeDescription
121 /** inherits all members of typelib_TypeDescription
123 typelib_TypeDescription aBase
;
125 /** pointer to base type description, else 0
127 struct _typelib_CompoundTypeDescription
* pBaseTypeDescription
;
129 /** number of members
132 /** byte offsets of each member including the size the base type
134 sal_Int32
* pMemberOffsets
;
135 /** members of the struct or exception
137 typelib_TypeDescriptionReference
** ppTypeRefs
;
138 /** member names of the struct or exception
140 rtl_uString
** ppMemberNames
;
141 } typelib_CompoundTypeDescription
;
144 Type description for struct types.
146 This is only used to represent plain struct types and instantiated
147 polymorphic struct types; there is no representation of polymorphic struct
148 type templates at this level.
152 typedef struct _typelib_StructTypeDescription
155 Derived from typelib_CompoundTypeDescription.
157 typelib_CompoundTypeDescription aBase
;
160 Flags for direct members, specifying whether they are of parameterized
161 type (true) or explicit type (false).
163 For a plain struct type, this is a null pointer.
165 sal_Bool
* pParameterizedTypes
;
166 } typelib_StructTypeDescription
;
168 /** Type description of a sequence.
170 typedef struct _typelib_IndirectTypeDescription
172 /** inherits all members of typelib_TypeDescription
174 typelib_TypeDescription aBase
;
176 /** pointer to element type
178 typelib_TypeDescriptionReference
* pType
;
179 } typelib_IndirectTypeDescription
;
181 /** Type description of an enum. The type class of this description is typelib_TypeClass_ENUM.
183 typedef struct _typelib_EnumTypeDescription
185 /** inherits all members of typelib_TypeDescription
187 typelib_TypeDescription aBase
;
189 /** first value of the enum
191 sal_Int32 nDefaultEnumValue
;
192 /** number of enum values
194 sal_Int32 nEnumValues
;
195 /** names of enum values
197 rtl_uString
** ppEnumNames
;
198 /** values of enum (corresponding to names in similar order)
200 sal_Int32
* pEnumValues
;
201 } typelib_EnumTypeDescription
;
203 /** Description of an interface method parameter.
205 typedef struct _typelib_MethodParameter
207 /** name of parameter
210 /** type of parameter
212 typelib_TypeDescriptionReference
* pTypeRef
;
213 /** true: the call type of this parameter is [in] or [inout]
214 false: the call type of this parameter is [out]
217 /** true: the call type of this parameter is [out] or [inout]
218 false: the call type of this parameter is [in]
221 } typelib_MethodParameter
;
223 /** Common base type description of typelib_InterfaceMethodTypeDescription and
224 typelib_InterfaceAttributeTypeDescription.
226 typedef struct _typelib_InterfaceMemberTypeDescription
228 /** inherits all members of typelib_TypeDescription
230 typelib_TypeDescription aBase
;
232 /** position of member in the interface including the number of members of
238 rtl_uString
* pMemberName
;
239 } typelib_InterfaceMemberTypeDescription
;
241 /** Type description of an interface method. The type class of this description is
242 typelib_TypeClass_INTERFACE_METHOD. The size and the alignment are 0.
244 typedef struct _typelib_InterfaceMethodTypeDescription
246 /** inherits all members of typelib_InterfaceMemberTypeDescription
248 typelib_InterfaceMemberTypeDescription aBase
;
250 /** type of the return value
252 typelib_TypeDescriptionReference
* pReturnTypeRef
;
253 /** number of parameters
256 /** array of parameters
258 typelib_MethodParameter
* pParams
;
259 /** number of exceptions
261 sal_Int32 nExceptions
;
262 /** array of exception types
264 typelib_TypeDescriptionReference
** ppExceptions
;
265 /** determines whether method is declared oneway
269 /** the interface description this method is a member of
271 struct _typelib_InterfaceTypeDescription
* pInterface
;
272 /** the inherited direct base method (null for a method that is not
277 typelib_TypeDescriptionReference
* pBaseRef
;
278 /** if pBaseRef is null, the member position of this method within
279 pInterface, not counting members inherited from bases; if pBaseRef is
280 not null, the index of the direct base within pInterface from which this
286 } typelib_InterfaceMethodTypeDescription
;
288 /** The description of an interface attribute. The type class of this description is
289 typelib_TypeClass_INTERFACE_ATTRIBUTE. The size and the alignment are 0.
291 typedef struct _typelib_InterfaceAttributeTypeDescription
293 /** inherits all members of typelib_InterfaceMemberTypeDescription
295 typelib_InterfaceMemberTypeDescription aBase
;
297 /** determines whether attribute is read only
300 /** type of the attribute
302 typelib_TypeDescriptionReference
* pAttributeTypeRef
;
304 /** the interface description this attribute is a member of
306 struct _typelib_InterfaceTypeDescription
* pInterface
;
307 /** the inherited direct base attribute (null for an attribute that is not
312 typelib_TypeDescriptionReference
* pBaseRef
;
313 /** if pBaseRef is null, the member position of this attribute within
314 pInterface, not counting members inherited from bases; if pBaseRef is
315 not null, the index of the direct base within pInterface from which this
316 attribute is inherited
321 /** number of getter exceptions
325 sal_Int32 nGetExceptions
;
326 /** array of getter exception types
330 typelib_TypeDescriptionReference
** ppGetExceptions
;
331 /** number of setter exceptions
335 sal_Int32 nSetExceptions
;
336 /** array of setter exception types
340 typelib_TypeDescriptionReference
** ppSetExceptions
;
341 } typelib_InterfaceAttributeTypeDescription
;
343 /** Type description of an interface.
345 <p>Not all members are always initialized (not yet initialized members being
346 null); there are three levels:</p>
348 <li>Minimally, only <code>aBase</code>,
349 <code>pBaseTypeDescription</code>, <code>aUik</code>,
350 <code>nBaseTypes</code>, and <code>ppBaseTypes</code> are initialized;
351 <code>aBase.bComplete</code> is false. This only happens when an
352 interface type description is created with
353 <code>typelib_static_mi_interface_type_init</code> or
354 <code>typelib_static_interface_type_init</code>.</li>
356 <li>At the next level, <code>nMembers</code>, <code>ppMembers</code>,
357 <code>nAllMembers</code>, <code>ppAllMembers</code> are also
358 initialized; <code>aBase.bComplete</code> is still false. This happens
359 when an interface type description is created with
360 <code>typelib_typedescription_newMIInterface</code> or
361 <code>typelib_typedescription_newInterface</code>.</li>
363 <li>At the final level, <code>pMapMemberIndexToFunctionIndex</code>,
364 <code>nMapFunctionIndexToMemberIndex</code>, and
365 <code>pMapFunctionIndexToMemberIndex</code> are also initialized;
366 <code>aBase.bComplete</code> is true. This happens after a call to
367 <code>typelib_typedescription_complete</code>.</li>
370 typedef struct SAL_DLLPUBLIC_RTTI _typelib_InterfaceTypeDescription
372 /** inherits all members of typelib_TypeDescription
374 typelib_TypeDescription aBase
;
376 /** pointer to base type description, else 0
379 use nBaseTypes and ppBaseTypes instead
381 struct _typelib_InterfaceTypeDescription
* pBaseTypeDescription
;
382 /** unique identifier of interface
385 should always contain all-zeros
388 /** number of members
391 /** array of members; references attributes or methods
393 typelib_TypeDescriptionReference
** ppMembers
;
394 /** number of members including members of base interface
396 sal_Int32 nAllMembers
;
397 /** array of members including members of base interface; references attributes or methods
399 typelib_TypeDescriptionReference
** ppAllMembers
;
400 /** array mapping index of the member description to an index doubling for read-write
401 attributes (called function index); size of array is nAllMembers
403 sal_Int32
* pMapMemberIndexToFunctionIndex
;
404 /** number of members plus number of read-write attributes
406 sal_Int32 nMapFunctionIndexToMemberIndex
;
407 /** array mapping function index to member index; size of array is nMapFunctionIndexToMemberIndex
409 sal_Int32
* pMapFunctionIndexToMemberIndex
;
410 /** number of base types
414 sal_Int32 nBaseTypes
;
415 /** array of base type descriptions
419 struct _typelib_InterfaceTypeDescription
** ppBaseTypes
;
420 } typelib_InterfaceTypeDescription
;
422 /** Init struct of compound members for typelib_typedescription_new().
424 typedef struct _typelib_CompoundMember_Init
426 /** type class of compound member
428 typelib_TypeClass eTypeClass
;
429 /** name of type of compound member
431 For a member of an instantiated polymorphic struct type that is of
432 parameterized type, this will be a null pointer.
434 rtl_uString
* pTypeName
;
435 /** name of compound member
437 rtl_uString
* pMemberName
;
438 } typelib_CompoundMember_Init
;
441 Init struct of members for typelib_typedescription_newStruct().
445 typedef struct _typelib_StructMember_Init
448 Derived from typelib_CompoundMember_Init;
450 typelib_CompoundMember_Init aBase
;
453 Flag specifying whether the member is of parameterized type (true) or
454 explicit type (false).
456 sal_Bool bParameterizedType
;
457 } typelib_StructMember_Init
;
459 /** Init struct of interface methods for typelib_typedescription_new().
461 typedef struct _typelib_Parameter_Init
463 /** type class of parameter
465 typelib_TypeClass eTypeClass
;
466 /** name of parameter
468 rtl_uString
* pTypeName
;
469 /** name of parameter
471 rtl_uString
* pParamName
;
472 /** true, if parameter is [in] or [inout]
475 /** true, if parameter is [out] or [inout]
478 } typelib_Parameter_Init
;
484 /** Creates an enum type description.
486 @param ppRet inout enum type description
487 @param pTypeName name of enum
488 @param nDefaultValue default enum value
489 @param nEnumValues number of enum values
490 @param ppEnumNames names of enum values
491 @param pEnumValues enum values
493 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_newEnum(
494 typelib_TypeDescription
** ppRet
,
495 rtl_uString
* pTypeName
,
496 sal_Int32 nDefaultValue
,
497 sal_Int32 nEnumValues
,
498 rtl_uString
** ppEnumNames
,
499 sal_Int32
* pEnumValues
)
500 SAL_THROW_EXTERN_C();
502 /** Creates a new type description.
504 Since this function can only be used to create type descriptions for plain
505 struct types, not for instantiated polymorphic struct types, the function
506 typelib_typedescription_newStruct should be used instead for all struct
509 @param ppRet inout type description
510 @param eTypeClass type class
511 @param pTypeName name of type
512 @param pType sequence: element type;
513 struct, Exception: base type;
514 @param nMembers number of members if struct, exception
515 @param pMembers array of members if struct, exception
517 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_new(
518 typelib_TypeDescription
** ppRet
,
519 typelib_TypeClass eTypeClass
,
520 rtl_uString
* pTypeName
,
521 typelib_TypeDescriptionReference
* pType
,
523 typelib_CompoundMember_Init
* pMembers
)
524 SAL_THROW_EXTERN_C();
526 /** Creates a new struct type description.
528 @param ppRet inout type description
529 @param pTypeName name of type
530 @param pType base type;
531 @param nMembers number of members
532 @param pMembers array of members
536 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_newStruct(
537 typelib_TypeDescription
** ppRet
,
538 rtl_uString
* pTypeName
,
539 typelib_TypeDescriptionReference
* pType
,
541 typelib_StructMember_Init
* pMembers
)
542 SAL_THROW_EXTERN_C();
544 /** Creates an interface type description.
546 @param ppRet inout interface type description
547 @param pTypeName the fully qualified name of the interface.
548 @param nUik1 uik part; deprecated and ignored, should always be 0
549 @param nUik2 uik part; deprecated and ignored, should always be 0
550 @param nUik3 uik part; deprecated and ignored, should always be 0
551 @param nUik4 uik part; deprecated and ignored, should always be 0
552 @param nUik5 uik part; deprecated and ignored, should always be 0
553 @param pBaseInterface base interface type, else 0
554 @param nMembers number of members
555 @param ppMembers members; attributes or methods
558 use typelib_typedescription_newMIInterface instead
560 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_newInterface(
561 typelib_InterfaceTypeDescription
** ppRet
,
562 rtl_uString
* pTypeName
,
563 sal_uInt32 nUik1
, sal_uInt16 nUik2
, sal_uInt16 nUik3
, sal_uInt32 nUik4
, sal_uInt32 nUik5
,
564 typelib_TypeDescriptionReference
* pBaseInterface
,
566 typelib_TypeDescriptionReference
** ppMembers
)
567 SAL_THROW_EXTERN_C();
569 /** Creates a multiple-inheritance interface type description.
571 @param ppRet inout interface type description
572 @param pTypeName the fully qualified name of the interface.
573 @param nUik1 uik part; deprecated and ignored, should always be 0
574 @param nUik2 uik part; deprecated and ignored, should always be 0
575 @param nUik3 uik part; deprecated and ignored, should always be 0
576 @param nUik4 uik part; deprecated and ignored, should always be 0
577 @param nUik5 uik part; deprecated and ignored, should always be 0
578 @param nBaseInterfaces number of base interface types
579 @param ppBaseInterfaces base interface types
580 @param nMembers number of members
581 @param ppMembers members; attributes or methods
585 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_newMIInterface(
586 typelib_InterfaceTypeDescription
** ppRet
,
587 rtl_uString
* pTypeName
,
588 sal_uInt32 nUik1
, sal_uInt16 nUik2
, sal_uInt16 nUik3
, sal_uInt32 nUik4
, sal_uInt32 nUik5
,
589 sal_Int32 nBaseInterfaces
,
590 typelib_TypeDescriptionReference
** ppBaseInterfaces
,
592 typelib_TypeDescriptionReference
** ppMembers
)
593 SAL_THROW_EXTERN_C();
595 /** Creates an interface method type description.
597 @param ppRet inout method type description
598 @param nAbsolutePosition position of member including all members of base interfaces
599 @param bOneWay determines whether method is declared oneway
600 @param pMethodName fully qualified name of method including interface name
601 @param eReturnTypeClass type class of return type
602 @param pReturnTypeName type name of the return type
603 @param nParams number of parameters
604 @param pParams parameter types
605 @param nExceptions number of exceptions
606 @param ppExceptionNames type names of exceptions
608 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_newInterfaceMethod(
609 typelib_InterfaceMethodTypeDescription
** ppRet
,
610 sal_Int32 nAbsolutePosition
,
612 rtl_uString
* pMethodName
,
613 typelib_TypeClass eReturnTypeClass
,
614 rtl_uString
* pReturnTypeName
,
616 typelib_Parameter_Init
* pParams
,
617 sal_Int32 nExceptions
,
618 rtl_uString
** ppExceptionNames
)
619 SAL_THROW_EXTERN_C();
621 /** Creates an interface attribute type description.
623 @param ppRet inout attribute type description
624 @param nAbsolutePosition position of this attribute including all members of base interfaces
625 @param pAttributeName fully qualified name of attribute including interface
627 @param eAttributeTypeClass type class of attribute type
628 @param pAttributeTypeName type name of attribute type
629 @param bReadOnly determines whether attribute is read-only
632 use typelib_typedescription_newExtendedInterfaceAttribute instead
634 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_newInterfaceAttribute(
635 typelib_InterfaceAttributeTypeDescription
** ppRet
,
636 sal_Int32 nAbsolutePosition
,
637 rtl_uString
* pAttributeName
,
638 typelib_TypeClass eAttributeTypeClass
,
639 rtl_uString
* pAttributeTypeName
,
641 SAL_THROW_EXTERN_C();
643 /** Creates an extended interface attribute type description.
645 @param ppRet inout attribute type description
646 @param nAbsolutePosition position of this attribute including all members of
648 @param pAttributeName fully qualified name of attribute including interface
650 @param eAttributeTypeClass type class of attribute type
651 @param pAttributeTypeName type name of attribute type
652 @param bReadOnly determines whether attribute is read-only
653 @param nGetExceptions number of getter exceptions
654 @param ppGetExceptionNames type names of getter exceptions
655 @param nSetExceptions number of setter exceptions
656 @param ppSetExceptionNames type names of setter exceptions
660 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_newExtendedInterfaceAttribute(
661 typelib_InterfaceAttributeTypeDescription
** ppRet
,
662 sal_Int32 nAbsolutePosition
,
663 rtl_uString
* pAttributeName
,
664 typelib_TypeClass eAttributeTypeClass
,
665 rtl_uString
* pAttributeTypeName
,
667 sal_Int32 nGetExceptions
, rtl_uString
** ppGetExceptionNames
,
668 sal_Int32 nSetExceptions
, rtl_uString
** ppSetExceptionNames
)
669 SAL_THROW_EXTERN_C();
671 /** Increments reference count of given type description.
673 @param pDesc type description
675 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_acquire(
676 typelib_TypeDescription
* pDesc
)
677 SAL_THROW_EXTERN_C();
679 /** Decrements reference count of given type. If reference count reaches 0, the type description
682 @param pDesc type description
684 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_release(
685 typelib_TypeDescription
* pDesc
)
686 SAL_THROW_EXTERN_C();
688 /** Registers a type description and creates a type description reference. Type descriptions
689 will be registered automatically if they are provided via the callback chain.
691 @param ppNewDescription inout description to be registered;
693 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_register(
694 typelib_TypeDescription
** ppNewDescription
)
695 SAL_THROW_EXTERN_C();
697 /** Tests whether two types descriptions are equal, i.e. type class and names are equal.
699 @param p1 a type description
700 @param p2 another type description
701 @return true, if type descriptions are equal
703 CPPU_DLLPUBLIC sal_Bool SAL_CALL
typelib_typedescription_equals(
704 const typelib_TypeDescription
* p1
, const typelib_TypeDescription
* p2
)
705 SAL_THROW_EXTERN_C();
707 /** Retrieves a type description via its fully qualified name.
709 @param ppRet inout type description; *ppRet is 0, if type description was not found
710 @param pName name demanded type description
712 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_getByName(
713 typelib_TypeDescription
** ppRet
, rtl_uString
* pName
)
714 SAL_THROW_EXTERN_C();
716 /** Sets size of type description cache.
718 @param nNewSize new size of cache
720 CPPU_DLLPUBLIC
void SAL_CALL
typelib_setCacheSize(
722 SAL_THROW_EXTERN_C();
724 /** Function pointer declaration of callback function get additional descriptions. Callbacks
725 must provide complete type descriptions (see typelib_typedescription_complete())!
727 @param pContext callback context
728 @param ppRet inout type description
729 @param pTypeName name of demanded type description
731 typedef void (SAL_CALL
* typelib_typedescription_Callback
)(
732 void * pContext
, typelib_TypeDescription
** ppRet
, rtl_uString
* pTypeName
);
734 /** Registers callback function providing additional type descriptions.
736 @param pContext callback context
737 @param pCallback callback function
739 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_registerCallback(
740 void * pContext
, typelib_typedescription_Callback pCallback
)
741 SAL_THROW_EXTERN_C();
743 /** Revokes a previously registered callback function.
745 @param pContext callback context
746 @param pCallback registered callback function
748 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescription_revokeCallback(
749 void * pContext
, typelib_typedescription_Callback pCallback
)
750 SAL_THROW_EXTERN_C();
753 /*----------------------------------------------------------------------------*/
754 /*----------------------------------------------------------------------------*/
755 /*----------------------------------------------------------------------------*/
757 /** Creates a type description reference. This is a weak reference not holding the description.
758 If the description is already registered, the previous one is returned.
760 @param ppTDR inout type description reference
761 @param eTypeClass type class of type
762 @param pTypeName name of type
764 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescriptionreference_new(
765 typelib_TypeDescriptionReference
** ppTDR
,
766 typelib_TypeClass eTypeClass
,
767 rtl_uString
* pTypeName
)
768 SAL_THROW_EXTERN_C();
770 /** Creates a type description reference. This is a weak reference not holding the description.
771 If the description is already registered, the previous one is returned.
773 @param ppTDR inout type description reference
774 @param eTypeClass type class of type
775 @param pTypeName ascii name of type
777 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescriptionreference_newByAsciiName(
778 typelib_TypeDescriptionReference
** ppTDR
,
779 typelib_TypeClass eTypeClass
,
780 const char * pTypeName
)
781 SAL_THROW_EXTERN_C();
783 /** Increments reference count of type description reference.
785 @param pRef type description reference
787 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescriptionreference_acquire(
788 typelib_TypeDescriptionReference
* pRef
)
789 SAL_THROW_EXTERN_C();
791 /** Increments reference count of type description reference. If the reference count reaches 0,
792 then the reference is deleted.
794 @param pRef type description reference
796 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescriptionreference_release(
797 typelib_TypeDescriptionReference
* pRef
)
798 SAL_THROW_EXTERN_C();
800 /** Retrieves the type description for a given reference. If it is not possible to resolve the
801 reference, null is returned.
803 @param[in,out] ppRet type description
804 @param[in] pRef type description reference
806 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescriptionreference_getDescription(
807 typelib_TypeDescription
** ppRet
, typelib_TypeDescriptionReference
* pRef
)
808 SAL_THROW_EXTERN_C();
810 /** Tests whether two types description references are equal, i.e. type class and names are equal.
812 @param p1 a type description reference
813 @param p2 another type description reference
814 @return true, if type description references are equal
816 CPPU_DLLPUBLIC sal_Bool SAL_CALL
typelib_typedescriptionreference_equals(
817 const typelib_TypeDescriptionReference
* p1
, const typelib_TypeDescriptionReference
* p2
)
818 SAL_THROW_EXTERN_C();
822 @param ppDest destination type
823 @param pSource source type
825 CPPU_DLLPUBLIC
void SAL_CALL
typelib_typedescriptionreference_assign(
826 typelib_TypeDescriptionReference
** ppDest
,
827 typelib_TypeDescriptionReference
* pSource
)
828 SAL_THROW_EXTERN_C();
830 /** Tests if values of type pAssignable can be assigned by values of type pFrom. This includes
831 widening conversion (e.g., long assignable from short), as long as there is no data loss.
833 @param pAssignable type description of value to be assigned
834 @param pFrom type description of value
836 CPPU_DLLPUBLIC sal_Bool SAL_CALL
typelib_typedescription_isAssignableFrom(
837 typelib_TypeDescription
* pAssignable
,
838 typelib_TypeDescription
* pFrom
)
839 SAL_THROW_EXTERN_C();
841 /** Tests if values of type pAssignable can be assigned by values of type pFrom. This includes
842 widening conversion (e.g., long assignable from short), as long as there is no data loss.
844 @param pAssignable type of value to be assigned
845 @param pFrom type of value
847 CPPU_DLLPUBLIC sal_Bool SAL_CALL
typelib_typedescriptionreference_isAssignableFrom(
848 typelib_TypeDescriptionReference
* pAssignable
,
849 typelib_TypeDescriptionReference
* pFrom
)
850 SAL_THROW_EXTERN_C();
852 /** Gets static type reference of standard types by type class.
853 ADDITIONAL OPT: provides Type com.sun.star.uno.Exception for typelib_TypeClass_EXCEPTION
854 and com.sun.star.uno.XInterface for typelib_TypeClass_INTERFACE.
856 Thread synchronizes on typelib mutex.
858 @param eTypeClass type class of basic type
859 @return pointer to type reference pointer
861 CPPU_DLLPUBLIC typelib_TypeDescriptionReference
** SAL_CALL
typelib_static_type_getByTypeClass(
862 typelib_TypeClass eTypeClass
)
863 SAL_THROW_EXTERN_C();
865 /** Inits static type reference. Thread synchronizes on typelib init mutex.
867 @param ppRef pointer to type reference pointer
868 @param eTypeClass type class of type
869 @param pTypeName ascii name of type
871 CPPU_DLLPUBLIC
void SAL_CALL
typelib_static_type_init(
872 typelib_TypeDescriptionReference
** ppRef
,
873 typelib_TypeClass eTypeClass
, const char * pTypeName
)
874 SAL_THROW_EXTERN_C();
876 /** Inits static sequence type reference. Thread synchronizes on typelib init mutex.
878 @param ppRef pointer to type reference pointer
879 @param pElementType element type of sequence
881 CPPU_DLLPUBLIC
void SAL_CALL
typelib_static_sequence_type_init(
882 typelib_TypeDescriptionReference
** ppRef
,
883 typelib_TypeDescriptionReference
* pElementType
)
884 SAL_THROW_EXTERN_C ();
886 /** Inits incomplete static compound type reference. Thread synchronizes on typelib init mutex.
888 Since this function can only be used to create type descriptions for plain
889 struct types, not for instantiated polymorphic struct types, the function
890 typelib_static_struct_type_init should be used instead for all struct types.
892 @param ppRef pointer to type reference pointer
893 @param eTypeClass typelib_TypeClass_STRUCT or typelib_TypeClass_EXCEPTION
894 @param pTypeName name of type
895 @param pBaseType base type
896 @param nMembers number of members
897 @param ppMembers member types
899 CPPU_DLLPUBLIC
void SAL_CALL
typelib_static_compound_type_init(
900 typelib_TypeDescriptionReference
** ppRef
,
901 typelib_TypeClass eTypeClass
, const char * pTypeName
,
902 typelib_TypeDescriptionReference
* pBaseType
,
903 sal_Int32 nMembers
, typelib_TypeDescriptionReference
** ppMembers
)
904 SAL_THROW_EXTERN_C();
906 /** Inits incomplete static struct type reference.
908 Thread synchronizes on typelib init mutex.
910 @param ppRef pointer to type reference pointer
911 @param pTypeName name of type
912 @param pBaseType base type
913 @param nMembers number of members
914 @param ppMembers member types
915 @param pParameterizedTypes flags for direct members, specifying whether they
916 are of parameterized type (true) or explicit type (false); must be null
917 for a plain struct type
921 CPPU_DLLPUBLIC
void SAL_CALL
typelib_static_struct_type_init(
922 typelib_TypeDescriptionReference
** ppRef
, const char * pTypeName
,
923 typelib_TypeDescriptionReference
* pBaseType
,
924 sal_Int32 nMembers
, typelib_TypeDescriptionReference
** ppMembers
,
925 sal_Bool
const * pParameterizedTypes
)
926 SAL_THROW_EXTERN_C();
928 /** Inits incomplete static interface type reference. Thread synchronizes on typelib init mutex.
930 @param ppRef pointer to type reference pointer
931 @param pTypeName name of interface
932 @param pBaseType base type
934 CPPU_DLLPUBLIC
void SAL_CALL
typelib_static_interface_type_init(
935 typelib_TypeDescriptionReference
** ppRef
,
936 const char * pTypeName
,
937 typelib_TypeDescriptionReference
* pBaseType
)
938 SAL_THROW_EXTERN_C();
940 /** Inits incomplete static multiple-inheritance interface type reference.
941 Thread synchronizes on typelib init mutex.
943 @param ppRef pointer to type reference pointer
944 @param pTypeName name of interface
945 @param nBaseTypes number of base types
946 @param ppBaseTypes base types
950 CPPU_DLLPUBLIC
void SAL_CALL
typelib_static_mi_interface_type_init(
951 typelib_TypeDescriptionReference
** ppRef
,
952 const char * pTypeName
,
953 sal_Int32 nBaseTypes
,
954 typelib_TypeDescriptionReference
** ppBaseTypes
)
955 SAL_THROW_EXTERN_C();
957 /** Inits incomplete static enum type reference. Thread synchronizes on typelib init mutex.
959 @param ppRef pointer to type reference pointer
960 @param pTypeName name of enum
961 @param nDefaultValue default enum value
963 CPPU_DLLPUBLIC
void SAL_CALL
typelib_static_enum_type_init(
964 typelib_TypeDescriptionReference
** ppRef
,
965 const char * pTypeName
,
966 sal_Int32 nDefaultValue
)
967 SAL_THROW_EXTERN_C();
969 /** Completes a typedescription to be used for, e.g., marshalling values. COMPOUND,
970 INTERFACE and ENUM type descriptions may be partly initialized (see typelib_static_...(),
971 typelib_TypeDescription::bComplete). For interface type descriptions, this will also
974 @param ppTypeDescr [inout] type description to be completed (may be exchanged!)
975 @return true, if type description is complete
977 CPPU_DLLPUBLIC sal_Bool SAL_CALL
typelib_typedescription_complete(
978 typelib_TypeDescription
** ppTypeDescr
)
979 SAL_THROW_EXTERN_C();
983 /** Returns true, if the type description reference may lose the type description. Otherwise
984 pType is a valid pointer and cannot be discarded through the lifetime of this reference.
985 Remark: If the pWeakObj of the type is set too, you can avoid the call of
986 ...getDescription(...) and use the description directly. pWeakObj == 0 means, that the
987 description is not initialized.
990 #if defined LIBO_INTERNAL_ONLY && defined __cplusplus
993 inline bool TYPELIB_TYPEDESCRIPTIONREFERENCE_ISREALLYWEAK( _typelib_TypeClass eTypeClass
)
995 return (eTypeClass
== typelib_TypeClass_INTERFACE_METHOD
) ||
996 (eTypeClass
== typelib_TypeClass_INTERFACE_ATTRIBUTE
);
999 /** Gets a description from the reference. The description may not be locked by this call.
1000 You must use the TYPELIB_DANGER_RELEASE macro to release the description fetched with
1004 inline void TYPELIB_DANGER_GET( typelib_TypeDescription
** ppMacroTypeDescr
,
1005 typelib_TypeDescriptionReference
* pMacroTypeRef
)
1007 if (TYPELIB_TYPEDESCRIPTIONREFERENCE_ISREALLYWEAK( pMacroTypeRef
->eTypeClass
))
1009 typelib_typedescriptionreference_getDescription( ppMacroTypeDescr
, pMacroTypeRef
);
1011 else if (!pMacroTypeRef
->pType
|| !pMacroTypeRef
->pType
->pWeakRef
)
1013 typelib_typedescriptionreference_getDescription( ppMacroTypeDescr
, pMacroTypeRef
);
1014 if (*ppMacroTypeDescr
)
1015 typelib_typedescription_release( *ppMacroTypeDescr
);
1019 *ppMacroTypeDescr
= pMacroTypeRef
->pType
;
1023 /** Releases the description previous fetched by TYPELIB_DANGER_GET.
1026 inline void TYPELIB_DANGER_RELEASE( typelib_TypeDescription
* pDescription
)
1028 if (TYPELIB_TYPEDESCRIPTIONREFERENCE_ISREALLYWEAK( pDescription
->eTypeClass
))
1029 typelib_typedescription_release( pDescription
);
1040 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */