source: trunk/poppler/freetype-2.1.10/src/winfonts/winfnt.c @ 2

Last change on this file since 2 was 2, checked in by Eugene Romanenko, 15 years ago

First import

File size: 20.1 KB
Line 
1/***************************************************************************/
2/*                                                                         */
3/*  winfnt.c                                                               */
4/*                                                                         */
5/*    FreeType font driver for Windows FNT/FON files                       */
6/*                                                                         */
7/*  Copyright 1996-2001, 2002, 2003, 2004 by                               */
8/*  David Turner, Robert Wilhelm, and Werner Lemberg.                      */
9/*                                                                         */
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.                                        */
15/*                                                                         */
16/***************************************************************************/
17
18
19#include <ft2build.h>
20#include FT_WINFONTS_H
21#include FT_INTERNAL_DEBUG_H
22#include FT_INTERNAL_STREAM_H
23#include FT_INTERNAL_OBJECTS_H
24
25#include "winfnt.h"
26#include "fnterrs.h"
27#include FT_SERVICE_WINFNT_H
28#include FT_SERVICE_XFREE86_NAME_H
29
30  /*************************************************************************/
31  /*                                                                       */
32  /* The macro FT_COMPONENT is used in trace mode.  It is an implicit      */
33  /* parameter of the FT_TRACE() and FT_ERROR() macros, used to print/log  */
34  /* messages during execution.                                            */
35  /*                                                                       */
36#undef  FT_COMPONENT
37#define FT_COMPONENT  trace_winfnt
38
39
40  static const FT_Frame_Field  winmz_header_fields[] =
41  {
42#undef  FT_STRUCTURE
43#define FT_STRUCTURE  WinMZ_HeaderRec
44
45    FT_FRAME_START( 64 ),
46      FT_FRAME_USHORT_LE ( magic ),
47      FT_FRAME_SKIP_BYTES( 29 * 2 ),
48      FT_FRAME_ULONG_LE  ( lfanew ),
49    FT_FRAME_END
50  };
51
52  static const FT_Frame_Field  winne_header_fields[] =
53  {
54#undef  FT_STRUCTURE
55#define FT_STRUCTURE  WinNE_HeaderRec
56
57    FT_FRAME_START( 40 ),
58      FT_FRAME_USHORT_LE ( magic ),
59      FT_FRAME_SKIP_BYTES( 34 ),
60      FT_FRAME_USHORT_LE ( resource_tab_offset ),
61      FT_FRAME_USHORT_LE ( rname_tab_offset ),
62    FT_FRAME_END
63  };
64
65  static const FT_Frame_Field  winfnt_header_fields[] =
66  {
67#undef  FT_STRUCTURE
68#define FT_STRUCTURE  FT_WinFNT_HeaderRec
69
70    FT_FRAME_START( 148 ),
71      FT_FRAME_USHORT_LE( version ),
72      FT_FRAME_ULONG_LE ( file_size ),
73      FT_FRAME_BYTES    ( copyright, 60 ),
74      FT_FRAME_USHORT_LE( file_type ),
75      FT_FRAME_USHORT_LE( nominal_point_size ),
76      FT_FRAME_USHORT_LE( vertical_resolution ),
77      FT_FRAME_USHORT_LE( horizontal_resolution ),
78      FT_FRAME_USHORT_LE( ascent ),
79      FT_FRAME_USHORT_LE( internal_leading ),
80      FT_FRAME_USHORT_LE( external_leading ),
81      FT_FRAME_BYTE     ( italic ),
82      FT_FRAME_BYTE     ( underline ),
83      FT_FRAME_BYTE     ( strike_out ),
84      FT_FRAME_USHORT_LE( weight ),
85      FT_FRAME_BYTE     ( charset ),
86      FT_FRAME_USHORT_LE( pixel_width ),
87      FT_FRAME_USHORT_LE( pixel_height ),
88      FT_FRAME_BYTE     ( pitch_and_family ),
89      FT_FRAME_USHORT_LE( avg_width ),
90      FT_FRAME_USHORT_LE( max_width ),
91      FT_FRAME_BYTE     ( first_char ),
92      FT_FRAME_BYTE     ( last_char ),
93      FT_FRAME_BYTE     ( default_char ),
94      FT_FRAME_BYTE     ( break_char ),
95      FT_FRAME_USHORT_LE( bytes_per_row ),
96      FT_FRAME_ULONG_LE ( device_offset ),
97      FT_FRAME_ULONG_LE ( face_name_offset ),
98      FT_FRAME_ULONG_LE ( bits_pointer ),
99      FT_FRAME_ULONG_LE ( bits_offset ),
100      FT_FRAME_BYTE     ( reserved ),
101      FT_FRAME_ULONG_LE ( flags ),
102      FT_FRAME_USHORT_LE( A_space ),
103      FT_FRAME_USHORT_LE( B_space ),
104      FT_FRAME_USHORT_LE( C_space ),
105      FT_FRAME_ULONG_LE ( color_table_offset ),
106      FT_FRAME_BYTES    ( reserved1, 16 ),
107    FT_FRAME_END
108  };
109
110
111  static void
112  fnt_font_done( FNT_Face face )
113  {
114    FT_Memory  memory = FT_FACE( face )->memory;
115    FT_Stream  stream = FT_FACE( face )->stream;
116    FNT_Font   font   = face->font;
117
118
119    if ( !font )
120      return;
121
122    if ( font->fnt_frame )
123      FT_FRAME_RELEASE( font->fnt_frame );
124    FT_FREE( font->family_name );
125
126    FT_FREE( font );
127    face->font = 0;
128  }
129
130
131  static FT_Error
132  fnt_font_load( FNT_Font   font,
133                 FT_Stream  stream )
134  {
135    FT_Error          error;
136    FT_WinFNT_Header  header = &font->header;
137    FT_Bool           new_format;
138    FT_UInt           size;
139
140
141    /* first of all, read the FNT header */
142    if ( FT_STREAM_SEEK( font->offset )                        ||
143         FT_STREAM_READ_FIELDS( winfnt_header_fields, header ) )
144      goto Exit;
145
146    /* check header */
147    if ( header->version != 0x200 &&
148         header->version != 0x300 )
149    {
150      FT_TRACE2(( "[not a valid FNT file]\n" ));
151      error = FNT_Err_Unknown_File_Format;
152      goto Exit;
153    }
154
155    new_format = FT_BOOL( font->header.version == 0x300 );
156    size       = new_format ? 148 : 118;
157
158    if ( header->file_size < size )
159    {
160      FT_TRACE2(( "[not a valid FNT file]\n" ));
161      error = FNT_Err_Unknown_File_Format;
162      goto Exit;
163    }
164
165    /* Version 2 doesn't have these fields */
166    if ( header->version == 0x200 )
167    {
168      header->flags   = 0;
169      header->A_space = 0;
170      header->B_space = 0;
171      header->C_space = 0;
172
173      header->color_table_offset = 0;
174    }
175
176    if ( header->file_type & 1 )
177    {
178      FT_TRACE2(( "[can't handle vector FNT fonts]\n" ));
179      error = FNT_Err_Unknown_File_Format;
180      goto Exit;
181    }
182
183    /* this is a FNT file/table; extract its frame */
184    if ( FT_STREAM_SEEK( font->offset )                         ||
185         FT_FRAME_EXTRACT( header->file_size, font->fnt_frame ) )
186      goto Exit;
187
188  Exit:
189    return error;
190  }
191
192
193  static FT_Error
194  fnt_face_get_dll_font( FNT_Face  face,
195                         FT_Int    face_index )
196  {
197    FT_Error         error;
198    FT_Stream        stream = FT_FACE( face )->stream;
199    FT_Memory        memory = FT_FACE( face )->memory;
200    WinMZ_HeaderRec  mz_header;
201
202
203    face->font = 0;
204
205    /* does it begin with an MZ header? */
206    if ( FT_STREAM_SEEK( 0 )                                      ||
207         FT_STREAM_READ_FIELDS( winmz_header_fields, &mz_header ) )
208      goto Exit;
209
210    error = FNT_Err_Unknown_File_Format;
211    if ( mz_header.magic == WINFNT_MZ_MAGIC )
212    {
213      /* yes, now look for an NE header in the file */
214      WinNE_HeaderRec  ne_header;
215
216
217      if ( FT_STREAM_SEEK( mz_header.lfanew )                       ||
218           FT_STREAM_READ_FIELDS( winne_header_fields, &ne_header ) )
219        goto Exit;
220
221      error = FNT_Err_Unknown_File_Format;
222      if ( ne_header.magic == WINFNT_NE_MAGIC )
223      {
224        /* good, now look into the resource table for each FNT resource */
225        FT_ULong   res_offset  = mz_header.lfanew +
226                                   ne_header.resource_tab_offset;
227        FT_UShort  size_shift;
228        FT_UShort  font_count  = 0;
229        FT_ULong   font_offset = 0;
230
231
232        if ( FT_STREAM_SEEK( res_offset )                    ||
233             FT_FRAME_ENTER( ne_header.rname_tab_offset -
234                             ne_header.resource_tab_offset ) )
235          goto Exit;
236
237        size_shift = FT_GET_USHORT_LE();
238
239        for (;;)
240        {
241          FT_UShort  type_id, count;
242
243
244          type_id = FT_GET_USHORT_LE();
245          if ( !type_id )
246            break;
247
248          count = FT_GET_USHORT_LE();
249
250          if ( type_id == 0x8008U )
251          {
252            font_count  = count;
253            font_offset = (FT_ULong)( FT_STREAM_POS() + 4 +
254                                      ( stream->cursor - stream->limit ) );
255            break;
256          }
257
258          stream->cursor += 4 + count * 12;
259        }
260
261        FT_FRAME_EXIT();
262
263        if ( !font_count || !font_offset )
264        {
265          FT_TRACE2(( "this file doesn't contain any FNT resources!\n" ));
266          error = FNT_Err_Unknown_File_Format;
267          goto Exit;
268        }
269
270        face->root.num_faces = font_count;
271
272        if ( face_index >= font_count )
273        {
274          error = FNT_Err_Bad_Argument;
275          goto Exit;
276        }
277
278        if ( FT_NEW( face->font ) )
279          goto Exit;
280
281        if ( FT_STREAM_SEEK( font_offset + face_index * 12 ) ||
282             FT_FRAME_ENTER( 12 )                            )
283          goto Fail;
284
285        face->font->offset     = (FT_ULong)FT_GET_USHORT_LE() << size_shift;
286        face->font->fnt_size   = (FT_ULong)FT_GET_USHORT_LE() << size_shift;
287        face->font->size_shift = size_shift;
288
289        stream->cursor += 8;
290
291        FT_FRAME_EXIT();
292
293        error = fnt_font_load( face->font, stream );
294      }
295    }
296
297  Fail:
298    if ( error )
299      fnt_font_done( face );
300
301  Exit:
302    return error;
303  }
304
305
306  typedef struct  FNT_CMapRec_
307  {
308    FT_CMapRec  cmap;
309    FT_UInt32   first;
310    FT_UInt32   count;
311
312  } FNT_CMapRec, *FNT_CMap;
313
314
315  static FT_Error
316  fnt_cmap_init( FNT_CMap  cmap )
317  {
318    FNT_Face  face = (FNT_Face)FT_CMAP_FACE( cmap );
319    FNT_Font  font = face->font;
320
321
322    cmap->first = (FT_UInt32)  font->header.first_char;
323    cmap->count = (FT_UInt32)( font->header.last_char - cmap->first + 1 );
324
325    return 0;
326  }
327
328
329  static FT_UInt
330  fnt_cmap_char_index( FNT_CMap   cmap,
331                       FT_UInt32  char_code )
332  {
333    FT_UInt  gindex = 0;
334
335
336    char_code -= cmap->first;
337    if ( char_code < cmap->count )
338      gindex = char_code + 1; /* we artificially increase the glyph index; */
339                              /* FNT_Load_Glyph reverts to the right one   */
340    return gindex;
341  }
342
343
344  static FT_UInt
345  fnt_cmap_char_next( FNT_CMap    cmap,
346                      FT_UInt32  *pchar_code )
347  {
348    FT_UInt    gindex = 0;
349    FT_UInt32  result = 0;
350    FT_UInt32  char_code = *pchar_code + 1;
351
352
353    if ( char_code <= cmap->first )
354    {
355      result = cmap->first;
356      gindex = 1;
357    }
358    else
359    {
360      char_code -= cmap->first;
361      if ( char_code < cmap->count )
362      {
363        result = cmap->first + char_code;
364        gindex = char_code + 1;
365      }
366    }
367
368    *pchar_code = result;
369    return gindex;
370  }
371
372
373  static const FT_CMap_ClassRec  fnt_cmap_class_rec =
374  {
375    sizeof ( FNT_CMapRec ),
376
377    (FT_CMap_InitFunc)     fnt_cmap_init,
378    (FT_CMap_DoneFunc)     NULL,
379    (FT_CMap_CharIndexFunc)fnt_cmap_char_index,
380    (FT_CMap_CharNextFunc) fnt_cmap_char_next
381  };
382
383  static FT_CMap_Class const  fnt_cmap_class = &fnt_cmap_class_rec;
384
385
386  static void
387  FNT_Face_Done( FNT_Face  face )
388  {
389    FT_Memory  memory = FT_FACE_MEMORY( face );
390
391
392    fnt_font_done( face );
393
394    FT_FREE( face->root.available_sizes );
395    face->root.num_fixed_sizes = 0;
396  }
397
398
399  static FT_Error
400  FNT_Face_Init( FT_Stream      stream,
401                 FNT_Face       face,
402                 FT_Int         face_index,
403                 FT_Int         num_params,
404                 FT_Parameter*  params )
405  {
406    FT_Error   error;
407    FT_Memory  memory = FT_FACE_MEMORY( face );
408
409    FT_UNUSED( num_params );
410    FT_UNUSED( params );
411
412
413    /* try to load font from a DLL */
414    error = fnt_face_get_dll_font( face, face_index );
415    if ( error )
416    {
417      /* this didn't work; try to load a single FNT font */
418      FNT_Font  font;
419
420
421      if ( FT_NEW( face->font ) )
422        goto Exit;
423
424      face->root.num_faces = 1;
425
426      font           = face->font;
427      font->offset   = 0;
428      font->fnt_size = stream->size;
429
430      error = fnt_font_load( font, stream );
431      if ( error )
432        goto Fail;
433    }
434
435    /* we now need to fill the root FT_Face fields */
436    /* with relevant information                   */
437    {
438      FT_Face     root = FT_FACE( face );
439      FNT_Font    font = face->font;
440      FT_PtrDist  family_size;
441
442
443      root->face_flags = FT_FACE_FLAG_FIXED_SIZES |
444                         FT_FACE_FLAG_HORIZONTAL;
445
446      if ( font->header.avg_width == font->header.max_width )
447        root->face_flags |= FT_FACE_FLAG_FIXED_WIDTH;
448
449      if ( font->header.italic )
450        root->style_flags |= FT_STYLE_FLAG_ITALIC;
451
452      if ( font->header.weight >= 800 )
453        root->style_flags |= FT_STYLE_FLAG_BOLD;
454
455      /* set up the `fixed_sizes' array */
456      if ( FT_NEW_ARRAY( root->available_sizes, 1 ) )
457        goto Fail;
458
459      root->num_fixed_sizes = 1;
460
461      {
462        FT_Bitmap_Size*  bsize = root->available_sizes;
463
464
465        bsize->width  = font->header.avg_width;
466        bsize->height = (FT_Short)(
467          font->header.pixel_height + font->header.external_leading );
468        bsize->size   = font->header.nominal_point_size << 6;
469        bsize->x_ppem = font->header.pixel_width << 6;
470        bsize->y_ppem = font->header.pixel_height << 6;
471      }
472
473      {
474        FT_CharMapRec  charmap;
475
476
477        charmap.encoding    = FT_ENCODING_NONE;
478        charmap.platform_id = 0;
479        charmap.encoding_id = 0;
480        charmap.face        = root;
481
482        if ( font->header.charset == FT_WinFNT_ID_MAC )
483        {
484          charmap.encoding    = FT_ENCODING_APPLE_ROMAN;
485          charmap.platform_id = 1;
486/*        charmap.encoding_id = 0; */
487        }
488
489        error = FT_CMap_New( fnt_cmap_class,
490                             NULL,
491                             &charmap,
492                             NULL );
493        if ( error )
494          goto Fail;
495
496        /* Select default charmap */
497        if ( root->num_charmaps )
498          root->charmap = root->charmaps[0];
499      }
500
501      /* setup remaining flags */
502
503      /* reserve one slot for the .notdef glyph at index 0 */
504      root->num_glyphs = font->header.last_char -
505                           font->header.first_char + 1 + 1;
506
507      /* Some broken fonts don't delimit the face name with a final */
508      /* NULL byte -- the frame is erroneously one byte too small.  */
509      /* We thus allocate one more byte, setting it explicitly to   */
510      /* zero.                                                      */
511      family_size = font->header.file_size - font->header.face_name_offset;
512      if ( FT_ALLOC( font->family_name, family_size + 1 ) )
513        goto Fail;
514      FT_MEM_COPY( font->family_name,
515                   font->fnt_frame + font->header.face_name_offset,
516                   family_size );
517      font->family_name[family_size] = '\0';
518      if ( FT_REALLOC( font->family_name,
519                       family_size,
520                       ft_strlen( font->family_name ) + 1 ) )
521        goto Fail;
522      root->family_name = font->family_name;
523      root->style_name  = (char *)"Regular";
524
525      if ( root->style_flags & FT_STYLE_FLAG_BOLD )
526      {
527        if ( root->style_flags & FT_STYLE_FLAG_ITALIC )
528          root->style_name = (char *)"Bold Italic";
529        else
530          root->style_name = (char *)"Bold";
531      }
532      else if ( root->style_flags & FT_STYLE_FLAG_ITALIC )
533        root->style_name = (char *)"Italic";
534    }
535    goto Exit;
536
537  Fail:
538    FNT_Face_Done( face );
539
540  Exit:
541    return error;
542  }
543
544
545  static FT_Error
546  FNT_Size_Set_Pixels( FT_Size  size )
547  {
548    FNT_Face  face = (FNT_Face)FT_SIZE_FACE( size );
549    FT_Face   root = FT_FACE( face );
550
551
552    if ( size->metrics.y_ppem == root->available_sizes->y_ppem >> 6 )
553    {
554      FNT_Font  font = face->font;
555
556
557      size->metrics.ascender    = font->header.ascent * 64;
558      size->metrics.descender   = -( font->header.pixel_height -
559                                       font->header.ascent ) * 64;
560      size->metrics.height      = font->header.pixel_height * 64;
561      size->metrics.max_advance = font->header.max_width * 64;
562
563      return FNT_Err_Ok;
564    }
565    else
566      return FNT_Err_Invalid_Pixel_Size;
567  }
568
569
570  static FT_Error
571  FNT_Load_Glyph( FT_GlyphSlot  slot,
572                  FT_Size       size,
573                  FT_UInt       glyph_index,
574                  FT_Int32      load_flags )
575  {
576    FNT_Face    face   = (FNT_Face)FT_SIZE_FACE( size );
577    FNT_Font    font   = face->font;
578    FT_Error    error  = FNT_Err_Ok;
579    FT_Byte*    p;
580    FT_Int      len;
581    FT_Bitmap*  bitmap = &slot->bitmap;
582    FT_ULong    offset;
583    FT_Bool     new_format;
584
585    FT_UNUSED( load_flags );
586
587
588    if ( !face || !font )
589    {
590      error = FNT_Err_Invalid_Argument;
591      goto Exit;
592    }
593
594    if ( glyph_index > 0 )
595      glyph_index--;                           /* revert to real index */
596    else
597      glyph_index = font->header.default_char; /* the .notdef glyph */
598
599    new_format = FT_BOOL( font->header.version == 0x300 );
600    len        = new_format ? 6 : 4;
601
602    /* jump to glyph entry */
603    p = font->fnt_frame + ( new_format ? 148 : 118 ) + len * glyph_index;
604
605    bitmap->width = FT_NEXT_SHORT_LE( p );
606
607    if ( new_format )
608      offset = FT_NEXT_ULONG_LE( p );
609    else
610      offset = FT_NEXT_USHORT_LE( p );
611
612    if ( offset >= font->header.file_size )
613    {
614      FT_TRACE2(( "invalid FNT offset!\n" ));
615      error = FNT_Err_Invalid_File_Format;
616      goto Exit;
617    }
618
619    /* jump to glyph data */
620    p = font->fnt_frame + /* font->header.bits_offset */ + offset;
621
622    /* allocate and build bitmap */
623    {
624      FT_Memory  memory = FT_FACE_MEMORY( slot->face );
625      FT_Int     pitch  = ( bitmap->width + 7 ) >> 3;
626      FT_Byte*   column;
627      FT_Byte*   write;
628
629
630      bitmap->pitch      = pitch;
631      bitmap->rows       = font->header.pixel_height;
632      bitmap->pixel_mode = FT_PIXEL_MODE_MONO;
633
634      /* note: since glyphs are stored in columns and not in rows we */
635      /*       can't use ft_glyphslot_set_bitmap                     */
636      if ( FT_ALLOC( bitmap->buffer, pitch * bitmap->rows ) )
637        goto Exit;
638
639      column = (FT_Byte*)bitmap->buffer;
640
641      for ( ; pitch > 0; pitch--, column++ )
642      {
643        FT_Byte*  limit = p + bitmap->rows;
644
645
646        for ( write = column; p < limit; p++, write += bitmap->pitch )
647          *write = *p;
648      }
649    }
650
651    slot->internal->flags = FT_GLYPH_OWN_BITMAP;
652    slot->bitmap_left     = 0;
653    slot->bitmap_top      = font->header.ascent;
654    slot->format          = FT_GLYPH_FORMAT_BITMAP;
655
656    /* now set up metrics */
657    slot->metrics.width        = bitmap->width << 6;
658    slot->metrics.height       = bitmap->rows << 6;
659    slot->metrics.horiAdvance  = bitmap->width << 6;
660    slot->metrics.horiBearingX = 0;
661    slot->metrics.horiBearingY = slot->bitmap_top << 6;
662
663    slot->linearHoriAdvance    = (FT_Fixed)bitmap->width << 16;
664    slot->format               = FT_GLYPH_FORMAT_BITMAP;
665
666  Exit:
667    return error;
668  }
669
670
671  static FT_Error
672  winfnt_get_header( FT_Face               face,
673                     FT_WinFNT_HeaderRec  *aheader )
674  {
675    FNT_Font  font = ((FNT_Face)face)->font;
676
677
678    *aheader = font->header;
679
680    return 0;
681  }
682
683
684  static const FT_Service_WinFntRec  winfnt_service_rec =
685  {
686    winfnt_get_header
687  };
688
689 /*
690  *  SERVICE LIST
691  *
692  */
693
694  static const FT_ServiceDescRec  winfnt_services[] =
695  {
696    { FT_SERVICE_ID_XF86_NAME, FT_XF86_FORMAT_WINFNT },
697    { FT_SERVICE_ID_WINFNT,    &winfnt_service_rec },
698    { NULL, NULL }
699  };
700
701
702  static FT_Module_Interface
703  winfnt_get_service( FT_Driver         driver,
704                      const FT_String*  service_id )
705  {
706    FT_UNUSED( driver );
707
708    return ft_service_list_lookup( winfnt_services, service_id );
709  }
710
711
712
713
714  FT_CALLBACK_TABLE_DEF
715  const FT_Driver_ClassRec  winfnt_driver_class =
716  {
717    {
718      FT_MODULE_FONT_DRIVER        |
719      FT_MODULE_DRIVER_NO_OUTLINES,
720      sizeof ( FT_DriverRec ),
721
722      "winfonts",
723      0x10000L,
724      0x20000L,
725
726      0,
727
728      (FT_Module_Constructor)0,
729      (FT_Module_Destructor) 0,
730      (FT_Module_Requester)  winfnt_get_service
731    },
732
733    sizeof( FNT_FaceRec ),
734    sizeof( FT_SizeRec ),
735    sizeof( FT_GlyphSlotRec ),
736
737    (FT_Face_InitFunc)        FNT_Face_Init,
738    (FT_Face_DoneFunc)        FNT_Face_Done,
739    (FT_Size_InitFunc)        0,
740    (FT_Size_DoneFunc)        0,
741    (FT_Slot_InitFunc)        0,
742    (FT_Slot_DoneFunc)        0,
743
744    (FT_Size_ResetPointsFunc) FNT_Size_Set_Pixels,
745    (FT_Size_ResetPixelsFunc) FNT_Size_Set_Pixels,
746    (FT_Slot_LoadFunc)        FNT_Load_Glyph,
747
748    (FT_Face_GetKerningFunc)  0,
749    (FT_Face_AttachFunc)      0,
750    (FT_Face_GetAdvancesFunc) 0
751  };
752
753
754/* END */
Note: See TracBrowser for help on using the repository browser.