2 * Copyright (c) 2014 Apple Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
25 Copyright (c) 1999-2013, Apple Inc. All rights reserved.
28 #if !defined(__COREFOUNDATION_CFPLUGIN__)
29 #define __COREFOUNDATION_CFPLUGIN__ 1
31 #if !defined(COREFOUNDATION_CFPLUGINCOM_SEPARATE)
32 #define COREFOUNDATION_CFPLUGINCOM_SEPARATE 1
35 #include <CoreFoundation/CFBase.h>
36 #include <CoreFoundation/CFArray.h>
37 #include <CoreFoundation/CFBundle.h>
38 #include <CoreFoundation/CFString.h>
39 #include <CoreFoundation/CFURL.h>
40 #include <CoreFoundation/CFUUID.h>
44 /* ================ Standard Info.plist keys for plugIns ================ */
46 CF_EXPORT
const CFStringRef kCFPlugInDynamicRegistrationKey
;
47 CF_EXPORT
const CFStringRef kCFPlugInDynamicRegisterFunctionKey
;
48 CF_EXPORT
const CFStringRef kCFPlugInUnloadFunctionKey
;
49 CF_EXPORT
const CFStringRef kCFPlugInFactoriesKey
;
50 CF_EXPORT
const CFStringRef kCFPlugInTypesKey
;
52 /* ================= Function prototypes for various callbacks ================= */
53 /* Function types that plugIn authors can implement for various purposes. */
55 typedef void (*CFPlugInDynamicRegisterFunction
)(CFPlugInRef plugIn
);
56 typedef void (*CFPlugInUnloadFunction
)(CFPlugInRef plugIn
);
57 typedef void *(*CFPlugInFactoryFunction
)(CFAllocatorRef allocator
, CFUUIDRef typeUUID
);
59 /* ================= Creating PlugIns ================= */
61 CF_EXPORT CFTypeID
CFPlugInGetTypeID(void);
63 CF_EXPORT CFPlugInRef
CFPlugInCreate(CFAllocatorRef allocator
, CFURLRef plugInURL
);
64 /* Might return an existing instance with the ref-count bumped. */
66 CF_EXPORT CFBundleRef
CFPlugInGetBundle(CFPlugInRef plugIn
);
68 /* ================= Controlling load on demand ================= */
70 /* PlugIns that do static registration are load on demand by default. */
71 /* PlugIns that do dynamic registration are not load on demand by default. */
72 /* A dynamic registration function can call CFPlugInSetLoadOnDemand(). */
74 CF_EXPORT
void CFPlugInSetLoadOnDemand(CFPlugInRef plugIn
, Boolean flag
);
76 CF_EXPORT Boolean
CFPlugInIsLoadOnDemand(CFPlugInRef plugIn
);
78 /* ================= Finding factories and creating instances ================= */
79 /* For plugIn hosts. */
80 /* Functions for finding factories to create specific types and actually creating instances of a type. */
82 /* This function finds all the factories from any plugin for the given type. Returns an array that the caller must release. */
83 CF_EXPORT CFArrayRef
CFPlugInFindFactoriesForPlugInType(CFUUIDRef typeUUID
) CF_RETURNS_RETAINED
;
86 /* This function restricts the result to factories from the given plug-in that can create the given type. Returns an array that the caller must release. */
87 CF_EXPORT CFArrayRef
CFPlugInFindFactoriesForPlugInTypeInPlugIn(CFUUIDRef typeUUID
, CFPlugInRef plugIn
) CF_RETURNS_RETAINED
;
89 /* This function returns the IUnknown interface for the new instance. */
90 CF_EXPORT
void *CFPlugInInstanceCreate(CFAllocatorRef allocator
, CFUUIDRef factoryUUID
, CFUUIDRef typeUUID
);
92 /* ================= Registering factories and types ================= */
93 /* For plugIn writers who must dynamically register things. */
94 /* Functions to register factory functions and to associate factories with types. */
96 CF_EXPORT Boolean
CFPlugInRegisterFactoryFunction(CFUUIDRef factoryUUID
, CFPlugInFactoryFunction func
);
98 CF_EXPORT Boolean
CFPlugInRegisterFactoryFunctionByName(CFUUIDRef factoryUUID
, CFPlugInRef plugIn
, CFStringRef functionName
);
100 CF_EXPORT Boolean
CFPlugInUnregisterFactory(CFUUIDRef factoryUUID
);
102 CF_EXPORT Boolean
CFPlugInRegisterPlugInType(CFUUIDRef factoryUUID
, CFUUIDRef typeUUID
);
104 CF_EXPORT Boolean
CFPlugInUnregisterPlugInType(CFUUIDRef factoryUUID
, CFUUIDRef typeUUID
);
106 /* ================= Registering instances ================= */
107 /* When a new instance of a type is created, the instance is responsible for registering itself with the factory that created it and unregistering when it deallocates. */
108 /* This means that an instance must keep track of the CFUUIDRef of the factory that created it so it can unregister when it goes away. */
110 CF_EXPORT
void CFPlugInAddInstanceForFactory(CFUUIDRef factoryID
);
112 CF_EXPORT
void CFPlugInRemoveInstanceForFactory(CFUUIDRef factoryID
);
117 typedef struct __CFPlugInInstance
*CFPlugInInstanceRef
;
119 typedef Boolean (*CFPlugInInstanceGetInterfaceFunction
)(CFPlugInInstanceRef instance
, CFStringRef interfaceName
, void **ftbl
);
120 typedef void (*CFPlugInInstanceDeallocateInstanceDataFunction
)(void *instanceData
);
122 CF_EXPORT Boolean
CFPlugInInstanceGetInterfaceFunctionTable(CFPlugInInstanceRef instance
, CFStringRef interfaceName
, void **ftbl
);
124 /* This function returns a retained object on 10.8 or later. */
125 CF_EXPORT CFStringRef
CFPlugInInstanceGetFactoryName(CFPlugInInstanceRef instance
) CF_RETURNS_RETAINED
;
127 CF_EXPORT
void *CFPlugInInstanceGetInstanceData(CFPlugInInstanceRef instance
);
129 CF_EXPORT CFTypeID
CFPlugInInstanceGetTypeID(void);
131 CF_EXPORT CFPlugInInstanceRef
CFPlugInInstanceCreateWithInstanceDataSize(CFAllocatorRef allocator
, CFIndex instanceDataSize
, CFPlugInInstanceDeallocateInstanceDataFunction deallocateInstanceFunction
, CFStringRef factoryName
, CFPlugInInstanceGetInterfaceFunction getInterfaceFunction
);
135 #if !COREFOUNDATION_CFPLUGINCOM_SEPARATE
136 #include <CoreFoundation/CFPlugInCOM.h>
137 #endif /* !COREFOUNDATION_CFPLUGINCOM_SEPARATE */
139 #endif /* ! __COREFOUNDATION_CFPLUGIN__ */