fontservices/freetypefontrasteriser/freetype2/include/freetype/internal/ftobjs.h
author hgs
Wed, 27 Oct 2010 16:14:22 +0800
changeset 71 6cc5529d4a89
permissions -rw-r--r--
201033_10
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
71
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     1
/***************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     2
/*                                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     3
/*  ftobjs.h                                                               */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     4
/*                                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     5
/*    The FreeType private base classes (specification).                   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     6
/*                                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     7
/*  Copyright 1996-2001, 2002, 2003, 2004, 2005, 2006 by                   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     8
/*  David Turner, Robert Wilhelm, and Werner Lemberg.                      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
     9
/*                                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    10
/*  This file is part of the FreeType project, and may only be used,       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    11
/*  modified, and distributed under the terms of the FreeType project      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    12
/*  license, FTL.TXT.  By continuing to use, modify, or distribute     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    13
/*  this file you indicate that you have read the license and              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    14
/*  understand and accept it fully.                                        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    15
/*                                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    16
/***************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    17
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    18
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    19
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    20
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    21
  /*  This file contains the definition of all internal FreeType classes.  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    22
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    23
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    24
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    25
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    26
#ifndef __FTOBJS_H__
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    27
#define __FTOBJS_H__
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    28
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    29
#include <ft2build.h>
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    30
#include FT_RENDER_H
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    31
#include FT_SIZES_H
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    32
#include FT_INTERNAL_MEMORY_H
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    33
#include FT_INTERNAL_GLYPH_LOADER_H
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    34
#include FT_INTERNAL_DRIVER_H
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    35
#include FT_INTERNAL_AUTOHINT_H
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    36
#include FT_INTERNAL_SERVICE_H
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    37
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    38
#ifdef FT_CONFIG_OPTION_INCREMENTAL
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    39
#include FT_INCREMENTAL_H
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    40
#endif
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    41
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    42
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    43
FT_BEGIN_HEADER
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    44
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    45
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    46
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    47
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    48
  /* Some generic definitions.                                             */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    49
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    50
#ifndef TRUE
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    51
#define TRUE  1
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    52
#endif
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    53
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    54
#ifndef FALSE
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    55
#define FALSE  0
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    56
#endif
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    57
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    58
#ifndef NULL
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    59
#define NULL  (void*)0
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    60
#endif
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    61
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    62
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    63
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    64
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    65
  /* The min and max functions missing in C.  As usual, be careful not to  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    66
  /* write things like FT_MIN( a++, b++ ) to avoid side effects.           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    67
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    68
#define FT_MIN( a, b )  ( (a) < (b) ? (a) : (b) )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    69
#define FT_MAX( a, b )  ( (a) > (b) ? (a) : (b) )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    70
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    71
#define FT_ABS( a )     ( (a) < 0 ? -(a) : (a) )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    72
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    73
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    74
#define FT_PAD_FLOOR( x, n )  ( (x) & ~((n)-1) )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    75
#define FT_PAD_ROUND( x, n )  FT_PAD_FLOOR( (x) + ((n)/2), n )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    76
#define FT_PAD_CEIL( x, n )   FT_PAD_FLOOR( (x) + ((n)-1), n )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    77
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    78
#define FT_PIX_FLOOR( x )     ( (x) & ~63 )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    79
#define FT_PIX_ROUND( x )     FT_PIX_FLOOR( (x) + 32 )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    80
#define FT_PIX_CEIL( x )      FT_PIX_FLOOR( (x) + 63 )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    81
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    82
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    83
  /*
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    84
   *  Return the highest power of 2 that is <= value; this correspond to
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    85
   *  the highest bit in a given 32-bit value.
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    86
   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    87
  FT_BASE( FT_UInt32 )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    88
  ft_highpow2( FT_UInt32  value );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    89
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    90
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    91
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    92
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    93
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    94
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    95
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    96
  /****                       C H A R M A P S                           ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    97
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    98
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
    99
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   100
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   101
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   102
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   103
  /* handle to internal charmap object */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   104
  typedef struct FT_CMapRec_*              FT_CMap;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   105
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   106
  /* handle to charmap class structure */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   107
  typedef const struct FT_CMap_ClassRec_*  FT_CMap_Class;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   108
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   109
  /* internal charmap object structure */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   110
  typedef struct  FT_CMapRec_
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   111
  {
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   112
    FT_CharMapRec  charmap;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   113
    FT_CMap_Class  clazz;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   114
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   115
  } FT_CMapRec;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   116
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   117
  /* typecase any pointer to a charmap handle */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   118
