rev |
line source |
nuclear@0
|
1 /***************************************************************************/
|
nuclear@0
|
2 /* */
|
nuclear@0
|
3 /* ftdriver.h */
|
nuclear@0
|
4 /* */
|
nuclear@0
|
5 /* FreeType font driver interface (specification). */
|
nuclear@0
|
6 /* */
|
nuclear@0
|
7 /* Copyright 1996-2001, 2002, 2003, 2006, 2008 by */
|
nuclear@0
|
8 /* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
nuclear@0
|
9 /* */
|
nuclear@0
|
10 /* This file is part of the FreeType project, and may only be used, */
|
nuclear@0
|
11 /* modified, and distributed under the terms of the FreeType project */
|
nuclear@0
|
12 /* license, LICENSE.TXT. By continuing to use, modify, or distribute */
|
nuclear@0
|
13 /* this file you indicate that you have read the license and */
|
nuclear@0
|
14 /* understand and accept it fully. */
|
nuclear@0
|
15 /* */
|
nuclear@0
|
16 /***************************************************************************/
|
nuclear@0
|
17
|
nuclear@0
|
18
|
nuclear@0
|
19 #ifndef __FTDRIVER_H__
|
nuclear@0
|
20 #define __FTDRIVER_H__
|
nuclear@0
|
21
|
nuclear@0
|
22
|
nuclear@0
|
23 #include <ft2build.h>
|
nuclear@0
|
24 #include FT_MODULE_H
|
nuclear@0
|
25
|
nuclear@0
|
26
|
nuclear@0
|
27 FT_BEGIN_HEADER
|
nuclear@0
|
28
|
nuclear@0
|
29
|
nuclear@0
|
30 typedef FT_Error
|
nuclear@0
|
31 (*FT_Face_InitFunc)( FT_Stream stream,
|
nuclear@0
|
32 FT_Face face,
|
nuclear@0
|
33 FT_Int typeface_index,
|
nuclear@0
|
34 FT_Int num_params,
|
nuclear@0
|
35 FT_Parameter* parameters );
|
nuclear@0
|
36
|
nuclear@0
|
37 typedef void
|
nuclear@0
|
38 (*FT_Face_DoneFunc)( FT_Face face );
|
nuclear@0
|
39
|
nuclear@0
|
40
|
nuclear@0
|
41 typedef FT_Error
|
nuclear@0
|
42 (*FT_Size_InitFunc)( FT_Size size );
|
nuclear@0
|
43
|
nuclear@0
|
44 typedef void
|
nuclear@0
|
45 (*FT_Size_DoneFunc)( FT_Size size );
|
nuclear@0
|
46
|
nuclear@0
|
47
|
nuclear@0
|
48 typedef FT_Error
|
nuclear@0
|
49 (*FT_Slot_InitFunc)( FT_GlyphSlot slot );
|
nuclear@0
|
50
|
nuclear@0
|
51 typedef void
|
nuclear@0
|
52 (*FT_Slot_DoneFunc)( FT_GlyphSlot slot );
|
nuclear@0
|
53
|
nuclear@0
|
54
|
nuclear@0
|
55 typedef FT_Error
|
nuclear@0
|
56 (*FT_Size_RequestFunc)( FT_Size size,
|
nuclear@0
|
57 FT_Size_Request req );
|
nuclear@0
|
58
|
nuclear@0
|
59 typedef FT_Error
|
nuclear@0
|
60 (*FT_Size_SelectFunc)( FT_Size size,
|
nuclear@0
|
61 FT_ULong size_index );
|
nuclear@0
|
62
|
nuclear@0
|
63 #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
|
nuclear@0
|
64
|
nuclear@0
|
65 typedef FT_Error
|
nuclear@0
|
66 (*FT_Size_ResetPointsFunc)( FT_Size size,
|
nuclear@0
|
67 FT_F26Dot6 char_width,
|
nuclear@0
|
68 FT_F26Dot6 char_height,
|
nuclear@0
|
69 FT_UInt horz_resolution,
|
nuclear@0
|
70 FT_UInt vert_resolution );
|
nuclear@0
|
71
|
nuclear@0
|
72 typedef FT_Error
|
nuclear@0
|
73 (*FT_Size_ResetPixelsFunc)( FT_Size size,
|
nuclear@0
|
74 FT_UInt pixel_width,
|
nuclear@0
|
75 FT_UInt pixel_height );
|
nuclear@0
|
76
|
nuclear@0
|
77 #endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
|
nuclear@0
|
78
|
nuclear@0
|
79 typedef FT_Error
|
nuclear@0
|
80 (*FT_Slot_LoadFunc)( FT_GlyphSlot slot,
|
nuclear@0
|
81 FT_Size size,
|
nuclear@0
|
82 FT_UInt glyph_index,
|
nuclear@0
|
83 FT_Int32 load_flags );
|
nuclear@0
|
84
|
nuclear@0
|
85
|
nuclear@0
|
86 typedef FT_UInt
|
nuclear@0
|
87 (*FT_CharMap_CharIndexFunc)( FT_CharMap charmap,
|
nuclear@0
|
88 FT_Long charcode );
|
nuclear@0
|
89
|
nuclear@0
|
90 typedef FT_Long
|
nuclear@0
|
91 (*FT_CharMap_CharNextFunc)( FT_CharMap charmap,
|
nuclear@0
|
92 FT_Long charcode );
|
nuclear@0
|
93
|
nuclear@0
|
94
|
nuclear@0
|
95 typedef FT_Error
|
nuclear@0
|
96 (*FT_Face_GetKerningFunc)( FT_Face face,
|
nuclear@0
|
97 FT_UInt left_glyph,
|
nuclear@0
|
98 FT_UInt right_glyph,
|
nuclear@0
|
99 FT_Vector* kerning );
|
nuclear@0
|
100
|
nuclear@0
|
101
|
nuclear@0
|
102 typedef FT_Error
|
nuclear@0
|
103 (*FT_Face_AttachFunc)( FT_Face face,
|
nuclear@0
|
104 FT_Stream stream );
|
nuclear@0
|
105
|
nuclear@0
|
106
|
nuclear@0
|
107 typedef FT_Error
|
nuclear@0
|
108 (*FT_Face_GetAdvancesFunc)( FT_Face face,
|
nuclear@0
|
109 FT_UInt first,
|
nuclear@0
|
110 FT_UInt count,
|
nuclear@0
|
111 FT_Int32 flags,
|
nuclear@0
|
112 FT_Fixed* advances );
|
nuclear@0
|
113
|
nuclear@0
|
114
|
nuclear@0
|
115 /*************************************************************************/
|
nuclear@0
|
116 /* */
|
nuclear@0
|
117 /* <Struct> */
|
nuclear@0
|
118 /* FT_Driver_ClassRec */
|
nuclear@0
|
119 /* */
|
nuclear@0
|
120 /* <Description> */
|
nuclear@0
|
121 /* The font driver class. This structure mostly contains pointers to */
|
nuclear@0
|
122 /* driver methods. */
|
nuclear@0
|
123 /* */
|
nuclear@0
|
124 /* <Fields> */
|
nuclear@0
|
125 /* root :: The parent module. */
|
nuclear@0
|
126 /* */
|
nuclear@0
|
127 /* face_object_size :: The size of a face object in bytes. */
|
nuclear@0
|
128 /* */
|
nuclear@0
|
129 /* size_object_size :: The size of a size object in bytes. */
|
nuclear@0
|
130 /* */
|
nuclear@0
|
131 /* slot_object_size :: The size of a glyph object in bytes. */
|
nuclear@0
|
132 /* */
|
nuclear@0
|
133 /* init_face :: The format-specific face constructor. */
|
nuclear@0
|
134 /* */
|
nuclear@0
|
135 /* done_face :: The format-specific face destructor. */
|
nuclear@0
|
136 /* */
|
nuclear@0
|
137 /* init_size :: The format-specific size constructor. */
|
nuclear@0
|
138 /* */
|
nuclear@0
|
139 /* done_size :: The format-specific size destructor. */
|
nuclear@0
|
140 /* */
|
nuclear@0
|
141 /* init_slot :: The format-specific slot constructor. */
|
nuclear@0
|
142 /* */
|
nuclear@0
|
143 /* done_slot :: The format-specific slot destructor. */
|
nuclear@0
|
144 /* */
|
nuclear@0
|
145 /* */
|
nuclear@0
|
146 /* load_glyph :: A function handle to load a glyph to a slot. */
|
nuclear@0
|
147 /* This field is mandatory! */
|
nuclear@0
|
148 /* */
|
nuclear@0
|
149 /* get_kerning :: A function handle to return the unscaled */
|
nuclear@0
|
150 /* kerning for a given pair of glyphs. Can be */
|
nuclear@0
|
151 /* set to 0 if the format doesn't support */
|
nuclear@0
|
152 /* kerning. */
|
nuclear@0
|
153 /* */
|
nuclear@0
|
154 /* attach_file :: This function handle is used to read */
|
nuclear@0
|
155 /* additional data for a face from another */
|
nuclear@0
|
156 /* file/stream. For example, this can be used to */
|
nuclear@0
|
157 /* add data from AFM or PFM files on a Type 1 */
|
nuclear@0
|
158 /* face, or a CIDMap on a CID-keyed face. */
|
nuclear@0
|
159 /* */
|
nuclear@0
|
160 /* get_advances :: A function handle used to return advance */
|
nuclear@0
|
161 /* widths of `count' glyphs (in font units), */
|
nuclear@0
|
162 /* starting at `first'. The `vertical' flag must */
|
nuclear@0
|
163 /* be set to get vertical advance heights. The */
|
nuclear@0
|
164 /* `advances' buffer is caller-allocated. */
|
nuclear@0
|
165 /* Currently not implemented. The idea of this */
|
nuclear@0
|
166 /* function is to be able to perform */
|
nuclear@0
|
167 /* device-independent text layout without loading */
|
nuclear@0
|
168 /* a single glyph image. */
|
nuclear@0
|
169 /* */
|
nuclear@0
|
170 /* request_size :: A handle to a function used to request the new */
|
nuclear@0
|
171 /* character size. Can be set to 0 if the */
|
nuclear@0
|
172 /* scaling done in the base layer suffices. */
|
nuclear@0
|
173 /* */
|
nuclear@0
|
174 /* select_size :: A handle to a function used to select a new */
|
nuclear@0
|
175 /* fixed size. It is used only if */
|
nuclear@0
|
176 /* @FT_FACE_FLAG_FIXED_SIZES is set. Can be set */
|
nuclear@0
|
177 /* to 0 if the scaling done in the base layer */
|
nuclear@0
|
178 /* suffices. */
|
nuclear@0
|
179 /* <Note> */
|
nuclear@0
|
180 /* Most function pointers, with the exception of `load_glyph', can be */
|
nuclear@0
|
181 /* set to 0 to indicate a default behaviour. */
|
nuclear@0
|
182 /* */
|
nuclear@0
|
183 typedef struct FT_Driver_ClassRec_
|
nuclear@0
|
184 {
|
nuclear@0
|
185 FT_Module_Class root;
|
nuclear@0
|
186
|
nuclear@0
|
187 FT_Long face_object_size;
|
nuclear@0
|
188 FT_Long size_object_size;
|
nuclear@0
|
189 FT_Long slot_object_size;
|
nuclear@0
|
190
|
nuclear@0
|
191 FT_Face_InitFunc init_face;
|
nuclear@0
|
192 FT_Face_DoneFunc done_face;
|
nuclear@0
|
193
|
nuclear@0
|
194 FT_Size_InitFunc init_size;
|
nuclear@0
|
195 FT_Size_DoneFunc done_size;
|
nuclear@0
|
196
|
nuclear@0
|
197 FT_Slot_InitFunc init_slot;
|
nuclear@0
|
198 FT_Slot_DoneFunc done_slot;
|
nuclear@0
|
199
|
nuclear@0
|
200 #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
|
nuclear@0
|
201
|
nuclear@0
|
202 FT_Size_ResetPointsFunc set_char_sizes;
|
nuclear@0
|
203 FT_Size_ResetPixelsFunc set_pixel_sizes;
|
nuclear@0
|
204
|
nuclear@0
|
205 #endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
|
nuclear@0
|
206
|
nuclear@0
|
207 FT_Slot_LoadFunc load_glyph;
|
nuclear@0
|
208
|
nuclear@0
|
209 FT_Face_GetKerningFunc get_kerning;
|
nuclear@0
|
210 FT_Face_AttachFunc attach_file;
|
nuclear@0
|
211 FT_Face_GetAdvancesFunc get_advances;
|
nuclear@0
|
212
|
nuclear@0
|
213 /* since version 2.2 */
|
nuclear@0
|
214 FT_Size_RequestFunc request_size;
|
nuclear@0
|
215 FT_Size_SelectFunc select_size;
|
nuclear@0
|
216
|
nuclear@0
|
217 } FT_Driver_ClassRec, *FT_Driver_Class;
|
nuclear@0
|
218
|
nuclear@0
|
219
|
nuclear@0
|
220 /*
|
nuclear@0
|
221 * The following functions are used as stubs for `set_char_sizes' and
|
nuclear@0
|
222 * `set_pixel_sizes'; the code uses `request_size' and `select_size'
|
nuclear@0
|
223 * functions instead.
|
nuclear@0
|
224 *
|
nuclear@0
|
225 * Implementation is in `src/base/ftobjs.c'.
|
nuclear@0
|
226 */
|
nuclear@0
|
227 #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
|
nuclear@0
|
228
|
nuclear@0
|
229 FT_BASE( FT_Error )
|
nuclear@0
|
230 ft_stub_set_char_sizes( FT_Size size,
|
nuclear@0
|
231 FT_F26Dot6 width,
|
nuclear@0
|
232 FT_F26Dot6 height,
|
nuclear@0
|
233 FT_UInt horz_res,
|
nuclear@0
|
234 FT_UInt vert_res );
|
nuclear@0
|
235
|
nuclear@0
|
236 FT_BASE( FT_Error )
|
nuclear@0
|
237 ft_stub_set_pixel_sizes( FT_Size size,
|
nuclear@0
|
238 FT_UInt width,
|
nuclear@0
|
239 FT_UInt height );
|
nuclear@0
|
240
|
nuclear@0
|
241 #endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
|
nuclear@0
|
242
|
nuclear@0
|
243 /*************************************************************************/
|
nuclear@0
|
244 /* */
|
nuclear@0
|
245 /* <Macro> */
|
nuclear@0
|
246 /* FT_DECLARE_DRIVER */
|
nuclear@0
|
247 /* */
|
nuclear@0
|
248 /* <Description> */
|
nuclear@0
|
249 /* Used to create a forward declaration of a */
|
nuclear@0
|
250 /* FT_Driver_ClassRec stract instance. */
|
nuclear@0
|
251 /* */
|
nuclear@0
|
252 /* <Macro> */
|
nuclear@0
|
253 /* FT_DEFINE_DRIVER */
|
nuclear@0
|
254 /* */
|
nuclear@0
|
255 /* <Description> */
|
nuclear@0
|
256 /* Used to initialize an instance of FT_Driver_ClassRec struct. */
|
nuclear@0
|
257 /* */
|
nuclear@0
|
258 /* When FT_CONFIG_OPTION_PIC is defined a Create funtion will need */
|
nuclear@0
|
259 /* to called with a pointer where the allocated stracture is returned.*/
|
nuclear@0
|
260 /* And when it is no longer needed a Destroy function needs */
|
nuclear@0
|
261 /* to be called to release that allocation. */
|
nuclear@0
|
262 /* fcinit.c (ft_create_default_module_classes) already contains */
|
nuclear@0
|
263 /* a mechanism to call these functions for the default modules */
|
nuclear@0
|
264 /* described in ftmodule.h */
|
nuclear@0
|
265 /* */
|
nuclear@0
|
266 /* Notice that the created Create and Destroy functions call */
|
nuclear@0
|
267 /* pic_init and pic_free function to allow you to manually allocate */
|
nuclear@0
|
268 /* and initialize any additional global data, like module specific */
|
nuclear@0
|
269 /* interface, and put them in the global pic container defined in */
|
nuclear@0
|
270 /* ftpic.h. if you don't need them just implement the functions as */
|
nuclear@0
|
271 /* empty to resolve the link error. */
|
nuclear@0
|
272 /* */
|
nuclear@0
|
273 /* When FT_CONFIG_OPTION_PIC is not defined the struct will be */
|
nuclear@0
|
274 /* allocated in the global scope (or the scope where the macro */
|
nuclear@0
|
275 /* is used). */
|
nuclear@0
|
276 /* */
|
nuclear@0
|
277 #ifndef FT_CONFIG_OPTION_PIC
|
nuclear@0
|
278
|
nuclear@0
|
279 #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
|
nuclear@0
|
280 #define FT_DEFINE_DRIVERS_OLD_INTERNALS(a_,b_) \
|
nuclear@0
|
281 a_, b_,
|
nuclear@0
|
282 #else
|
nuclear@0
|
283 #define FT_DEFINE_DRIVERS_OLD_INTERNALS(a_,b_)
|
nuclear@0
|
284 #endif
|
nuclear@0
|
285
|
nuclear@0
|
286 #define FT_DECLARE_DRIVER(class_) \
|
nuclear@0
|
287 FT_CALLBACK_TABLE \
|
nuclear@0
|
288 const FT_Driver_ClassRec class_;
|
nuclear@0
|
289
|
nuclear@0
|
290 #define FT_DEFINE_DRIVER(class_, \
|
nuclear@0
|
291 flags_, size_, name_, version_, requires_, \
|
nuclear@0
|
292 interface_, init_, done_, get_interface_, \
|
nuclear@0
|
293 face_object_size_, size_object_size_, \
|
nuclear@0
|
294 slot_object_size_, init_face_, done_face_, \
|
nuclear@0
|
295 init_size_, done_size_, init_slot_, done_slot_, \
|
nuclear@0
|
296 old_set_char_sizes_, old_set_pixel_sizes_, \
|
nuclear@0
|
297 load_glyph_, get_kerning_, attach_file_, \
|
nuclear@0
|
298 get_advances_, request_size_, select_size_ ) \
|
nuclear@0
|
299 FT_CALLBACK_TABLE_DEF \
|
nuclear@0
|
300 const FT_Driver_ClassRec class_ = \
|
nuclear@0
|
301 { \
|
nuclear@0
|
302 FT_DEFINE_ROOT_MODULE(flags_,size_,name_,version_,requires_,interface_, \
|
nuclear@0
|
303 init_,done_,get_interface_) \
|
nuclear@0
|
304 \
|
nuclear@0
|
305 face_object_size_, \
|
nuclear@0
|
306 size_object_size_, \
|
nuclear@0
|
307 slot_object_size_, \
|
nuclear@0
|
308 \
|
nuclear@0
|
309 init_face_, \
|
nuclear@0
|
310 done_face_, \
|
nuclear@0
|
311 \
|
nuclear@0
|
312 init_size_, \
|
nuclear@0
|
313 done_size_, \
|
nuclear@0
|
314 \
|
nuclear@0
|
315 init_slot_, \
|
nuclear@0
|
316 done_slot_, \
|
nuclear@0
|
317 \
|
nuclear@0
|
318 FT_DEFINE_DRIVERS_OLD_INTERNALS(old_set_char_sizes_, old_set_pixel_sizes_) \
|
nuclear@0
|
319 \
|
nuclear@0
|
320 load_glyph_, \
|
nuclear@0
|
321 \
|
nuclear@0
|
322 get_kerning_, \
|
nuclear@0
|
323 attach_file_, \
|
nuclear@0
|
324 get_advances_, \
|
nuclear@0
|
325 \
|
nuclear@0
|
326 request_size_, \
|
nuclear@0
|
327 select_size_ \
|
nuclear@0
|
328 };
|
nuclear@0
|
329
|
nuclear@0
|
330 #else /* FT_CONFIG_OPTION_PIC */
|
nuclear@0
|
331
|
nuclear@0
|
332 #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
|
nuclear@0
|
333 #define FT_DEFINE_DRIVERS_OLD_INTERNALS(a_,b_) \
|
nuclear@0
|
334 clazz->set_char_sizes = a_; \
|
nuclear@0
|
335 clazz->set_pixel_sizes = b_;
|
nuclear@0
|
336 #else
|
nuclear@0
|
337 #define FT_DEFINE_DRIVERS_OLD_INTERNALS(a_,b_)
|
nuclear@0
|
338 #endif
|
nuclear@0
|
339
|
nuclear@0
|
340 #define FT_DECLARE_DRIVER(class_) FT_DECLARE_MODULE(class_)
|
nuclear@0
|
341
|
nuclear@0
|
342 #define FT_DEFINE_DRIVER(class_, \
|
nuclear@0
|
343 flags_, size_, name_, version_, requires_, \
|
nuclear@0
|
344 interface_, init_, done_, get_interface_, \
|
nuclear@0
|
345 face_object_size_, size_object_size_, \
|
nuclear@0
|
346 slot_object_size_, init_face_, done_face_, \
|
nuclear@0
|
347 init_size_, done_size_, init_slot_, done_slot_, \
|
nuclear@0
|
348 old_set_char_sizes_, old_set_pixel_sizes_, \
|
nuclear@0
|
349 load_glyph_, get_kerning_, attach_file_, \
|
nuclear@0
|
350 get_advances_, request_size_, select_size_ ) \
|
nuclear@0
|
351 void class_##_pic_free( FT_Library library ); \
|
nuclear@0
|
352 FT_Error class_##_pic_init( FT_Library library ); \
|
nuclear@0
|
353 \
|
nuclear@0
|
354 void \
|
nuclear@0
|
355 FT_Destroy_Class_##class_( FT_Library library, \
|
nuclear@0
|
356 FT_Module_Class* clazz ) \
|
nuclear@0
|
357 { \
|
nuclear@0
|
358 FT_Memory memory = library->memory; \
|
nuclear@0
|
359 FT_Driver_Class dclazz = (FT_Driver_Class)clazz; \
|
nuclear@0
|
360 class_##_pic_free( library ); \
|
nuclear@0
|
361 if ( dclazz ) \
|
nuclear@0
|
362 FT_FREE( dclazz ); \
|
nuclear@0
|
363 } \
|
nuclear@0
|
364 \
|
nuclear@0
|
365 FT_Error \
|
nuclear@0
|
366 FT_Create_Class_##class_( FT_Library library, \
|
nuclear@0
|
367 FT_Module_Class** output_class ) \
|
nuclear@0
|
368 { \
|
nuclear@0
|
369 FT_Driver_Class clazz; \
|
nuclear@0
|
370 FT_Error error; \
|
nuclear@0
|
371 FT_Memory memory = library->memory; \
|
nuclear@0
|
372 \
|
nuclear@0
|
373 if ( FT_ALLOC( clazz, sizeof(*clazz) ) ) \
|
nuclear@0
|
374 return error; \
|
nuclear@0
|
375 \
|
nuclear@0
|
376 error = class_##_pic_init( library ); \
|
nuclear@0
|
377 if(error) \
|
nuclear@0
|
378 { \
|
nuclear@0
|
379 FT_FREE( clazz ); \
|
nuclear@0
|
380 return error; \
|
nuclear@0
|
381 } \
|
nuclear@0
|
382 \
|
nuclear@0
|
383 FT_DEFINE_ROOT_MODULE(flags_,size_,name_,version_,requires_,interface_, \
|
nuclear@0
|
384 init_,done_,get_interface_) \
|
nuclear@0
|
385 \
|
nuclear@0
|
386 clazz->face_object_size = face_object_size_; \
|
nuclear@0
|
387 clazz->size_object_size = size_object_size_; \
|
nuclear@0
|
388 clazz->slot_object_size = slot_object_size_; \
|
nuclear@0
|
389 \
|
nuclear@0
|
390 clazz->init_face = init_face_; \
|
nuclear@0
|
391 clazz->done_face = done_face_; \
|
nuclear@0
|
392 \
|
nuclear@0
|
393 clazz->init_size = init_size_; \
|
nuclear@0
|
394 clazz->done_size = done_size_; \
|
nuclear@0
|
395 \
|
nuclear@0
|
396 clazz->init_slot = init_slot_; \
|
nuclear@0
|
397 clazz->done_slot = done_slot_; \
|
nuclear@0
|
398 \
|
nuclear@0
|
399 FT_DEFINE_DRIVERS_OLD_INTERNALS(old_set_char_sizes_, old_set_pixel_sizes_) \
|
nuclear@0
|
400 \
|
nuclear@0
|
401 clazz->load_glyph = load_glyph_; \
|
nuclear@0
|
402 \
|
nuclear@0
|
403 clazz->get_kerning = get_kerning_; \
|
nuclear@0
|
404 clazz->attach_file = attach_file_; \
|
nuclear@0
|
405 clazz->get_advances = get_advances_; \
|
nuclear@0
|
406 \
|
nuclear@0
|
407 clazz->request_size = request_size_; \
|
nuclear@0
|
408 clazz->select_size = select_size_; \
|
nuclear@0
|
409 \
|
nuclear@0
|
410 *output_class = (FT_Module_Class*)clazz; \
|
nuclear@0
|
411 return FT_Err_Ok; \
|
nuclear@0
|
412 }
|
nuclear@0
|
413
|
nuclear@0
|
414
|
nuclear@0
|
415 #endif /* FT_CONFIG_OPTION_PIC */
|
nuclear@0
|
416
|
nuclear@0
|
417 FT_END_HEADER
|
nuclear@0
|
418
|
nuclear@0
|
419 #endif /* __FTDRIVER_H__ */
|
nuclear@0
|
420
|
nuclear@0
|
421
|
nuclear@0
|
422 /* END */
|