1
/***************************************************************************/
5
/* The FreeType services (specification only). */
7
/* Copyright 2003 by */
8
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
10
/* This file is part of the FreeType project, and may only be used, */
11
/* modified, and distributed under the terms of the FreeType project */
12
/* license, LICENSE.TXT. By continuing to use, modify, or distribute */
13
/* this file you indicate that you have read the license and */
14
/* understand and accept it fully. */
16
/***************************************************************************/
18
/*************************************************************************/
20
/* Each module can export one or more `services'. Each service is */
21
/* identified by a constant string and modeled by a pointer; the latter */
22
/* generally corresponds to a structure containing function pointers. */
24
/* Note that a service's data cannot be a mere function pointer because */
25
/* in C it is possible that function pointers might be implemented */
26
/* differently than data pointers (e.g. 48 bits instead of 32). */
28
/*************************************************************************/
40
* FT_FACE_FIND_SERVICE
43
* This macro is used to look up a service from a face's driver module.
47
* The source face handle.
50
* A string describing the service as defined in the service's
51
* header files (e.g. FT_SERVICE_ID_MULTI_MASTERS which expands to
52
* `multi-masters'). It is automatically prefixed with
57
* A variable that receives the service pointer. Will be NULL
60
#define FT_FACE_FIND_SERVICE( face, ptr, id ) \
62
FT_Module module = FT_MODULE( FT_FACE(face)->driver ); \
63
/* the strange cast is to allow C++ compilation */ \
64
FT_Pointer* Pptr = (FT_Pointer*) &(ptr); \
68
if ( module->clazz->get_interface ) \
69
*Pptr = module->clazz->get_interface( module, FT_SERVICE_ID_ ## id ); \
75
* FT_FACE_FIND_GLOBAL_SERVICE
78
* This macro is used to look up a service from all modules.
82
* The source face handle.
85
* A string describing the service as defined in the service's
86
* header files (e.g. FT_SERVICE_ID_MULTI_MASTERS which expands to
87
* `multi-masters'). It is automatically prefixed with
92
* A variable that receives the service pointer. Will be NULL
95
#define FT_FACE_FIND_GLOBAL_SERVICE( face, ptr, id ) \
97
FT_Module module = FT_MODULE( FT_FACE(face)->driver ); \
98
/* the strange cast is to allow C++ compilation */ \
99
FT_Pointer* Pptr = (FT_Pointer*) &(ptr); \
102
*Pptr = ft_module_get_service( module, FT_SERVICE_ID_ ## id ); \
106
/*************************************************************************/
107
/*************************************************************************/
109
/***** S E R V I C E D E S C R I P T O R S *****/
111
/*************************************************************************/
112
/*************************************************************************/
115
* The following structure is used to _describe_ a given service
116
* to the library. This is useful to build simple static service lists.
118
typedef struct FT_ServiceDescRec_
120
const char* serv_id; /* service name */
121
const void* serv_data; /* service pointer/data */
125
typedef const FT_ServiceDescRec* FT_ServiceDesc;
129
* Parse a list of FT_ServiceDescRec descriptors and look for
130
* a specific service by ID. Note that the last element in the
131
* array must be { NULL, NULL }, and that the function should
132
* return NULL if the service isn't available.
134
* This function can be used by modules to implement their
135
* `get_service' method.
137
FT_BASE( FT_Pointer )
138
ft_service_list_lookup( FT_ServiceDesc service_descriptors,
139
const char* service_id );
142
/*************************************************************************/
143
/*************************************************************************/
145
/***** S E R V I C E S C A C H E *****/
147
/*************************************************************************/
148
/*************************************************************************/
151
* This structure is used to store a cache for several frequently used
152
* services. It is the type of `face->internal->services'. You
153
* should only use FT_FACE_LOOKUP_SERVICE to access it.
155
* All fields should have the type FT_Pointer to relax compilation
156
* dependencies. We assume the developer isn't completely stupid.
158
* Each field must be named `service_XXXX' where `XXX' corresponds to
159
* the correct FT_SERVICE_ID_XXXX macro. See the definition of
160
* FT_FACE_LOOKUP_SERVICE below how this is implemented.
163
typedef struct FT_ServiceCacheRec_
165
FT_Pointer service_POSTSCRIPT_FONT_NAME;
166
FT_Pointer service_MULTI_MASTERS;
167
FT_Pointer service_GLYPH_DICT;
168
FT_Pointer service_PFR_METRICS;
169
FT_Pointer service_WINFNT;
171
} FT_ServiceCacheRec, *FT_ServiceCache;
175
* A magic number used within the services cache.
177
#define FT_SERVICE_UNAVAILABLE ((FT_Pointer)-2) /* magic number */
182
* FT_FACE_LOOKUP_SERVICE
185
* This macro is used to lookup a service from a face's driver module
190
* The source face handle containing the cache.
193
* The field name in the cache.
200
* A variable receiving the service data. NULL if not available.
202
#define FT_FACE_LOOKUP_SERVICE( face, ptr, id ) \
204
/* the strange cast is to allow C++ compilation */ \
205
FT_Pointer* pptr = (FT_Pointer*)&(ptr); \
209
svc = FT_FACE(face)->internal->services. service_ ## id ; \
210
if ( svc == FT_SERVICE_UNAVAILABLE ) \
212
else if ( svc == NULL ) \
214
FT_FACE_FIND_SERVICE( face, svc, id ); \
216
FT_FACE(face)->internal->services. service_ ## id = \
217
(FT_Pointer)( svc != NULL ? svc \
218
: FT_SERVICE_UNAVAILABLE ); \
225
* A macro used to define new service structure types.
228
#define FT_DEFINE_SERVICE( name ) \
229
typedef struct FT_Service_ ## name ## Rec_ \
230
FT_Service_ ## name ## Rec ; \
231
typedef struct FT_Service_ ## name ## Rec_ \
232
const * FT_Service_ ## name ; \
233
struct FT_Service_ ## name ## Rec_
238
* The header files containing the services.
241
#define FT_SERVICE_MULTIPLE_MASTERS_H <freetype/internal/services/svmm.h>
242
#define FT_SERVICE_POSTSCRIPT_NAME_H <freetype/internal/services/svpostnm.h>
243
#define FT_SERVICE_POSTSCRIPT_CMAPS_H <freetype/internal/services/svpscmap.h>
244
#define FT_SERVICE_POSTSCRIPT_INFO_H <freetype/internal/services/svpsinfo.h>
245
#define FT_SERVICE_GLYPH_DICT_H <freetype/internal/services/svgldict.h>
246
#define FT_SERVICE_BDF_H <freetype/internal/services/svbdf.h>
247
#define FT_SERVICE_XFREE86_NAME_H <freetype/internal/services/svxf86nm.h>
248
#define FT_SERVICE_SFNT_H <freetype/internal/services/svsfnt.h>
249
#define FT_SERVICE_PFR_H <freetype/internal/services/svpfr.h>
250
#define FT_SERVICE_WINFNT_H <freetype/internal/services/svwinfnt.h>
251
#define FT_SERVICE_TT_CMAP_H <freetype/internal/services/svttcmap.h>
257
#endif /* __FTSERV_H__ */