#define FT_CMAP( x )              ((FT_CMap)( x ))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   119
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   120
  /* obvious macros */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   121
#define FT_CMAP_PLATFORM_ID( x )  FT_CMAP( x )->charmap.platform_id
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   122
#define FT_CMAP_ENCODING_ID( x )  FT_CMAP( x )->charmap.encoding_id
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   123
#define FT_CMAP_ENCODING( x )     FT_CMAP( x )->charmap.encoding
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   124
#define FT_CMAP_FACE( x )         FT_CMAP( x )->charmap.face
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   125
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   126
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   127
  /* class method definitions */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   128
  typedef FT_Error
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   129
  (*FT_CMap_InitFunc)( FT_CMap     cmap,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   130
                       FT_Pointer  init_data );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   131
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   132
  typedef void
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   133
  (*FT_CMap_DoneFunc)( FT_CMap  cmap );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   134
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   135
  typedef FT_UInt
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   136
  (*FT_CMap_CharIndexFunc)( FT_CMap    cmap,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   137
                            FT_UInt32  char_code );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   138
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   139
  typedef FT_UInt
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   140
  (*FT_CMap_CharNextFunc)( FT_CMap     cmap,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   141
                           FT_UInt32  *achar_code );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   142
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   143
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   144
  typedef struct  FT_CMap_ClassRec_
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   145
  {
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   146
    FT_ULong               size;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   147
    FT_CMap_InitFunc       init;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   148
    FT_CMap_DoneFunc       done;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   149
    FT_CMap_CharIndexFunc  char_index;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   150
    FT_CMap_CharNextFunc   char_next;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   151
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   152
  } FT_CMap_ClassRec;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   153
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   154
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   155
  /* create a new charmap and add it to charmap->face */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   156
  FT_BASE( FT_Error )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   157
  FT_CMap_New( FT_CMap_Class  clazz,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   158
               FT_Pointer     init_data,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   159
               FT_CharMap     charmap,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   160
               FT_CMap       *acmap );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   161
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   162
  /* destroy a charmap and remove it from face's list */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   163
  FT_BASE( void )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   164
  FT_CMap_Done( FT_CMap  cmap );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   165
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   166
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   167
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   168
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   169
  /* <Struct>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   170
  /*    FT_Face_InternalRec                                                */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   171
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   172
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   173
  /*    This structure contains the internal fields of each FT_Face        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   174
  /*    object.  These fields may change between different releases of     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   175
  /*    FreeType.                                                          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   176
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   177
  /* <Fields>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   178
  /*    max_points ::                                                      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   179
  /*      The maximal number of points used to store the vectorial outline */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   180
  /*      of any glyph in this face.  If this value cannot be known in     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   181
  /*      advance, or if the face isn't scalable, this should be set to 0. */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   182
  /*      Only relevant for scalable formats.                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   183
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   184
  /*    max_contours ::                                                    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   185
  /*      The maximal number of contours used to store the vectorial       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   186
  /*      outline of any glyph in this face.  If this value cannot be      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   187
  /*      known in advance, or if the face isn't scalable, this should be  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   188
  /*      set to 0.  Only relevant for scalable formats.                   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   189
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   190
  /*    transform_matrix ::                                                */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   191
  /*      A 2x2 matrix of 16.16 coefficients used to transform glyph       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   192
  /*      outlines after they are loaded from the font.  Only used by the  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   193
  /*      convenience functions.                                           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   194
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   195
  /*    transform_delta ::                                                 */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   196
  /*      A translation vector used to transform glyph outlines after they */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   197
  /*      are loaded from the font.  Only used by the convenience          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   198
  /*      functions.                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   199
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   200
  /*    transform_flags ::                                                 */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   201
  /*      Some flags used to classify the transform.  Only used by the     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   202
  /*      convenience functions.                                           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   203
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   204
  /*    services ::                                                        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   205
  /*      A cache for frequently used services.  It should be only         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   206
  /*      accessed with the macro `FT_FACE_LOOKUP_SERVICE'.                */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   207
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   208
  /*    incremental_interface ::                                           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   209
  /*      If non-null, the interface through which glyph data and metrics  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   210
  /*      are loaded incrementally for faces that do not provide all of    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   211
  /*      this data when first opened.  This field exists only if          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   212
  /*      @FT_CONFIG_OPTION_INCREMENTAL is defined.                        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   213
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   214
  typedef struct  FT_Face_InternalRec_
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   215
  {
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   216
#ifdef FT_CONFIG_OPTION_OLD_INTERNALS
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   217
    FT_UShort           reserved1;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   218
    FT_Short            reserved2;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   219
#endif
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   220
    FT_Matrix           transform_matrix;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   221
    FT_Vector           transform_delta;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   222
    FT_Int              transform_flags;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   223
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   224
    FT_ServiceCacheRec  services;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   225
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   226
#ifdef FT_CONFIG_OPTION_INCREMENTAL
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   227
    FT_Incremental_InterfaceRec*  incremental_interface;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   228
#endif
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   229
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   230
  } FT_Face_InternalRec;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   231
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   232
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   233
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   234
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   235
  /* <Struct>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   236
  /*    FT_Slot_InternalRec                                                */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   237
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   238
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   239
  /*    This structure contains the internal fields of each FT_GlyphSlot   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   240
  /*    object.  These fields may change between different releases of     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   241
  /*    FreeType.                                                          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   242
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   243
  /* <Fields>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   244
  /*    loader            :: The glyph loader object used to load outlines */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   245
  /*                         into the glyph slot.                          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   246
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   247
  /*    flags             :: Possible values are zero or                   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   248
  /*                         FT_GLYPH_OWN_BITMAP.  The latter indicates    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   249
  /*                         that the FT_GlyphSlot structure owns the      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   250
  /*                         bitmap buffer.                                */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   251
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   252
  /*    glyph_transformed :: Boolean.  Set to TRUE when the loaded glyph   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   253
  /*                         must be transformed through a specific        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   254
  /*                         font transformation.  This is _not_ the same  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   255
  /*                         as the face transform set through             */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   256
  /*                         FT_Set_Transform().                           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   257
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   258
  /*    glyph_matrix      :: The 2x2 matrix corresponding to the glyph     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   259
  /*                         transformation, if necessary.                 */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   260
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   261
  /*    glyph_delta       :: The 2d translation vector corresponding to    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   262
  /*                         the glyph transformation, if necessary.       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   263
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   264
  /*    glyph_hints       :: Format-specific glyph hints management.       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   265
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   266
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   267
#define FT_GLYPH_OWN_BITMAP  0x1
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   268
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   269
  typedef struct  FT_Slot_InternalRec_
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   270
  {
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   271
    FT_GlyphLoader  loader;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   272
    FT_UInt         flags;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   273
    FT_Bool         glyph_transformed;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   274
    FT_Matrix       glyph_matrix;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   275
    FT_Vector       glyph_delta;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   276
    void*           glyph_hints;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   277
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   278
  } FT_GlyphSlot_InternalRec;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   279
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   280
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   281
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   282
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   283
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   284
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   285
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   286
  /****                         M O D U L E S                           ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   287
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   288
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   289
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   290
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   291
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   292
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   293
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   294
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   295
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   296
  /* <Struct>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   297
  /*    FT_ModuleRec                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   298
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   299
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   300
  /*    A module object instance.                                          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   301
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   302
  /* <Fields>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   303
  /*    clazz   :: A pointer to the module's class.                        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   304
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   305
  /*    library :: A handle to the parent library object.                  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   306
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   307
  /*    memory  :: A handle to the memory manager.                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   308
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   309
  /*    generic :: A generic structure for user-level extensibility (?).   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   310
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   311
  typedef struct  FT_ModuleRec_
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   312
  {
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   313
    FT_Module_Class*  clazz;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   314
    FT_Library        library;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   315
    FT_Memory         memory;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   316
    FT_Generic        generic;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   317
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   318
  } FT_ModuleRec;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   319
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   320
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   321
  /* typecast an object to a FT_Module */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   322
