]> git.saurik.com Git - apple/cf.git/blame - PlugIn.subproj/CFPlugIn.h
CF-368.11.tar.gz
[apple/cf.git] / PlugIn.subproj / CFPlugIn.h
CommitLineData
9ce05555 1/*
d8925383 2 * Copyright (c) 2005 Apple Computer, Inc. All rights reserved.
9ce05555
A
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
9ce05555
A
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
11 * file.
12 *
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.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23/* CFPlugIn.h
d8925383 24 Copyright (c) 1999-2005, Apple, Inc. All rights reserved.
9ce05555
A
25*/
26
27#if !defined(__COREFOUNDATION_CFPLUGIN__)
28#define __COREFOUNDATION_CFPLUGIN__ 1
29
30#if !defined(COREFOUNDATION_CFPLUGINCOM_SEPARATE)
31#define COREFOUNDATION_CFPLUGINCOM_SEPARATE 1
32#endif
33
34#include <CoreFoundation/CFBase.h>
35#include <CoreFoundation/CFArray.h>
36#include <CoreFoundation/CFBundle.h>
37#include <CoreFoundation/CFString.h>
38#include <CoreFoundation/CFURL.h>
39#include <CoreFoundation/CFUUID.h>
40
41#if defined(__cplusplus)
42extern "C" {
43#endif
44
45/* ================ Standard Info.plist keys for plugIns ================ */
46
47CF_EXPORT
48const CFStringRef kCFPlugInDynamicRegistrationKey;
49CF_EXPORT
50const CFStringRef kCFPlugInDynamicRegisterFunctionKey;
51CF_EXPORT
52const CFStringRef kCFPlugInUnloadFunctionKey;
53CF_EXPORT
54const CFStringRef kCFPlugInFactoriesKey;
55CF_EXPORT
56const CFStringRef kCFPlugInTypesKey;
57
58/* ================= Function prototypes for various callbacks ================= */
59/* Function types that plugIn authors can implement for various purposes. */
60
61typedef void (*CFPlugInDynamicRegisterFunction)(CFPlugInRef plugIn);
62typedef void (*CFPlugInUnloadFunction)(CFPlugInRef plugIn);
63typedef void *(*CFPlugInFactoryFunction)(CFAllocatorRef allocator, CFUUIDRef typeUUID);
64
65/* ================= Creating PlugIns ================= */
66
67CF_EXPORT
68UInt32 CFPlugInGetTypeID(void);
69
70CF_EXPORT
71CFPlugInRef CFPlugInCreate(CFAllocatorRef allocator, CFURLRef plugInURL);
72 /* Might return an existing instance with the ref-count bumped. */
73
74CF_EXPORT
75CFBundleRef CFPlugInGetBundle(CFPlugInRef plugIn);
76
77/* ================= Controlling load on demand ================= */
78/* For plugIns. */
79/* PlugIns that do static registration are load on demand by default. */
80/* PlugIns that do dynamic registration are not load on demand by default. */
81/* A dynamic registration function can call CFPlugInSetLoadOnDemand(). */
82
83CF_EXPORT
84void CFPlugInSetLoadOnDemand(CFPlugInRef plugIn, Boolean flag);
85
86CF_EXPORT
87Boolean CFPlugInIsLoadOnDemand(CFPlugInRef plugIn);
88
89/* ================= Finding factories and creating instances ================= */
90/* For plugIn hosts. */
91/* Functions for finding factories to create specific types and actually creating instances of a type. */
92
93CF_EXPORT
94CFArrayRef CFPlugInFindFactoriesForPlugInType(CFUUIDRef typeUUID);
95 /* This function finds all the factories from any plugin for the given type. Returns an array that the caller must release. */
96
97CF_EXPORT
98CFArrayRef CFPlugInFindFactoriesForPlugInTypeInPlugIn(CFUUIDRef typeUUID, CFPlugInRef plugIn);
99 /* 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. */
100
101CF_EXPORT
102void *CFPlugInInstanceCreate(CFAllocatorRef allocator, CFUUIDRef factoryUUID, CFUUIDRef typeUUID);
103 /* This function returns the IUnknown interface for the new instance. */
104
105/* ================= Registering factories and types ================= */
106/* For plugIn writers who must dynamically register things. */
107/* Functions to register factory functions and to associate factories with types. */
108
109CF_EXPORT
110Boolean CFPlugInRegisterFactoryFunction(CFUUIDRef factoryUUID, CFPlugInFactoryFunction func);
111
112CF_EXPORT
113Boolean CFPlugInRegisterFactoryFunctionByName(CFUUIDRef factoryUUID, CFPlugInRef plugIn, CFStringRef functionName);
114
115CF_EXPORT
116Boolean CFPlugInUnregisterFactory(CFUUIDRef factoryUUID);
117
118CF_EXPORT
119Boolean CFPlugInRegisterPlugInType(CFUUIDRef factoryUUID, CFUUIDRef typeUUID);
120
121CF_EXPORT
122Boolean CFPlugInUnregisterPlugInType(CFUUIDRef factoryUUID, CFUUIDRef typeUUID);
123
124/* ================= Registering instances ================= */
125/* 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. */
126/* 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. */
127
128CF_EXPORT
129void CFPlugInAddInstanceForFactory(CFUUIDRef factoryID);
130
131CF_EXPORT
132void CFPlugInRemoveInstanceForFactory(CFUUIDRef factoryID);
133
134
135/* Obsolete API */
136
137typedef struct __CFPlugInInstance *CFPlugInInstanceRef;
138
139typedef Boolean (*CFPlugInInstanceGetInterfaceFunction)(CFPlugInInstanceRef instance, CFStringRef interfaceName, void **ftbl);
140typedef void (*CFPlugInInstanceDeallocateInstanceDataFunction)(void *instanceData);
141
142CF_EXPORT
143Boolean CFPlugInInstanceGetInterfaceFunctionTable(CFPlugInInstanceRef instance, CFStringRef interfaceName, void **ftbl);
144CF_EXPORT
145CFStringRef CFPlugInInstanceGetFactoryName(CFPlugInInstanceRef instance);
146CF_EXPORT
147void *CFPlugInInstanceGetInstanceData(CFPlugInInstanceRef instance);
148CF_EXPORT
149UInt32 CFPlugInInstanceGetTypeID(void);
150CF_EXPORT
151CFPlugInInstanceRef CFPlugInInstanceCreateWithInstanceDataSize(CFAllocatorRef allocator, CFIndex instanceDataSize, CFPlugInInstanceDeallocateInstanceDataFunction deallocateInstanceFunction, CFStringRef factoryName, CFPlugInInstanceGetInterfaceFunction getInterfaceFunction);
152
153#if defined(__cplusplus)
154}
155#endif
156
157#if !COREFOUNDATION_CFPLUGINCOM_SEPARATE
158#include <CoreFoundation/CFPlugInCOM.h>
159#endif
160
161#endif /* ! __COREFOUNDATION_CFPLUGIN__ */
162