#define FT_MODULE( x )          ((FT_Module)( x ))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   323
#define FT_MODULE_CLASS( x )    FT_MODULE( x )->clazz
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   324
#define FT_MODULE_LIBRARY( x )  FT_MODULE( x )->library
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   325
#define FT_MODULE_MEMORY( x )   FT_MODULE( x )->memory
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   326
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   327
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   328
#define FT_MODULE_IS_DRIVER( x )  ( FT_MODULE_CLASS( x )->module_flags & \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   329
                                    FT_MODULE_FONT_DRIVER )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   330
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   331
#define FT_MODULE_IS_RENDERER( x )  ( FT_MODULE_CLASS( x )->module_flags & \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   332
                                      FT_MODULE_RENDERER )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   333
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   334
#define FT_MODULE_IS_HINTER( x )  ( FT_MODULE_CLASS( x )->module_flags & \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   335
                                    FT_MODULE_HINTER )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   336
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   337
#define FT_MODULE_IS_STYLER( x )  ( FT_MODULE_CLASS( x )->module_flags & \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   338
                                    FT_MODULE_STYLER )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   339
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   340
#define FT_DRIVER_IS_SCALABLE( x )  ( FT_MODULE_CLASS( x )->module_flags & \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   341
                                      FT_MODULE_DRIVER_SCALABLE )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   342
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   343
#define FT_DRIVER_USES_OUTLINES( x )  !( FT_MODULE_CLASS( x )->module_flags & \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   344
                                         FT_MODULE_DRIVER_NO_OUTLINES )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   345
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   346
#define FT_DRIVER_HAS_HINTER( x )  ( FT_MODULE_CLASS( x )->module_flags & \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   347
                                     FT_MODULE_DRIVER_HAS_HINTER )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   348
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   349
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   350
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   351
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   352
  /* <Function>                                                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   353
  /*    FT_Get_Module_Interface                                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   354
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   355
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   356
  /*    Finds a module and returns its specific interface as a typeless    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   357
  /*    pointer.                                                           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   358
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   359
  /* <Input>                                                               */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   360
  /*    library     :: A handle to the library object.                     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   361
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   362
  /*    module_name :: The module's name (as an ASCII string).             */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   363
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   364
  /* <Return>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   365
  /*    A module-specific interface if available, 0 otherwise.             */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   366
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   367
  /* <Note>                                                                */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   368
  /*    You should better be familiar with FreeType internals to know      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   369
  /*    which module to look for, and what its interface is :-)            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   370
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   371
  FT_BASE( const void* )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   372
  FT_Get_Module_Interface( FT_Library   library,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   373
                           const char*  mod_name );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   374
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   375
  FT_BASE( FT_Pointer )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   376
  ft_module_get_service( FT_Module    module,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   377
                         const char*  service_id );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   378
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   379
 /* */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   380
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   381
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   382
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   383
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   384
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   385
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   386
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   387
  /****               FACE, SIZE & GLYPH SLOT OBJECTS                   ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   388
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   389
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   390
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   391
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   392
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   393
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   394
  /* a few macros used to perform easy typecasts with minimal brain damage */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   395
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   396
#define FT_FACE( x )          ((FT_Face)(x))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   397
#define FT_SIZE( x )          ((FT_Size)(x))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   398
#define FT_SLOT( x )          ((FT_GlyphSlot)(x))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   399
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   400
#define FT_FACE_DRIVER( x )   FT_FACE( x )->driver
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   401
#define FT_FACE_LIBRARY( x )  FT_FACE_DRIVER( x )->root.library
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   402
#define FT_FACE_MEMORY( x )   FT_FACE( x )->memory
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   403
#define FT_FACE_STREAM( x )   FT_FACE( x )->stream
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   404
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   405
#define FT_SIZE_FACE( x )     FT_SIZE( x )->face
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   406
#define FT_SLOT_FACE( x )     FT_SLOT( x )->face
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   407
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   408
#define FT_FACE_SLOT( x )     FT_FACE( x )->glyph
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   409
#define FT_FACE_SIZE( x )     FT_FACE( x )->size
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   410
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   411
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   412
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   413
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   414
  /* <Function>                                                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   415
  /*    FT_New_GlyphSlot                                                   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   416
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   417
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   418
  /*    It is sometimes useful to have more than one glyph slot for a      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   419
  /*    given face object.  This function is used to create additional     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   420
  /*    slots.  All of them are automatically discarded when the face is   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   421
  /*    destroyed.                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   422
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   423
  /* <Input>                                                               */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   424
  /*    face  :: A handle to a parent face object.                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   425
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   426
  /* <Output>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   427
  /*    aslot :: A handle to a new glyph slot object.                      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   428
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   429
  /* <Return>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   430
  /*    FreeType error code.  0 means success.                             */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   431
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   432
  FT_BASE( FT_Error )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   433
  FT_New_GlyphSlot( FT_Face        face,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   434
                    FT_GlyphSlot  *aslot );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   435
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   436
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   437
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   438
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   439
  /* <Function>                                                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   440
  /*    FT_Done_GlyphSlot                                                  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   441
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   442
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   443
  /*    Destroys a given glyph slot.  Remember however that all slots are  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   444
  /*    automatically destroyed with its parent.  Using this function is   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   445
  /*    not always mandatory.                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   446
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   447
  /* <Input>                                                               */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   448
  /*    slot :: A handle to a target glyph slot.                           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   449
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   450
  FT_BASE( void )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   451
  FT_Done_GlyphSlot( FT_GlyphSlot  slot );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   452
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   453
 /* */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   454
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   455
#define FT_REQUEST_WIDTH( req )                                            \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   456
          ( (req)->horiResolution                                          \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   457
              ? (FT_Pos)( (req)->width * (req)->horiResolution + 36 ) / 72 \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   458
              : (req)->width )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   459
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   460
#define FT_REQUEST_HEIGHT( req )                                            \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   461
          ( (req)->vertResolution                                           \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   462
              ? (FT_Pos)( (req)->height * (req)->vertResolution + 36 ) / 72 \
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   463
              : (req)->height )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   464
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   465
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   466
  /* Set the metrics according to a bitmap strike. */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   467
  FT_BASE( void )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   468
  FT_Select_Metrics( FT_Face   face,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   469
                     FT_ULong  strike_index );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   470
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   471
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   472
  /* Set the metrics according to a size request. */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   473
  FT_BASE( void )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   474
  FT_Request_Metrics( FT_Face          face,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   475
                      FT_Size_Request  req );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   476
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   477
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   478
  /* Match a size request against `available_sizes'. */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   479
  FT_BASE( FT_Error )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   480
  FT_Match_Size( FT_Face          face,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   481
                 FT_Size_Request  req,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   482
                 FT_Bool          ignore_width,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   483
                 FT_ULong*        size_index );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   484
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   485
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   486
  /* Use the horizontal metrics to synthesize the vertical metrics. */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   487
  /* If `advance' is zero, it is also synthesized.                  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   488
  FT_BASE( void )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   489
  ft_synthesize_vertical_metrics( FT_Glyph_Metrics*  metrics,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   490
                                  FT_Pos             advance );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   491
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   492
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   493
  /* Free the bitmap of a given glyphslot when needed (i.e., only when it */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   494
  /* was allocated with ft_glyphslot_alloc_bitmap).                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   495
  FT_BASE( void )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   496
  ft_glyphslot_free_bitmap( FT_GlyphSlot  slot );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   497
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   498
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   499
  /* Allocate a new bitmap buffer in a glyph slot. */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   500
  FT_BASE( FT_Error )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   501
  ft_glyphslot_alloc_bitmap( FT_GlyphSlot  slot,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   502
                             FT_ULong      size );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   503
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   504
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   505
  /* Set the bitmap buffer in a glyph slot to a given pointer.  The buffer */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   506
  /* will not be freed by a later call to ft_glyphslot_free_bitmap.        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   507
  FT_BASE( void )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   508
  ft_glyphslot_set_bitmap( FT_GlyphSlot  slot,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   509
                           FT_Byte*      buffer );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   510
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   511
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   512
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   513
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   514
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   515
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   516
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   517
  /****                        R E N D E R E R S                        ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   518
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   519
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   520
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   521
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   522
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   523
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   524
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   525
#define FT_RENDERER( x )      ((FT_Renderer)( x ))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   526
#define FT_GLYPH( x )         ((FT_Glyph)( x ))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   527
#define FT_BITMAP_GLYPH( x )  ((FT_BitmapGlyph)( x ))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   528
#define FT_OUTLINE_GLYPH( x ) ((FT_OutlineGlyph)( x ))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   529
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   530
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   531
  typedef struct  FT_RendererRec_
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   532
  {
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   533
    FT_ModuleRec            root;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   534
    FT_Renderer_Class*      clazz;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   535
    FT_Glyph_Format         glyph_format;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   536
    FT_Glyph_Class          glyph_class;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   537
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   538
    FT_Raster               raster;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   539
    FT_Raster_Render_Func   raster_render;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   540
    FT_Renderer_RenderFunc  render;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   541
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   542
  } FT_RendererRec;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   543
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   544
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   545
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   546
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   547
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   548
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   549
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   550
  /****                    F O N T   D R I V E R S                      ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   551
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   552
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   553
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   554
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   555
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   556
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   557
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   558
  /* typecast a module into a driver easily */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   559
#define FT_DRIVER( x )        ((FT_Driver)(x))
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   560
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   561
  /* typecast a module as a driver, and get its driver class */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   562
#define FT_DRIVER_CLASS( x )  FT_DRIVER( x )->clazz
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   563
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   564
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   565
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   566
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   567
  /* <Struct>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   568
  /*    FT_DriverRec                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   569
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   570
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   571
  /*    The root font driver class.  A font driver is responsible for      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   572
  /*    managing and loading font files of a given format.                 */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   573
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   574
  /*  <Fields>                                                             */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   575
  /*     root         :: Contains the fields of the root module class.     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   576
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   577
  /*     clazz        :: A pointer to the font driver's class.  Note that  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   578
  /*                     this is NOT root.clazz.  `class' wasn't used      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   579
  /*                     as it is a reserved word in C++.                  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   580
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   581
  /*     faces_list   :: The list of faces currently opened by this        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   582
  /*                     driver.                                           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   583
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   584
  /*     extensions   :: A typeless pointer to the driver's extensions     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   585
  /*                     registry, if they are supported through the       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   586
  /*                     configuration macro FT_CONFIG_OPTION_EXTENSIONS.  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   587
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   588
  /*     glyph_loader :: The glyph loader for all faces managed by this    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   589
  /*                     driver.  This object isn't defined for unscalable */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   590
  /*                     formats.                                          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   591
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   592
  typedef struct  FT_DriverRec_
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   593
  {
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   594
    FT_ModuleRec     root;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   595
    FT_Driver_Class  clazz;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   596
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   597
    FT_ListRec       faces_list;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   598
    void*            extensions;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   599
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   600
    FT_GlyphLoader   glyph_loader;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   601
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   602
  } FT_DriverRec;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   603
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   604
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   605
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   606
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   607
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   608
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   609
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   610
  /****                       L I B R A R I E S                         ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   611
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   612
  /****                                                                 ****/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   613
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   614
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   615
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   616
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   617
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   618
  /* This hook is used by the TrueType debugger.  It must be set to an */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   619
  /* alternate truetype bytecode interpreter function.                 */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   620
#define FT_DEBUG_HOOK_TRUETYPE            0
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   621
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   622
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   623
  /* Set this debug hook to a non-null pointer to force unpatented hinting */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   624
  /* for all faces when both TT_CONFIG_OPTION_BYTECODE_INTERPRETER and     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   625
  /* TT_CONFIG_OPTION_UNPATENTED_HINTING are defined. this is only used    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   626
  /* during debugging.                                                     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   627
#define FT_DEBUG_HOOK_UNPATENTED_HINTING  1
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   628
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   629
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   630
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   631
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   632
  /* <Struct>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   633
  /*    FT_LibraryRec                                                      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   634
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   635
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   636
  /*    The FreeType library class.  This is the root of all FreeType      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   637
  /*    data.  Use FT_New_Library() to create a library object, and        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   638
  /*    FT_Done_Library() to discard it and all child objects.             */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   639
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   640
  /* <Fields>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   641
  /*    memory           :: The library's memory object.  Manages memory   */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   642
  /*                        allocation.                                    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   643
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   644
  /*    generic          :: Client data variable.  Used to extend the      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   645
  /*                        Library class by higher levels and clients.    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   646
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   647
  /*    version_major    :: The major version number of the library.       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   648
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   649
  /*    version_minor    :: The minor version number of the library.       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   650
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   651
  /*    version_patch    :: The current patch level of the library.        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   652
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   653
  /*    num_modules      :: The number of modules currently registered     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   654
  /*                        within this library.  This is set to 0 for new */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   655
  /*                        libraries.  New modules are added through the  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   656
  /*                        FT_Add_Module() API function.                  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   657
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   658
  /*    modules          :: A table used to store handles to the currently */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   659
  /*                        registered modules. Note that each font driver */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   660
  /*                        contains a list of its opened faces.           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   661
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   662
  /*    renderers        :: The list of renderers currently registered     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   663
  /*                        within the library.                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   664
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   665
  /*    cur_renderer     :: The current outline renderer.  This is a       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   666
  /*                        shortcut used to avoid parsing the list on     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   667
  /*                        each call to FT_Outline_Render().  It is a     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   668
  /*                        handle to the current renderer for the         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   669
  /*                        FT_GLYPH_FORMAT_OUTLINE format.                */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   670
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   671
  /*    auto_hinter      :: XXX                                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   672
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   673
  /*    raster_pool      :: The raster object's render pool.  This can     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   674
  /*                        ideally be changed dynamically at run-time.    */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   675
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   676
  /*    raster_pool_size :: The size of the render pool in bytes.          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   677
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   678
  /*    debug_hooks      :: XXX                                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   679
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   680
  typedef struct  FT_LibraryRec_
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   681
  {
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   682
    FT_Memory          memory;           /* library's memory manager */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   683
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   684
    FT_Generic         generic;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   685
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   686
    FT_Int             version_major;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   687
    FT_Int             version_minor;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   688
    FT_Int             version_patch;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   689
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   690
    FT_UInt            num_modules;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   691
    FT_Module          modules[FT_MAX_MODULES];  /* module objects  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   692
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   693
    FT_ListRec         renderers;        /* list of renderers        */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   694
    FT_Renderer        cur_renderer;     /* current outline renderer */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   695
    FT_Module          auto_hinter;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   696
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   697
    FT_Byte*           raster_pool;      /* scan-line conversion */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   698
                                         /* render pool          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   699
    FT_ULong           raster_pool_size; /* size of render pool in bytes */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   700
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   701
    FT_DebugHook_Func  debug_hooks[4];
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   702
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   703
  } FT_LibraryRec;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   704
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   705
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   706
  FT_BASE( FT_Renderer )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   707
  FT_Lookup_Renderer( FT_Library       library,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   708
                      FT_Glyph_Format  format,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   709
                      FT_ListNode*     node );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   710
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   711
  FT_BASE( FT_Error )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   712
  FT_Render_Glyph_Internal( FT_Library      library,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   713
                            FT_GlyphSlot    slot,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   714
                            FT_Render_Mode  render_mode );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   715
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   716
  typedef const char*
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   717
  (*FT_Face_GetPostscriptNameFunc)( FT_Face  face );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   718
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   719
  typedef FT_Error
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   720
  (*FT_Face_GetGlyphNameFunc)( FT_Face     face,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   721
                               FT_UInt     glyph_index,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   722
                               FT_Pointer  buffer,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   723
                               FT_UInt     buffer_max );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   724
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   725
  typedef FT_UInt
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   726
  (*FT_Face_GetGlyphNameIndexFunc)( FT_Face     face,
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   727
                                    FT_String*  glyph_name );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   728
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   729
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   730
#ifndef FT_CONFIG_OPTION_NO_DEFAULT_SYSTEM
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   731
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   732
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   733
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   734
  /* <Function>                                                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   735
  /*    FT_New_Memory                                                      */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   736
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   737
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   738
  /*    Creates a new memory object.                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   739
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   740
  /* <Return>                                                              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   741
  /*    A pointer to the new memory object.  0 in case of error.           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   742
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   743
  FT_BASE( FT_Memory )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   744
  FT_New_Memory( void );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   745
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   746
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   747
  /*************************************************************************/
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   748
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   749
  /* <Function>                                                            */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   750
  /*    FT_Done_Memory                                                     */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   751
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   752
  /* <Description>                                                         */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   753
  /*    Discards memory manager.                                           */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   754
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   755
  /* <Input>                                                               */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   756
  /*    memory :: A handle to the memory manager.                          */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   757
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   758
  FT_BASE( void )
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   759
  FT_Done_Memory( FT_Memory  memory );
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   760
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   761
#endif /* !FT_CONFIG_OPTION_NO_DEFAULT_SYSTEM */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   762
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   763
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   764
  /* Define default raster's interface.  The default raster is located in  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   765
  /* `src/base/ftraster.c'.                                                */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   766
  /*                                                                       */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   767
  /* Client applications can register new rasters through the              */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   768
  /* FT_Set_Raster() API.                                                  */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   769
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   770
#ifndef FT_NO_DEFAULT_RASTER
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   771
  FT_EXPORT_VAR( FT_Raster_Funcs )  ft_default_raster;
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   772
#endif
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   773
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   774
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   775
FT_END_HEADER
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   776
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   777
#endif /* __FTOBJS_H__ */
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   778
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   779
6cc5529d4a89 201033_10
hgs
parents:
diff changeset
   780
/* END */