xref: /inferno-os/include/freetype/internal/tttypes.h (revision 37da2899f40661e3e9631e497da8dc59b971cbd0)
1*37da2899SCharles.Forsyth /***************************************************************************/
2*37da2899SCharles.Forsyth /*                                                                         */
3*37da2899SCharles.Forsyth /*  tttypes.h                                                              */
4*37da2899SCharles.Forsyth /*                                                                         */
5*37da2899SCharles.Forsyth /*    Basic SFNT/TrueType type definitions and interface (specification    */
6*37da2899SCharles.Forsyth /*    only).                                                               */
7*37da2899SCharles.Forsyth /*                                                                         */
8*37da2899SCharles.Forsyth /*  Copyright 1996-2001, 2002 by                                           */
9*37da2899SCharles.Forsyth /*  David Turner, Robert Wilhelm, and Werner Lemberg.                      */
10*37da2899SCharles.Forsyth /*                                                                         */
11*37da2899SCharles.Forsyth /*  This file is part of the FreeType project, and may only be used,       */
12*37da2899SCharles.Forsyth /*  modified, and distributed under the terms of the FreeType project      */
13*37da2899SCharles.Forsyth /*  license, LICENSE.TXT.  By continuing to use, modify, or distribute     */
14*37da2899SCharles.Forsyth /*  this file you indicate that you have read the license and              */
15*37da2899SCharles.Forsyth /*  understand and accept it fully.                                        */
16*37da2899SCharles.Forsyth /*                                                                         */
17*37da2899SCharles.Forsyth /***************************************************************************/
18*37da2899SCharles.Forsyth 
19*37da2899SCharles.Forsyth 
20*37da2899SCharles.Forsyth #ifndef __TTTYPES_H__
21*37da2899SCharles.Forsyth #define __TTTYPES_H__
22*37da2899SCharles.Forsyth 
23*37da2899SCharles.Forsyth 
24*37da2899SCharles.Forsyth #include <ft2build.h>
25*37da2899SCharles.Forsyth #include FT_TRUETYPE_TABLES_H
26*37da2899SCharles.Forsyth #include FT_INTERNAL_OBJECTS_H
27*37da2899SCharles.Forsyth 
28*37da2899SCharles.Forsyth 
29*37da2899SCharles.Forsyth FT_BEGIN_HEADER
30*37da2899SCharles.Forsyth 
31*37da2899SCharles.Forsyth 
32*37da2899SCharles.Forsyth   /*************************************************************************/
33*37da2899SCharles.Forsyth   /*************************************************************************/
34*37da2899SCharles.Forsyth   /*************************************************************************/
35*37da2899SCharles.Forsyth   /***                                                                   ***/
36*37da2899SCharles.Forsyth   /***                                                                   ***/
37*37da2899SCharles.Forsyth   /***             REQUIRED TRUETYPE/OPENTYPE TABLES DEFINITIONS         ***/
38*37da2899SCharles.Forsyth   /***                                                                   ***/
39*37da2899SCharles.Forsyth   /***                                                                   ***/
40*37da2899SCharles.Forsyth   /*************************************************************************/
41*37da2899SCharles.Forsyth   /*************************************************************************/
42*37da2899SCharles.Forsyth   /*************************************************************************/
43*37da2899SCharles.Forsyth 
44*37da2899SCharles.Forsyth 
45*37da2899SCharles.Forsyth   /*************************************************************************/
46*37da2899SCharles.Forsyth   /*                                                                       */
47*37da2899SCharles.Forsyth   /* <Struct>                                                              */
48*37da2899SCharles.Forsyth   /*    TTC_HeaderRec                                                      */
49*37da2899SCharles.Forsyth   /*                                                                       */
50*37da2899SCharles.Forsyth   /* <Description>                                                         */
51*37da2899SCharles.Forsyth   /*    TrueType collection header.  This table contains the offsets of    */
52*37da2899SCharles.Forsyth   /*    the font headers of each distinct TrueType face in the file.       */
53*37da2899SCharles.Forsyth   /*                                                                       */
54*37da2899SCharles.Forsyth   /* <Fields>                                                              */
55*37da2899SCharles.Forsyth   /*    tag     :: Must be `ttc ' to indicate a TrueType collection.       */
56*37da2899SCharles.Forsyth   /*                                                                       */
57*37da2899SCharles.Forsyth   /*    version :: The version number.                                     */
58*37da2899SCharles.Forsyth   /*                                                                       */
59*37da2899SCharles.Forsyth   /*    count   :: The number of faces in the collection.  The             */
60*37da2899SCharles.Forsyth   /*               specification says this should be an unsigned long, but */
61*37da2899SCharles.Forsyth   /*               we use a signed long since we need the value -1 for     */
62*37da2899SCharles.Forsyth   /*               specific purposes.                                      */
63*37da2899SCharles.Forsyth   /*                                                                       */
64*37da2899SCharles.Forsyth   /*    offsets :: The offsets of the font headers, one per face.          */
65*37da2899SCharles.Forsyth   /*                                                                       */
66*37da2899SCharles.Forsyth   typedef struct  TTC_HeaderRec_
67*37da2899SCharles.Forsyth   {
68*37da2899SCharles.Forsyth     FT_ULong   tag;
69*37da2899SCharles.Forsyth     FT_Fixed   version;
70*37da2899SCharles.Forsyth     FT_Long    count;
71*37da2899SCharles.Forsyth     FT_ULong*  offsets;
72*37da2899SCharles.Forsyth 
73*37da2899SCharles.Forsyth   } TTC_HeaderRec;
74*37da2899SCharles.Forsyth 
75*37da2899SCharles.Forsyth 
76*37da2899SCharles.Forsyth   /*************************************************************************/
77*37da2899SCharles.Forsyth   /*                                                                       */
78*37da2899SCharles.Forsyth   /* <Struct>                                                              */
79*37da2899SCharles.Forsyth   /*    SFNT_HeaderRec                                                     */
80*37da2899SCharles.Forsyth   /*                                                                       */
81*37da2899SCharles.Forsyth   /* <Description>                                                         */
82*37da2899SCharles.Forsyth   /*    SFNT file format header.                                           */
83*37da2899SCharles.Forsyth   /*                                                                       */
84*37da2899SCharles.Forsyth   /* <Fields>                                                              */
85*37da2899SCharles.Forsyth   /*    format_tag     :: The font format tag.                             */
86*37da2899SCharles.Forsyth   /*                                                                       */
87*37da2899SCharles.Forsyth   /*    num_tables     :: The number of tables in file.                    */
88*37da2899SCharles.Forsyth   /*                                                                       */
89*37da2899SCharles.Forsyth   /*    search_range   :: Must be `16 * (max power of 2 <= num_tables)'.   */
90*37da2899SCharles.Forsyth   /*                                                                       */
91*37da2899SCharles.Forsyth   /*    entry_selector :: Must be log2 of `search_range / 16'.             */
92*37da2899SCharles.Forsyth   /*                                                                       */
93*37da2899SCharles.Forsyth   /*    range_shift    :: Must be `num_tables * 16 - search_range'.        */
94*37da2899SCharles.Forsyth   /*                                                                       */
95*37da2899SCharles.Forsyth   typedef struct  SFNT_HeaderRec_
96*37da2899SCharles.Forsyth   {
97*37da2899SCharles.Forsyth     FT_ULong   format_tag;
98*37da2899SCharles.Forsyth     FT_UShort  num_tables;
99*37da2899SCharles.Forsyth     FT_UShort  search_range;
100*37da2899SCharles.Forsyth     FT_UShort  entry_selector;
101*37da2899SCharles.Forsyth     FT_UShort  range_shift;
102*37da2899SCharles.Forsyth 
103*37da2899SCharles.Forsyth     FT_ULong   offset;  /* not in file */
104*37da2899SCharles.Forsyth 
105*37da2899SCharles.Forsyth   } SFNT_HeaderRec, *SFNT_Header;
106*37da2899SCharles.Forsyth 
107*37da2899SCharles.Forsyth 
108*37da2899SCharles.Forsyth   /*************************************************************************/
109*37da2899SCharles.Forsyth   /*                                                                       */
110*37da2899SCharles.Forsyth   /* <Struct>                                                              */
111*37da2899SCharles.Forsyth   /*    TT_TableDirRec                                                     */
112*37da2899SCharles.Forsyth   /*                                                                       */
113*37da2899SCharles.Forsyth   /* <Description>                                                         */
114*37da2899SCharles.Forsyth   /*    This structure models a TrueType table directory.  It is used to   */
115*37da2899SCharles.Forsyth   /*    access the various tables of the font face.                        */
116*37da2899SCharles.Forsyth   /*                                                                       */
117*37da2899SCharles.Forsyth   /* <Fields>                                                              */
118*37da2899SCharles.Forsyth   /*    version       :: The version number; starts with 0x00010000.       */
119*37da2899SCharles.Forsyth   /*                                                                       */
120*37da2899SCharles.Forsyth   /*    numTables     :: The number of tables.                             */
121*37da2899SCharles.Forsyth   /*                                                                       */
122*37da2899SCharles.Forsyth   /*    searchRange   :: Unused.                                           */
123*37da2899SCharles.Forsyth   /*                                                                       */
124*37da2899SCharles.Forsyth   /*    entrySelector :: Unused.                                           */
125*37da2899SCharles.Forsyth   /*                                                                       */
126*37da2899SCharles.Forsyth   /*    rangeShift    :: Unused.                                           */
127*37da2899SCharles.Forsyth   /*                                                                       */
128*37da2899SCharles.Forsyth   /* <Note>                                                                */
129*37da2899SCharles.Forsyth   /*    This structure is only used during font opening.                   */
130*37da2899SCharles.Forsyth   /*                                                                       */
131*37da2899SCharles.Forsyth   typedef struct  TT_TableDirRec_
132*37da2899SCharles.Forsyth   {
133*37da2899SCharles.Forsyth     FT_Fixed   version;        /* should be 0x10000 */
134*37da2899SCharles.Forsyth     FT_UShort  numTables;      /* number of tables  */
135*37da2899SCharles.Forsyth 
136*37da2899SCharles.Forsyth     FT_UShort  searchRange;    /* These parameters are only used  */
137*37da2899SCharles.Forsyth     FT_UShort  entrySelector;  /* for a dichotomy search in the   */
138*37da2899SCharles.Forsyth     FT_UShort  rangeShift;     /* directory.  We ignore them.     */
139*37da2899SCharles.Forsyth 
140*37da2899SCharles.Forsyth   } TT_TableDirRec;
141*37da2899SCharles.Forsyth 
142*37da2899SCharles.Forsyth 
143*37da2899SCharles.Forsyth   /*************************************************************************/
144*37da2899SCharles.Forsyth   /*                                                                       */
145*37da2899SCharles.Forsyth   /* <Struct>                                                              */
146*37da2899SCharles.Forsyth   /*    TT_TableRec                                                        */
147*37da2899SCharles.Forsyth   /*                                                                       */
148*37da2899SCharles.Forsyth   /* <Description>                                                         */
149*37da2899SCharles.Forsyth   /*    This structure describes a given table of a TrueType font.         */
150*37da2899SCharles.Forsyth   /*                                                                       */
151*37da2899SCharles.Forsyth   /* <Fields>                                                              */
152*37da2899SCharles.Forsyth   /*    Tag      :: A four-bytes tag describing the table.                 */
153*37da2899SCharles.Forsyth   /*                                                                       */
154*37da2899SCharles.Forsyth   /*    CheckSum :: The table checksum.  This value can be ignored.        */
155*37da2899SCharles.Forsyth   /*                                                                       */
156*37da2899SCharles.Forsyth   /*    Offset   :: The offset of the table from the start of the TrueType */
157*37da2899SCharles.Forsyth   /*                font in its resource.                                  */
158*37da2899SCharles.Forsyth   /*                                                                       */
159*37da2899SCharles.Forsyth   /*    Length   :: The table length (in bytes).                           */
160*37da2899SCharles.Forsyth   /*                                                                       */
161*37da2899SCharles.Forsyth   typedef struct  TT_TableRec_
162*37da2899SCharles.Forsyth   {
163*37da2899SCharles.Forsyth     FT_ULong  Tag;        /*        table type */
164*37da2899SCharles.Forsyth     FT_ULong  CheckSum;   /*    table checksum */
165*37da2899SCharles.Forsyth     FT_ULong  Offset;     /* table file offset */
166*37da2899SCharles.Forsyth     FT_ULong  Length;     /*      table length */
167*37da2899SCharles.Forsyth 
168*37da2899SCharles.Forsyth   } TT_TableRec, *TT_Table;
169*37da2899SCharles.Forsyth 
170*37da2899SCharles.Forsyth 
171*37da2899SCharles.Forsyth   /*************************************************************************/
172*37da2899SCharles.Forsyth   /*                                                                       */
173*37da2899SCharles.Forsyth   /* <Struct>                                                              */
174*37da2899SCharles.Forsyth   /*    TT_CMapDirRec                                                      */
175*37da2899SCharles.Forsyth   /*                                                                       */
176*37da2899SCharles.Forsyth   /* <Description>                                                         */
177*37da2899SCharles.Forsyth   /*    This structure describes the directory of the `cmap' table,        */
178*37da2899SCharles.Forsyth   /*    containing the font's character mappings table.                    */
179*37da2899SCharles.Forsyth   /*                                                                       */
180*37da2899SCharles.Forsyth   /* <Fields>                                                              */
181*37da2899SCharles.Forsyth   /*    tableVersionNumber :: The version number.                          */
182*37da2899SCharles.Forsyth   /*                                                                       */
183*37da2899SCharles.Forsyth   /*    numCMaps           :: The number of charmaps in the font.          */
184*37da2899SCharles.Forsyth   /*                                                                       */
185*37da2899SCharles.Forsyth   /* <Note>                                                                */
186*37da2899SCharles.Forsyth   /*    This structure is only used during font loading.                   */
187*37da2899SCharles.Forsyth   /*                                                                       */
188*37da2899SCharles.Forsyth   typedef struct  TT_CMapDirRec_
189*37da2899SCharles.Forsyth   {
190*37da2899SCharles.Forsyth     FT_UShort  tableVersionNumber;
191*37da2899SCharles.Forsyth     FT_UShort  numCMaps;
192*37da2899SCharles.Forsyth 
193*37da2899SCharles.Forsyth   } TT_CMapDirRec, *TT_CMapDir;
194*37da2899SCharles.Forsyth 
195*37da2899SCharles.Forsyth 
196*37da2899SCharles.Forsyth   /*************************************************************************/
197*37da2899SCharles.Forsyth   /*                                                                       */
198*37da2899SCharles.Forsyth   /* <Struct>                                                              */
199*37da2899SCharles.Forsyth   /*    TT_CMapDirEntryRec                                                 */
200*37da2899SCharles.Forsyth   /*                                                                       */
201*37da2899SCharles.Forsyth   /* <Description>                                                         */
202*37da2899SCharles.Forsyth   /*    This structure describes a charmap in a TrueType font.             */
203*37da2899SCharles.Forsyth   /*                                                                       */
204*37da2899SCharles.Forsyth   /* <Fields>                                                              */
205*37da2899SCharles.Forsyth   /*    platformID :: An ID used to specify for which platform this        */
206*37da2899SCharles.Forsyth   /*                  charmap is defined (FreeType manages all platforms). */
207*37da2899SCharles.Forsyth   /*                                                                       */
208*37da2899SCharles.Forsyth   /*    encodingID :: A platform-specific ID used to indicate which source */
209*37da2899SCharles.Forsyth   /*                  encoding is used in this charmap.                    */
210*37da2899SCharles.Forsyth   /*                                                                       */
211*37da2899SCharles.Forsyth   /*    offset     :: The offset of the charmap relative to the start of   */
212*37da2899SCharles.Forsyth   /*                  the `cmap' table.                                    */
213*37da2899SCharles.Forsyth   /*                                                                       */
214*37da2899SCharles.Forsyth   /* <Note>                                                                */
215*37da2899SCharles.Forsyth   /*    This structure is only used during font loading.                   */
216*37da2899SCharles.Forsyth   /*                                                                       */
217*37da2899SCharles.Forsyth   typedef struct  TT_CMapDirEntryRec_
218*37da2899SCharles.Forsyth   {
219*37da2899SCharles.Forsyth     FT_UShort  platformID;
220*37da2899SCharles.Forsyth     FT_UShort  platformEncodingID;
221*37da2899SCharles.Forsyth     FT_Long    offset;
222*37da2899SCharles.Forsyth 
223*37da2899SCharles.Forsyth   } TT_CMapDirEntryRec, *TT_CMapDirEntry;
224*37da2899SCharles.Forsyth 
225*37da2899SCharles.Forsyth 
226*37da2899SCharles.Forsyth   /*************************************************************************/
227*37da2899SCharles.Forsyth   /*                                                                       */
228*37da2899SCharles.Forsyth   /* <Struct>                                                              */
229*37da2899SCharles.Forsyth   /*    TT_LongMetricsRec                                                  */
230*37da2899SCharles.Forsyth   /*                                                                       */
231*37da2899SCharles.Forsyth   /* <Description>                                                         */
232*37da2899SCharles.Forsyth   /*    A structure modeling the long metrics of the `hmtx' and `vmtx'     */
233*37da2899SCharles.Forsyth   /*    TrueType tables.  The values are expressed in font units.          */
234*37da2899SCharles.Forsyth   /*                                                                       */
235*37da2899SCharles.Forsyth   /* <Fields>                                                              */
236*37da2899SCharles.Forsyth   /*    advance :: The advance width or height for the glyph.              */
237*37da2899SCharles.Forsyth   /*                                                                       */
238*37da2899SCharles.Forsyth   /*    bearing :: The left-side or top-side bearing for the glyph.        */
239*37da2899SCharles.Forsyth   /*                                                                       */
240*37da2899SCharles.Forsyth   typedef struct  TT_LongMetricsRec_
241*37da2899SCharles.Forsyth   {
242*37da2899SCharles.Forsyth     FT_UShort  advance;
243*37da2899SCharles.Forsyth     FT_Short   bearing;
244*37da2899SCharles.Forsyth 
245*37da2899SCharles.Forsyth   } TT_LongMetricsRec, *TT_LongMetrics;
246*37da2899SCharles.Forsyth 
247*37da2899SCharles.Forsyth 
248*37da2899SCharles.Forsyth   /*************************************************************************/
249*37da2899SCharles.Forsyth   /*                                                                       */
250*37da2899SCharles.Forsyth   /* <Type>                                                                */
251*37da2899SCharles.Forsyth   /*    TT_ShortMetrics                                                    */
252*37da2899SCharles.Forsyth   /*                                                                       */
253*37da2899SCharles.Forsyth   /* <Description>                                                         */
254*37da2899SCharles.Forsyth   /*    A simple type to model the short metrics of the `hmtx' and `vmtx'  */
255*37da2899SCharles.Forsyth   /*    tables.                                                            */
256*37da2899SCharles.Forsyth   /*                                                                       */
257*37da2899SCharles.Forsyth   typedef FT_Short  TT_ShortMetrics;
258*37da2899SCharles.Forsyth 
259*37da2899SCharles.Forsyth 
260*37da2899SCharles.Forsyth   /*************************************************************************/
261*37da2899SCharles.Forsyth   /*                                                                       */
262*37da2899SCharles.Forsyth   /* <Struct>                                                              */
263*37da2899SCharles.Forsyth   /*    TT_NameEntryRec                                                    */
264*37da2899SCharles.Forsyth   /*                                                                       */
265*37da2899SCharles.Forsyth   /* <Description>                                                         */
266*37da2899SCharles.Forsyth   /*    A structure modeling TrueType name records.  Name records are used */
267*37da2899SCharles.Forsyth   /*    to store important strings like family name, style name,           */
268*37da2899SCharles.Forsyth   /*    copyright, etc. in _localized_ versions (i.e., language, encoding, */
269*37da2899SCharles.Forsyth   /*    etc).                                                              */
270*37da2899SCharles.Forsyth   /*                                                                       */
271*37da2899SCharles.Forsyth   /* <Fields>                                                              */
272*37da2899SCharles.Forsyth   /*    platformID   :: The ID of the name's encoding platform.            */
273*37da2899SCharles.Forsyth   /*                                                                       */
274*37da2899SCharles.Forsyth   /*    encodingID   :: The platform-specific ID for the name's encoding.  */
275*37da2899SCharles.Forsyth   /*                                                                       */
276*37da2899SCharles.Forsyth   /*    languageID   :: The platform-specific ID for the name's language.  */
277*37da2899SCharles.Forsyth   /*                                                                       */
278*37da2899SCharles.Forsyth   /*    nameID       :: The ID specifying what kind of name this is.       */
279*37da2899SCharles.Forsyth   /*                                                                       */
280*37da2899SCharles.Forsyth   /*    stringLength :: The length of the string in bytes.                 */
281*37da2899SCharles.Forsyth   /*                                                                       */
282*37da2899SCharles.Forsyth   /*    stringOffset :: The offset to the string in the `name' table.      */
283*37da2899SCharles.Forsyth   /*                                                                       */
284*37da2899SCharles.Forsyth   /*    string       :: A pointer to the string's bytes.  Note that these  */
285*37da2899SCharles.Forsyth   /*                    are usually UTF-16 encoded characters.             */
286*37da2899SCharles.Forsyth   /*                                                                       */
287*37da2899SCharles.Forsyth   typedef struct  TT_NameEntryRec_
288*37da2899SCharles.Forsyth   {
289*37da2899SCharles.Forsyth     FT_UShort  platformID;
290*37da2899SCharles.Forsyth     FT_UShort  encodingID;
291*37da2899SCharles.Forsyth     FT_UShort  languageID;
292*37da2899SCharles.Forsyth     FT_UShort  nameID;
293*37da2899SCharles.Forsyth     FT_UShort  stringLength;
294*37da2899SCharles.Forsyth     FT_ULong   stringOffset;
295*37da2899SCharles.Forsyth 
296*37da2899SCharles.Forsyth     /* this last field is not defined in the spec */
297*37da2899SCharles.Forsyth     /* but used by the FreeType engine            */
298*37da2899SCharles.Forsyth 
299*37da2899SCharles.Forsyth     FT_Byte*   string;
300*37da2899SCharles.Forsyth 
301*37da2899SCharles.Forsyth   } TT_NameEntryRec, *TT_NameEntry;
302*37da2899SCharles.Forsyth 
303*37da2899SCharles.Forsyth 
304*37da2899SCharles.Forsyth   /*************************************************************************/
305*37da2899SCharles.Forsyth   /*                                                                       */
306*37da2899SCharles.Forsyth   /* <Struct>                                                              */
307*37da2899SCharles.Forsyth   /*    TT_NameTableRec                                                    */
308*37da2899SCharles.Forsyth   /*                                                                       */
309*37da2899SCharles.Forsyth   /* <Description>                                                         */
310*37da2899SCharles.Forsyth   /*    A structure modeling the TrueType name table.                      */
311*37da2899SCharles.Forsyth   /*                                                                       */
312*37da2899SCharles.Forsyth   /* <Fields>                                                              */
313*37da2899SCharles.Forsyth   /*    format         :: The format of the name table.                    */
314*37da2899SCharles.Forsyth   /*                                                                       */
315*37da2899SCharles.Forsyth   /*    numNameRecords :: The number of names in table.                    */
316*37da2899SCharles.Forsyth   /*                                                                       */
317*37da2899SCharles.Forsyth   /*    storageOffset  :: The offset of the name table in the `name'       */
318*37da2899SCharles.Forsyth   /*                      TrueType table.                                  */
319*37da2899SCharles.Forsyth   /*                                                                       */
320*37da2899SCharles.Forsyth   /*    names          :: An array of name records.                        */
321*37da2899SCharles.Forsyth   /*                                                                       */
322*37da2899SCharles.Forsyth   /*    stream         :: the file's input stream.                         */
323*37da2899SCharles.Forsyth   /*                                                                       */
324*37da2899SCharles.Forsyth   typedef struct  TT_NameTableRec_
325*37da2899SCharles.Forsyth   {
326*37da2899SCharles.Forsyth     FT_UShort         format;
327*37da2899SCharles.Forsyth     FT_UInt           numNameRecords;
328*37da2899SCharles.Forsyth     FT_UInt           storageOffset;
329*37da2899SCharles.Forsyth     TT_NameEntryRec*  names;
330*37da2899SCharles.Forsyth     FT_Stream         stream;
331*37da2899SCharles.Forsyth 
332*37da2899SCharles.Forsyth   } TT_NameTableRec, *TT_NameTable;
333*37da2899SCharles.Forsyth 
334*37da2899SCharles.Forsyth 
335*37da2899SCharles.Forsyth   /*************************************************************************/
336*37da2899SCharles.Forsyth   /*************************************************************************/
337*37da2899SCharles.Forsyth   /*************************************************************************/
338*37da2899SCharles.Forsyth   /***                                                                   ***/
339*37da2899SCharles.Forsyth   /***                                                                   ***/
340*37da2899SCharles.Forsyth   /***             OPTIONAL TRUETYPE/OPENTYPE TABLES DEFINITIONS         ***/
341*37da2899SCharles.Forsyth   /***                                                                   ***/
342*37da2899SCharles.Forsyth   /***                                                                   ***/
343*37da2899SCharles.Forsyth   /*************************************************************************/
344*37da2899SCharles.Forsyth   /*************************************************************************/
345*37da2899SCharles.Forsyth   /*************************************************************************/
346*37da2899SCharles.Forsyth 
347*37da2899SCharles.Forsyth 
348*37da2899SCharles.Forsyth   /*************************************************************************/
349*37da2899SCharles.Forsyth   /*                                                                       */
350*37da2899SCharles.Forsyth   /* <Struct>                                                              */
351*37da2899SCharles.Forsyth   /*    TT_GaspRangeRec                                                    */
352*37da2899SCharles.Forsyth   /*                                                                       */
353*37da2899SCharles.Forsyth   /* <Description>                                                         */
354*37da2899SCharles.Forsyth   /*    A tiny structure used to model a gasp range according to the       */
355*37da2899SCharles.Forsyth   /*    TrueType specification.                                            */
356*37da2899SCharles.Forsyth   /*                                                                       */
357*37da2899SCharles.Forsyth   /* <Fields>                                                              */
358*37da2899SCharles.Forsyth   /*    maxPPEM  :: The maximum ppem value to which `gaspFlag' applies.    */
359*37da2899SCharles.Forsyth   /*                                                                       */
360*37da2899SCharles.Forsyth   /*    gaspFlag :: A flag describing the grid-fitting and anti-aliasing   */
361*37da2899SCharles.Forsyth   /*                modes to be used.                                      */
362*37da2899SCharles.Forsyth   /*                                                                       */
363*37da2899SCharles.Forsyth   typedef struct  TT_GaspRangeRec_
364*37da2899SCharles.Forsyth   {
365*37da2899SCharles.Forsyth     FT_UShort  maxPPEM;
366*37da2899SCharles.Forsyth     FT_UShort  gaspFlag;
367*37da2899SCharles.Forsyth 
368*37da2899SCharles.Forsyth   } TT_GaspRangeRec, *TT_GaspRange;
369*37da2899SCharles.Forsyth 
370*37da2899SCharles.Forsyth 
371*37da2899SCharles.Forsyth #define TT_GASP_GRIDFIT  0x01
372*37da2899SCharles.Forsyth #define TT_GASP_DOGRAY   0x02
373*37da2899SCharles.Forsyth 
374*37da2899SCharles.Forsyth 
375*37da2899SCharles.Forsyth   /*************************************************************************/
376*37da2899SCharles.Forsyth   /*                                                                       */
377*37da2899SCharles.Forsyth   /* <Struct>                                                              */
378*37da2899SCharles.Forsyth   /*    TT_GaspRec                                                         */
379*37da2899SCharles.Forsyth   /*                                                                       */
380*37da2899SCharles.Forsyth   /* <Description>                                                         */
381*37da2899SCharles.Forsyth   /*    A structure modeling the TrueType `gasp' table used to specify     */
382*37da2899SCharles.Forsyth   /*    grid-fitting and anti-aliasing behaviour.                          */
383*37da2899SCharles.Forsyth   /*                                                                       */
384*37da2899SCharles.Forsyth   /* <Fields>                                                              */
385*37da2899SCharles.Forsyth   /*    version    :: The version number.                                  */
386*37da2899SCharles.Forsyth   /*                                                                       */
387*37da2899SCharles.Forsyth   /*    numRanges  :: The number of gasp ranges in table.                  */
388*37da2899SCharles.Forsyth   /*                                                                       */
389*37da2899SCharles.Forsyth   /*    gaspRanges :: An array of gasp ranges.                             */
390*37da2899SCharles.Forsyth   /*                                                                       */
391*37da2899SCharles.Forsyth   typedef struct  TT_Gasp_
392*37da2899SCharles.Forsyth   {
393*37da2899SCharles.Forsyth     FT_UShort     version;
394*37da2899SCharles.Forsyth     FT_UShort     numRanges;
395*37da2899SCharles.Forsyth     TT_GaspRange  gaspRanges;
396*37da2899SCharles.Forsyth 
397*37da2899SCharles.Forsyth   } TT_GaspRec;
398*37da2899SCharles.Forsyth 
399*37da2899SCharles.Forsyth 
400*37da2899SCharles.Forsyth   /*************************************************************************/
401*37da2899SCharles.Forsyth   /*                                                                       */
402*37da2899SCharles.Forsyth   /* <Struct>                                                              */
403*37da2899SCharles.Forsyth   /*    TT_HdmxEntryRec                                                    */
404*37da2899SCharles.Forsyth   /*                                                                       */
405*37da2899SCharles.Forsyth   /* <Description>                                                         */
406*37da2899SCharles.Forsyth   /*    A small structure used to model the pre-computed widths of a given */
407*37da2899SCharles.Forsyth   /*    size.  They are found in the `hdmx' table.                         */
408*37da2899SCharles.Forsyth   /*                                                                       */
409*37da2899SCharles.Forsyth   /* <Fields>                                                              */
410*37da2899SCharles.Forsyth   /*    ppem      :: The pixels per EM value at which these metrics apply. */
411*37da2899SCharles.Forsyth   /*                                                                       */
412*37da2899SCharles.Forsyth   /*    max_width :: The maximum advance width for this metric.            */
413*37da2899SCharles.Forsyth   /*                                                                       */
414*37da2899SCharles.Forsyth   /*    widths    :: An array of widths.  Note: These are 8-bit bytes.     */
415*37da2899SCharles.Forsyth   /*                                                                       */
416*37da2899SCharles.Forsyth   typedef struct  TT_HdmxEntryRec_
417*37da2899SCharles.Forsyth   {
418*37da2899SCharles.Forsyth     FT_Byte   ppem;
419*37da2899SCharles.Forsyth     FT_Byte   max_width;
420*37da2899SCharles.Forsyth     FT_Byte*  widths;
421*37da2899SCharles.Forsyth 
422*37da2899SCharles.Forsyth   } TT_HdmxEntryRec, *TT_HdmxEntry;
423*37da2899SCharles.Forsyth 
424*37da2899SCharles.Forsyth 
425*37da2899SCharles.Forsyth   /*************************************************************************/
426*37da2899SCharles.Forsyth   /*                                                                       */
427*37da2899SCharles.Forsyth   /* <Struct>                                                              */
428*37da2899SCharles.Forsyth   /*    TT_HdmxRec                                                         */
429*37da2899SCharles.Forsyth   /*                                                                       */
430*37da2899SCharles.Forsyth   /* <Description>                                                         */
431*37da2899SCharles.Forsyth   /*    A structure used to model the `hdmx' table, which contains         */
432*37da2899SCharles.Forsyth   /*    pre-computed widths for a set of given sizes/dimensions.           */
433*37da2899SCharles.Forsyth   /*                                                                       */
434*37da2899SCharles.Forsyth   /* <Fields>                                                              */
435*37da2899SCharles.Forsyth   /*    version     :: The version number.                                 */
436*37da2899SCharles.Forsyth   /*                                                                       */
437*37da2899SCharles.Forsyth   /*    num_records :: The number of hdmx records.                         */
438*37da2899SCharles.Forsyth   /*                                                                       */
439*37da2899SCharles.Forsyth   /*    records     :: An array of hdmx records.                           */
440*37da2899SCharles.Forsyth   /*                                                                       */
441*37da2899SCharles.Forsyth   typedef struct  TT_HdmxRec_
442*37da2899SCharles.Forsyth   {
443*37da2899SCharles.Forsyth     FT_UShort     version;
444*37da2899SCharles.Forsyth     FT_Short      num_records;
445*37da2899SCharles.Forsyth     TT_HdmxEntry  records;
446*37da2899SCharles.Forsyth 
447*37da2899SCharles.Forsyth   } TT_HdmxRec, *TT_Hdmx;
448*37da2899SCharles.Forsyth 
449*37da2899SCharles.Forsyth 
450*37da2899SCharles.Forsyth   /*************************************************************************/
451*37da2899SCharles.Forsyth   /*                                                                       */
452*37da2899SCharles.Forsyth   /* <Struct>                                                              */
453*37da2899SCharles.Forsyth   /*    TT_Kern0_PairRec                                                   */
454*37da2899SCharles.Forsyth   /*                                                                       */
455*37da2899SCharles.Forsyth   /* <Description>                                                         */
456*37da2899SCharles.Forsyth   /*    A structure used to model a kerning pair for the kerning table     */
457*37da2899SCharles.Forsyth   /*    format 0.  The engine now loads this table if it finds one in the  */
458*37da2899SCharles.Forsyth   /*    font file.                                                         */
459*37da2899SCharles.Forsyth   /*                                                                       */
460*37da2899SCharles.Forsyth   /* <Fields>                                                              */
461*37da2899SCharles.Forsyth   /*    left  :: The index of the left glyph in pair.                      */
462*37da2899SCharles.Forsyth   /*                                                                       */
463*37da2899SCharles.Forsyth   /*    right :: The index of the right glyph in pair.                     */
464*37da2899SCharles.Forsyth   /*                                                                       */
465*37da2899SCharles.Forsyth   /*    value :: The kerning distance.  A positive value spaces the        */
466*37da2899SCharles.Forsyth   /*             glyphs, a negative one makes them closer.                 */
467*37da2899SCharles.Forsyth   /*                                                                       */
468*37da2899SCharles.Forsyth   typedef struct  TT_Kern0_PairRec_
469*37da2899SCharles.Forsyth   {
470*37da2899SCharles.Forsyth     FT_UShort  left;   /* index of left  glyph in pair */
471*37da2899SCharles.Forsyth     FT_UShort  right;  /* index of right glyph in pair */
472*37da2899SCharles.Forsyth     FT_FWord   value;  /* kerning value                */
473*37da2899SCharles.Forsyth 
474*37da2899SCharles.Forsyth   } TT_Kern0_PairRec, *TT_Kern0_Pair;
475*37da2899SCharles.Forsyth 
476*37da2899SCharles.Forsyth 
477*37da2899SCharles.Forsyth   /*************************************************************************/
478*37da2899SCharles.Forsyth   /*************************************************************************/
479*37da2899SCharles.Forsyth   /*************************************************************************/
480*37da2899SCharles.Forsyth   /***                                                                   ***/
481*37da2899SCharles.Forsyth   /***                                                                   ***/
482*37da2899SCharles.Forsyth   /***                    EMBEDDED BITMAPS SUPPORT                       ***/
483*37da2899SCharles.Forsyth   /***                                                                   ***/
484*37da2899SCharles.Forsyth   /***                                                                   ***/
485*37da2899SCharles.Forsyth   /*************************************************************************/
486*37da2899SCharles.Forsyth   /*************************************************************************/
487*37da2899SCharles.Forsyth   /*************************************************************************/
488*37da2899SCharles.Forsyth 
489*37da2899SCharles.Forsyth 
490*37da2899SCharles.Forsyth   /*************************************************************************/
491*37da2899SCharles.Forsyth   /*                                                                       */
492*37da2899SCharles.Forsyth   /* <Struct>                                                              */
493*37da2899SCharles.Forsyth   /*    TT_SBit_MetricsRec                                                 */
494*37da2899SCharles.Forsyth   /*                                                                       */
495*37da2899SCharles.Forsyth   /* <Description>                                                         */
496*37da2899SCharles.Forsyth   /*    A structure used to hold the big metrics of a given glyph bitmap   */
497*37da2899SCharles.Forsyth   /*    in a TrueType or OpenType font.  These are usually found in the    */
498*37da2899SCharles.Forsyth   /*    `EBDT' (Microsoft) or `bloc' (Apple) table.                        */
499*37da2899SCharles.Forsyth   /*                                                                       */
500*37da2899SCharles.Forsyth   /* <Fields>                                                              */
501*37da2899SCharles.Forsyth   /*    height       :: The glyph height in pixels.                        */
502*37da2899SCharles.Forsyth   /*                                                                       */
503*37da2899SCharles.Forsyth   /*    width        :: The glyph width in pixels.                         */
504*37da2899SCharles.Forsyth   /*                                                                       */
505*37da2899SCharles.Forsyth   /*    horiBearingX :: The horizontal left bearing.                       */
506*37da2899SCharles.Forsyth   /*                                                                       */
507*37da2899SCharles.Forsyth   /*    horiBearingY :: The horizontal top bearing.                        */
508*37da2899SCharles.Forsyth   /*                                                                       */
509*37da2899SCharles.Forsyth   /*    horiAdvance  :: The horizontal advance.                            */
510*37da2899SCharles.Forsyth   /*                                                                       */
511*37da2899SCharles.Forsyth   /*    vertBearingX :: The vertical left bearing.                         */
512*37da2899SCharles.Forsyth   /*                                                                       */
513*37da2899SCharles.Forsyth   /*    vertBearingY :: The vertical top bearing.                          */
514*37da2899SCharles.Forsyth   /*                                                                       */
515*37da2899SCharles.Forsyth   /*    vertAdvance  :: The vertical advance.                              */
516*37da2899SCharles.Forsyth   /*                                                                       */
517*37da2899SCharles.Forsyth   typedef struct  TT_SBit_MetricsRec_
518*37da2899SCharles.Forsyth   {
519*37da2899SCharles.Forsyth     FT_Byte  height;
520*37da2899SCharles.Forsyth     FT_Byte  width;
521*37da2899SCharles.Forsyth 
522*37da2899SCharles.Forsyth     FT_Char  horiBearingX;
523*37da2899SCharles.Forsyth     FT_Char  horiBearingY;
524*37da2899SCharles.Forsyth     FT_Byte  horiAdvance;
525*37da2899SCharles.Forsyth 
526*37da2899SCharles.Forsyth     FT_Char  vertBearingX;
527*37da2899SCharles.Forsyth     FT_Char  vertBearingY;
528*37da2899SCharles.Forsyth     FT_Byte  vertAdvance;
529*37da2899SCharles.Forsyth 
530*37da2899SCharles.Forsyth   } TT_SBit_MetricsRec, *TT_SBit_Metrics;
531*37da2899SCharles.Forsyth 
532*37da2899SCharles.Forsyth 
533*37da2899SCharles.Forsyth   /*************************************************************************/
534*37da2899SCharles.Forsyth   /*                                                                       */
535*37da2899SCharles.Forsyth   /* <Struct>                                                              */
536*37da2899SCharles.Forsyth   /*    TT_SBit_SmallMetricsRec                                            */
537*37da2899SCharles.Forsyth   /*                                                                       */
538*37da2899SCharles.Forsyth   /* <Description>                                                         */
539*37da2899SCharles.Forsyth   /*    A structure used to hold the small metrics of a given glyph bitmap */
540*37da2899SCharles.Forsyth   /*    in a TrueType or OpenType font.  These are usually found in the    */
541*37da2899SCharles.Forsyth   /*    `EBDT' (Microsoft) or the `bdat' (Apple) table.                    */
542*37da2899SCharles.Forsyth   /*                                                                       */
543*37da2899SCharles.Forsyth   /* <Fields>                                                              */
544*37da2899SCharles.Forsyth   /*    height   :: The glyph height in pixels.                            */
545*37da2899SCharles.Forsyth   /*                                                                       */
546*37da2899SCharles.Forsyth   /*    width    :: The glyph width in pixels.                             */
547*37da2899SCharles.Forsyth   /*                                                                       */
548*37da2899SCharles.Forsyth   /*    bearingX :: The left-side bearing.                                 */
549*37da2899SCharles.Forsyth   /*                                                                       */
550*37da2899SCharles.Forsyth   /*    bearingY :: The top-side bearing.                                  */
551*37da2899SCharles.Forsyth   /*                                                                       */
552*37da2899SCharles.Forsyth   /*    advance  :: The advance width or height.                           */
553*37da2899SCharles.Forsyth   /*                                                                       */
554*37da2899SCharles.Forsyth   typedef struct  TT_SBit_Small_Metrics_
555*37da2899SCharles.Forsyth   {
556*37da2899SCharles.Forsyth     FT_Byte  height;
557*37da2899SCharles.Forsyth     FT_Byte  width;
558*37da2899SCharles.Forsyth 
559*37da2899SCharles.Forsyth     FT_Char  bearingX;
560*37da2899SCharles.Forsyth     FT_Char  bearingY;
561*37da2899SCharles.Forsyth     FT_Byte  advance;
562*37da2899SCharles.Forsyth 
563*37da2899SCharles.Forsyth   } TT_SBit_SmallMetricsRec, *TT_SBit_SmallMetrics;
564*37da2899SCharles.Forsyth 
565*37da2899SCharles.Forsyth 
566*37da2899SCharles.Forsyth   /*************************************************************************/
567*37da2899SCharles.Forsyth   /*                                                                       */
568*37da2899SCharles.Forsyth   /* <Struct>                                                              */
569*37da2899SCharles.Forsyth   /*    TT_SBit_LineMetricsRec                                             */
570*37da2899SCharles.Forsyth   /*                                                                       */
571*37da2899SCharles.Forsyth   /* <Description>                                                         */
572*37da2899SCharles.Forsyth   /*    A structure used to describe the text line metrics of a given      */
573*37da2899SCharles.Forsyth   /*    bitmap strike, for either a horizontal or vertical layout.         */
574*37da2899SCharles.Forsyth   /*                                                                       */
575*37da2899SCharles.Forsyth   /* <Fields>                                                              */
576*37da2899SCharles.Forsyth   /*    ascender                :: The ascender in pixels.                 */
577*37da2899SCharles.Forsyth   /*                                                                       */
578*37da2899SCharles.Forsyth   /*    descender               :: The descender in pixels.                */
579*37da2899SCharles.Forsyth   /*                                                                       */
580*37da2899SCharles.Forsyth   /*    max_width               :: The maximum glyph width in pixels.      */
581*37da2899SCharles.Forsyth   /*                                                                       */
582*37da2899SCharles.Forsyth   /*    caret_slope_enumerator  :: Rise of the caret slope, typically set  */
583*37da2899SCharles.Forsyth   /*                               to 1 for non-italic fonts.              */
584*37da2899SCharles.Forsyth   /*                                                                       */
585*37da2899SCharles.Forsyth   /*    caret_slope_denominator :: Rise of the caret slope, typically set  */
586*37da2899SCharles.Forsyth   /*                               to 0 for non-italic fonts.              */
587*37da2899SCharles.Forsyth   /*                                                                       */
588*37da2899SCharles.Forsyth   /*    caret_offset            :: Offset in pixels to move the caret for  */
589*37da2899SCharles.Forsyth   /*                               proper positioning.                     */
590*37da2899SCharles.Forsyth   /*                                                                       */
591*37da2899SCharles.Forsyth   /*    min_origin_SB           :: Minimum of horiBearingX (resp.          */
592*37da2899SCharles.Forsyth   /*                               vertBearingY).                          */
593*37da2899SCharles.Forsyth   /*    min_advance_SB          :: Minimum of                              */
594*37da2899SCharles.Forsyth   /*                                                                       */
595*37da2899SCharles.Forsyth   /*                                 horizontal advance -                  */
596*37da2899SCharles.Forsyth   /*                                   ( horiBearingX + width )            */
597*37da2899SCharles.Forsyth   /*                                                                       */
598*37da2899SCharles.Forsyth   /*                               resp.                                   */
599*37da2899SCharles.Forsyth   /*                                                                       */
600*37da2899SCharles.Forsyth   /*                                 vertical advance -                    */
601*37da2899SCharles.Forsyth   /*                                   ( vertBearingY + height )           */
602*37da2899SCharles.Forsyth   /*                                                                       */
603*37da2899SCharles.Forsyth   /*    max_before_BL           :: Maximum of horiBearingY (resp.          */
604*37da2899SCharles.Forsyth   /*                               vertBearingY).                          */
605*37da2899SCharles.Forsyth   /*                                                                       */
606*37da2899SCharles.Forsyth   /*    min_after_BL            :: Minimum of                              */
607*37da2899SCharles.Forsyth   /*                                                                       */
608*37da2899SCharles.Forsyth   /*                                 horiBearingY - height                 */
609*37da2899SCharles.Forsyth   /*                                                                       */
610*37da2899SCharles.Forsyth   /*                               resp.                                   */
611*37da2899SCharles.Forsyth   /*                                                                       */
612*37da2899SCharles.Forsyth   /*                                 vertBearingX - width                  */
613*37da2899SCharles.Forsyth   /*                                                                       */
614*37da2899SCharles.Forsyth   /*    pads                    :: Unused (to make the size of the record  */
615*37da2899SCharles.Forsyth   /*                               a multiple of 32 bits.                  */
616*37da2899SCharles.Forsyth   /*                                                                       */
617*37da2899SCharles.Forsyth   typedef struct  TT_SBit_LineMetricsRec_
618*37da2899SCharles.Forsyth   {
619*37da2899SCharles.Forsyth     FT_Char  ascender;
620*37da2899SCharles.Forsyth     FT_Char  descender;
621*37da2899SCharles.Forsyth     FT_Byte  max_width;
622*37da2899SCharles.Forsyth     FT_Char  caret_slope_numerator;
623*37da2899SCharles.Forsyth     FT_Char  caret_slope_denominator;
624*37da2899SCharles.Forsyth     FT_Char  caret_offset;
625*37da2899SCharles.Forsyth     FT_Char  min_origin_SB;
626*37da2899SCharles.Forsyth     FT_Char  min_advance_SB;
627*37da2899SCharles.Forsyth     FT_Char  max_before_BL;
628*37da2899SCharles.Forsyth     FT_Char  min_after_BL;
629*37da2899SCharles.Forsyth     FT_Char  pads[2];
630*37da2899SCharles.Forsyth 
631*37da2899SCharles.Forsyth   } TT_SBit_LineMetricsRec, *TT_SBit_LineMetrics;
632*37da2899SCharles.Forsyth 
633*37da2899SCharles.Forsyth 
634*37da2899SCharles.Forsyth   /*************************************************************************/
635*37da2899SCharles.Forsyth   /*                                                                       */
636*37da2899SCharles.Forsyth   /* <Struct>                                                              */
637*37da2899SCharles.Forsyth   /*    TT_SBit_RangeRec                                                   */
638*37da2899SCharles.Forsyth   /*                                                                       */
639*37da2899SCharles.Forsyth   /* <Description>                                                         */
640*37da2899SCharles.Forsyth   /*    A TrueType/OpenType subIndexTable as defined in the `EBLC'         */
641*37da2899SCharles.Forsyth   /*    (Microsoft) or `bloc' (Apple) tables.                              */
642*37da2899SCharles.Forsyth   /*                                                                       */
643*37da2899SCharles.Forsyth   /* <Fields>                                                              */
644*37da2899SCharles.Forsyth   /*    first_glyph   :: The first glyph index in the range.               */
645*37da2899SCharles.Forsyth   /*                                                                       */
646*37da2899SCharles.Forsyth   /*    last_glyph    :: The last glyph index in the range.                */
647*37da2899SCharles.Forsyth   /*                                                                       */
648*37da2899SCharles.Forsyth   /*    index_format  :: The format of index table.  Valid values are 1    */
649*37da2899SCharles.Forsyth   /*                     to 5.                                             */
650*37da2899SCharles.Forsyth   /*                                                                       */
651*37da2899SCharles.Forsyth   /*    image_format  :: The format of `EBDT' image data.                  */
652*37da2899SCharles.Forsyth   /*                                                                       */
653*37da2899SCharles.Forsyth   /*    image_offset  :: The offset to image data in `EBDT'.               */
654*37da2899SCharles.Forsyth   /*                                                                       */
655*37da2899SCharles.Forsyth   /*    image_size    :: For index formats 2 and 5.  This is the size in   */
656*37da2899SCharles.Forsyth   /*                     bytes of each glyph bitmap.                       */
657*37da2899SCharles.Forsyth   /*                                                                       */
658*37da2899SCharles.Forsyth   /*    big_metrics   :: For index formats 2 and 5.  This is the big       */
659*37da2899SCharles.Forsyth   /*                     metrics for each glyph bitmap.                    */
660*37da2899SCharles.Forsyth   /*                                                                       */
661*37da2899SCharles.Forsyth   /*    num_glyphs    :: For index formats 4 and 5.  This is the number of */
662*37da2899SCharles.Forsyth   /*                     glyphs in the code array.                         */
663*37da2899SCharles.Forsyth   /*                                                                       */
664*37da2899SCharles.Forsyth   /*    glyph_offsets :: For index formats 1 and 3.                        */
665*37da2899SCharles.Forsyth   /*                                                                       */
666*37da2899SCharles.Forsyth   /*    glyph_codes   :: For index formats 4 and 5.                        */
667*37da2899SCharles.Forsyth   /*                                                                       */
668*37da2899SCharles.Forsyth   /*    table_offset  :: The offset of the index table in the `EBLC'       */
669*37da2899SCharles.Forsyth   /*                     table.  Only used during strike loading.          */
670*37da2899SCharles.Forsyth   /*                                                                       */
671*37da2899SCharles.Forsyth   typedef struct  TT_SBit_RangeRec
672*37da2899SCharles.Forsyth   {
673*37da2899SCharles.Forsyth     FT_UShort           first_glyph;
674*37da2899SCharles.Forsyth     FT_UShort           last_glyph;
675*37da2899SCharles.Forsyth 
676*37da2899SCharles.Forsyth     FT_UShort           index_format;
677*37da2899SCharles.Forsyth     FT_UShort           image_format;
678*37da2899SCharles.Forsyth     FT_ULong            image_offset;
679*37da2899SCharles.Forsyth 
680*37da2899SCharles.Forsyth     FT_ULong            image_size;
681*37da2899SCharles.Forsyth     TT_SBit_MetricsRec  metrics;
682*37da2899SCharles.Forsyth     FT_ULong            num_glyphs;
683*37da2899SCharles.Forsyth 
684*37da2899SCharles.Forsyth     FT_ULong*           glyph_offsets;
685*37da2899SCharles.Forsyth     FT_UShort*          glyph_codes;
686*37da2899SCharles.Forsyth 
687*37da2899SCharles.Forsyth     FT_ULong            table_offset;
688*37da2899SCharles.Forsyth 
689*37da2899SCharles.Forsyth   } TT_SBit_RangeRec, *TT_SBit_Range;
690*37da2899SCharles.Forsyth 
691*37da2899SCharles.Forsyth 
692*37da2899SCharles.Forsyth   /*************************************************************************/
693*37da2899SCharles.Forsyth   /*                                                                       */
694*37da2899SCharles.Forsyth   /* <Struct>                                                              */
695*37da2899SCharles.Forsyth   /*    TT_SBit_StrikeRec                                                  */
696*37da2899SCharles.Forsyth   /*                                                                       */
697*37da2899SCharles.Forsyth   /* <Description>                                                         */
698*37da2899SCharles.Forsyth   /*    A structure used describe a given bitmap strike in the `EBLC'      */
699*37da2899SCharles.Forsyth   /*    (Microsoft) or `bloc' (Apple) tables.                              */
700*37da2899SCharles.Forsyth   /*                                                                       */
701*37da2899SCharles.Forsyth   /* <Fields>                                                              */
702*37da2899SCharles.Forsyth   /*   num_index_ranges :: The number of index ranges.                     */
703*37da2899SCharles.Forsyth   /*                                                                       */
704*37da2899SCharles.Forsyth   /*   index_ranges     :: An array of glyph index ranges.                 */
705*37da2899SCharles.Forsyth   /*                                                                       */
706*37da2899SCharles.Forsyth   /*   color_ref        :: Unused.  `color_ref' is put in for future       */
707*37da2899SCharles.Forsyth   /*                       enhancements, but these fields are already      */
708*37da2899SCharles.Forsyth   /*                       in use by other platforms (e.g. Newton).        */
709*37da2899SCharles.Forsyth   /*                       For details, please see                         */
710*37da2899SCharles.Forsyth   /*                                                                       */
711*37da2899SCharles.Forsyth   /*                         http://fonts.apple.com/                       */
712*37da2899SCharles.Forsyth   /*                                TTRefMan/RM06/Chap6bloc.html           */
713*37da2899SCharles.Forsyth   /*                                                                       */
714*37da2899SCharles.Forsyth   /*   hori             :: The line metrics for horizontal layouts.        */
715*37da2899SCharles.Forsyth   /*                                                                       */
716*37da2899SCharles.Forsyth   /*   vert             :: The line metrics for vertical layouts.          */
717*37da2899SCharles.Forsyth   /*                                                                       */
718*37da2899SCharles.Forsyth   /*   start_glyph      :: The lowest glyph index for this strike.         */
719*37da2899SCharles.Forsyth   /*                                                                       */
720*37da2899SCharles.Forsyth   /*   end_glyph        :: The highest glyph index for this strike.        */
721*37da2899SCharles.Forsyth   /*                                                                       */
722*37da2899SCharles.Forsyth   /*   x_ppem           :: The number of horizontal pixels per EM.         */
723*37da2899SCharles.Forsyth   /*                                                                       */
724*37da2899SCharles.Forsyth   /*   y_ppem           :: The number of vertical pixels per EM.           */
725*37da2899SCharles.Forsyth   /*                                                                       */
726*37da2899SCharles.Forsyth   /*   bit_depth        :: The bit depth.  Valid values are 1, 2, 4,       */
727*37da2899SCharles.Forsyth   /*                       and 8.                                          */
728*37da2899SCharles.Forsyth   /*                                                                       */
729*37da2899SCharles.Forsyth   /*   flags            :: Is this a vertical or horizontal strike?  For   */
730*37da2899SCharles.Forsyth   /*                       details, please see                             */
731*37da2899SCharles.Forsyth   /*                                                                       */
732*37da2899SCharles.Forsyth   /*                         http://fonts.apple.com/                       */
733*37da2899SCharles.Forsyth   /*                                TTRefMan/RM06/Chap6bloc.html           */
734*37da2899SCharles.Forsyth   /*                                                                       */
735*37da2899SCharles.Forsyth   typedef struct  TT_SBit_StrikeRec_
736*37da2899SCharles.Forsyth   {
737*37da2899SCharles.Forsyth     FT_Int                  num_ranges;
738*37da2899SCharles.Forsyth     TT_SBit_Range           sbit_ranges;
739*37da2899SCharles.Forsyth     FT_ULong                ranges_offset;
740*37da2899SCharles.Forsyth 
741*37da2899SCharles.Forsyth     FT_ULong                color_ref;
742*37da2899SCharles.Forsyth 
743*37da2899SCharles.Forsyth     TT_SBit_LineMetricsRec  hori;
744*37da2899SCharles.Forsyth     TT_SBit_LineMetricsRec  vert;
745*37da2899SCharles.Forsyth 
746*37da2899SCharles.Forsyth     FT_UShort               start_glyph;
747*37da2899SCharles.Forsyth     FT_UShort               end_glyph;
748*37da2899SCharles.Forsyth 
749*37da2899SCharles.Forsyth     FT_Byte                 x_ppem;
750*37da2899SCharles.Forsyth     FT_Byte                 y_ppem;
751*37da2899SCharles.Forsyth 
752*37da2899SCharles.Forsyth     FT_Byte                 bit_depth;
753*37da2899SCharles.Forsyth     FT_Char                 flags;
754*37da2899SCharles.Forsyth 
755*37da2899SCharles.Forsyth   } TT_SBit_StrikeRec, *TT_SBit_Strike;
756*37da2899SCharles.Forsyth 
757*37da2899SCharles.Forsyth 
758*37da2899SCharles.Forsyth   /*************************************************************************/
759*37da2899SCharles.Forsyth   /*                                                                       */
760*37da2899SCharles.Forsyth   /* <Struct>                                                              */
761*37da2899SCharles.Forsyth   /*    TT_SBit_ComponentRec                                               */
762*37da2899SCharles.Forsyth   /*                                                                       */
763*37da2899SCharles.Forsyth   /* <Description>                                                         */
764*37da2899SCharles.Forsyth   /*    A simple structure to describe a compound sbit element.            */
765*37da2899SCharles.Forsyth   /*                                                                       */
766*37da2899SCharles.Forsyth   /* <Fields>                                                              */
767*37da2899SCharles.Forsyth   /*    glyph_code :: The element's glyph index.                           */
768*37da2899SCharles.Forsyth   /*                                                                       */
769*37da2899SCharles.Forsyth   /*    x_offset   :: The element's left bearing.                          */
770*37da2899SCharles.Forsyth   /*                                                                       */
771*37da2899SCharles.Forsyth   /*    y_offset   :: The element's top bearing.                           */
772*37da2899SCharles.Forsyth   /*                                                                       */
773*37da2899SCharles.Forsyth   typedef struct  TT_SBit_ComponentRec_
774*37da2899SCharles.Forsyth   {
775*37da2899SCharles.Forsyth     FT_UShort  glyph_code;
776*37da2899SCharles.Forsyth     FT_Char    x_offset;
777*37da2899SCharles.Forsyth     FT_Char    y_offset;
778*37da2899SCharles.Forsyth 
779*37da2899SCharles.Forsyth   } TT_SBit_ComponentRec, *TT_SBit_Component;
780*37da2899SCharles.Forsyth 
781*37da2899SCharles.Forsyth 
782*37da2899SCharles.Forsyth   /*************************************************************************/
783*37da2899SCharles.Forsyth   /*                                                                       */
784*37da2899SCharles.Forsyth   /* <Struct>                                                              */
785*37da2899SCharles.Forsyth   /*    TT_SBit_ScaleRec                                                   */
786*37da2899SCharles.Forsyth   /*                                                                       */
787*37da2899SCharles.Forsyth   /* <Description>                                                         */
788*37da2899SCharles.Forsyth   /*    A structure used describe a given bitmap scaling table, as defined */
789*37da2899SCharles.Forsyth   /*    in the `EBSC' table.                                               */
790*37da2899SCharles.Forsyth   /*                                                                       */
791*37da2899SCharles.Forsyth   /* <Fields>                                                              */
792*37da2899SCharles.Forsyth   /*    hori              :: The horizontal line metrics.                  */
793*37da2899SCharles.Forsyth   /*                                                                       */
794*37da2899SCharles.Forsyth   /*    vert              :: The vertical line metrics.                    */
795*37da2899SCharles.Forsyth   /*                                                                       */
796*37da2899SCharles.Forsyth   /*    x_ppem            :: The number of horizontal pixels per EM.       */
797*37da2899SCharles.Forsyth   /*                                                                       */
798*37da2899SCharles.Forsyth   /*    y_ppem            :: The number of vertical pixels per EM.         */
799*37da2899SCharles.Forsyth   /*                                                                       */
800*37da2899SCharles.Forsyth   /*    x_ppem_substitute :: Substitution x_ppem value.                    */
801*37da2899SCharles.Forsyth   /*                                                                       */
802*37da2899SCharles.Forsyth   /*    y_ppem_substitute :: Substitution y_ppem value.                    */
803*37da2899SCharles.Forsyth   /*                                                                       */
804*37da2899SCharles.Forsyth   typedef struct  TT_SBit_ScaleRec_
805*37da2899SCharles.Forsyth   {
806*37da2899SCharles.Forsyth     TT_SBit_LineMetricsRec  hori;
807*37da2899SCharles.Forsyth     TT_SBit_LineMetricsRec  vert;
808*37da2899SCharles.Forsyth 
809*37da2899SCharles.Forsyth     FT_Byte                 x_ppem;
810*37da2899SCharles.Forsyth     FT_Byte                 y_ppem;
811*37da2899SCharles.Forsyth 
812*37da2899SCharles.Forsyth     FT_Byte                 x_ppem_substitute;
813*37da2899SCharles.Forsyth     FT_Byte                 y_ppem_substitute;
814*37da2899SCharles.Forsyth 
815*37da2899SCharles.Forsyth   } TT_SBit_ScaleRec, *TT_SBit_Scale;
816*37da2899SCharles.Forsyth 
817*37da2899SCharles.Forsyth 
818*37da2899SCharles.Forsyth   /*************************************************************************/
819*37da2899SCharles.Forsyth   /*************************************************************************/
820*37da2899SCharles.Forsyth   /*************************************************************************/
821*37da2899SCharles.Forsyth   /***                                                                   ***/
822*37da2899SCharles.Forsyth   /***                                                                   ***/
823*37da2899SCharles.Forsyth   /***                  POSTSCRIPT GLYPH NAMES SUPPORT                   ***/
824*37da2899SCharles.Forsyth   /***                                                                   ***/
825*37da2899SCharles.Forsyth   /***                                                                   ***/
826*37da2899SCharles.Forsyth   /*************************************************************************/
827*37da2899SCharles.Forsyth   /*************************************************************************/
828*37da2899SCharles.Forsyth   /*************************************************************************/
829*37da2899SCharles.Forsyth 
830*37da2899SCharles.Forsyth 
831*37da2899SCharles.Forsyth   /*************************************************************************/
832*37da2899SCharles.Forsyth   /*                                                                       */
833*37da2899SCharles.Forsyth   /* <Struct>                                                              */
834*37da2899SCharles.Forsyth   /*    TT_Post_20Rec                                                      */
835*37da2899SCharles.Forsyth   /*                                                                       */
836*37da2899SCharles.Forsyth   /* <Description>                                                         */
837*37da2899SCharles.Forsyth   /*    Postscript names sub-table, format 2.0.  Stores the PS name of     */
838*37da2899SCharles.Forsyth   /*    each glyph in the font face.                                       */
839*37da2899SCharles.Forsyth   /*                                                                       */
840*37da2899SCharles.Forsyth   /* <Fields>                                                              */
841*37da2899SCharles.Forsyth   /*    num_glyphs    :: The number of named glyphs in the table.          */
842*37da2899SCharles.Forsyth   /*                                                                       */
843*37da2899SCharles.Forsyth   /*    num_names     :: The number of PS names stored in the table.       */
844*37da2899SCharles.Forsyth   /*                                                                       */
845*37da2899SCharles.Forsyth   /*    glyph_indices :: The indices of the glyphs in the names arrays.    */
846*37da2899SCharles.Forsyth   /*                                                                       */
847*37da2899SCharles.Forsyth   /*    glyph_names   :: The PS names not in Mac Encoding.                 */
848*37da2899SCharles.Forsyth   /*                                                                       */
849*37da2899SCharles.Forsyth   typedef struct  TT_Post_20Rec_
850*37da2899SCharles.Forsyth   {
851*37da2899SCharles.Forsyth     FT_UShort   num_glyphs;
852*37da2899SCharles.Forsyth     FT_UShort   num_names;
853*37da2899SCharles.Forsyth     FT_UShort*  glyph_indices;
854*37da2899SCharles.Forsyth     FT_Char**   glyph_names;
855*37da2899SCharles.Forsyth 
856*37da2899SCharles.Forsyth   } TT_Post_20Rec, *TT_Post_20;
857*37da2899SCharles.Forsyth 
858*37da2899SCharles.Forsyth 
859*37da2899SCharles.Forsyth   /*************************************************************************/
860*37da2899SCharles.Forsyth   /*                                                                       */
861*37da2899SCharles.Forsyth   /* <Struct>                                                              */
862*37da2899SCharles.Forsyth   /*    TT_Post_25Rec                                                      */
863*37da2899SCharles.Forsyth   /*                                                                       */
864*37da2899SCharles.Forsyth   /* <Description>                                                         */
865*37da2899SCharles.Forsyth   /*    Postscript names sub-table, format 2.5.  Stores the PS name of     */
866*37da2899SCharles.Forsyth   /*    each glyph in the font face.                                       */
867*37da2899SCharles.Forsyth   /*                                                                       */
868*37da2899SCharles.Forsyth   /* <Fields>                                                              */
869*37da2899SCharles.Forsyth   /*    num_glyphs :: The number of glyphs in the table.                   */
870*37da2899SCharles.Forsyth   /*                                                                       */
871*37da2899SCharles.Forsyth   /*    offsets    :: An array of signed offsets in a normal Mac           */
872*37da2899SCharles.Forsyth   /*                  Postscript name encoding.                            */
873*37da2899SCharles.Forsyth   /*                                                                       */
874*37da2899SCharles.Forsyth   typedef struct  TT_Post_25_
875*37da2899SCharles.Forsyth   {
876*37da2899SCharles.Forsyth     FT_UShort  num_glyphs;
877*37da2899SCharles.Forsyth     FT_Char*   offsets;
878*37da2899SCharles.Forsyth 
879*37da2899SCharles.Forsyth   } TT_Post_25Rec, *TT_Post_25;
880*37da2899SCharles.Forsyth 
881*37da2899SCharles.Forsyth 
882*37da2899SCharles.Forsyth   /*************************************************************************/
883*37da2899SCharles.Forsyth   /*                                                                       */
884*37da2899SCharles.Forsyth   /* <Struct>                                                              */
885*37da2899SCharles.Forsyth   /*    TT_Post_NamesRec                                                   */
886*37da2899SCharles.Forsyth   /*                                                                       */
887*37da2899SCharles.Forsyth   /* <Description>                                                         */
888*37da2899SCharles.Forsyth   /*    Postscript names table, either format 2.0 or 2.5.                  */
889*37da2899SCharles.Forsyth   /*                                                                       */
890*37da2899SCharles.Forsyth   /* <Fields>                                                              */
891*37da2899SCharles.Forsyth   /*    loaded    :: A flag to indicate whether the PS names are loaded.   */
892*37da2899SCharles.Forsyth   /*                                                                       */
893*37da2899SCharles.Forsyth   /*    format_20 :: The sub-table used for format 2.0.                    */
894*37da2899SCharles.Forsyth   /*                                                                       */
895*37da2899SCharles.Forsyth   /*    format_25 :: The sub-table used for format 2.5.                    */
896*37da2899SCharles.Forsyth   /*                                                                       */
897*37da2899SCharles.Forsyth   typedef struct  TT_Post_NamesRec_
898*37da2899SCharles.Forsyth   {
899*37da2899SCharles.Forsyth     FT_Bool  loaded;
900*37da2899SCharles.Forsyth 
901*37da2899SCharles.Forsyth     union
902*37da2899SCharles.Forsyth     {
903*37da2899SCharles.Forsyth       TT_Post_20Rec  format_20;
904*37da2899SCharles.Forsyth       TT_Post_25Rec  format_25;
905*37da2899SCharles.Forsyth 
906*37da2899SCharles.Forsyth     } names;
907*37da2899SCharles.Forsyth 
908*37da2899SCharles.Forsyth   } TT_Post_NamesRec, *TT_Post_Names;
909*37da2899SCharles.Forsyth 
910*37da2899SCharles.Forsyth 
911*37da2899SCharles.Forsyth   /*************************************************************************/
912*37da2899SCharles.Forsyth   /*************************************************************************/
913*37da2899SCharles.Forsyth   /*************************************************************************/
914*37da2899SCharles.Forsyth   /***                                                                   ***/
915*37da2899SCharles.Forsyth   /***                                                                   ***/
916*37da2899SCharles.Forsyth   /***                  TRUETYPE CHARMAPS SUPPORT                        ***/
917*37da2899SCharles.Forsyth   /***                                                                   ***/
918*37da2899SCharles.Forsyth   /***                                                                   ***/
919*37da2899SCharles.Forsyth   /*************************************************************************/
920*37da2899SCharles.Forsyth   /*************************************************************************/
921*37da2899SCharles.Forsyth   /*************************************************************************/
922*37da2899SCharles.Forsyth 
923*37da2899SCharles.Forsyth 
924*37da2899SCharles.Forsyth   /* format 0 */
925*37da2899SCharles.Forsyth 
926*37da2899SCharles.Forsyth   typedef struct  TT_CMap0_
927*37da2899SCharles.Forsyth   {
928*37da2899SCharles.Forsyth     FT_ULong  language;       /* for Mac fonts (originally ushort) */
929*37da2899SCharles.Forsyth 
930*37da2899SCharles.Forsyth     FT_Byte*  glyphIdArray;
931*37da2899SCharles.Forsyth 
932*37da2899SCharles.Forsyth   } TT_CMap0Rec, *TT_CMap0;
933*37da2899SCharles.Forsyth 
934*37da2899SCharles.Forsyth 
935*37da2899SCharles.Forsyth   /* format 2 */
936*37da2899SCharles.Forsyth 
937*37da2899SCharles.Forsyth   typedef struct  TT_CMap2SubHeaderRec_
938*37da2899SCharles.Forsyth   {
939*37da2899SCharles.Forsyth     FT_UShort  firstCode;      /* first valid low byte         */
940*37da2899SCharles.Forsyth     FT_UShort  entryCount;     /* number of valid low bytes    */
941*37da2899SCharles.Forsyth     FT_Short   idDelta;        /* delta value to glyphIndex    */
942*37da2899SCharles.Forsyth     FT_UShort  idRangeOffset;  /* offset from here to 1st code */
943*37da2899SCharles.Forsyth 
944*37da2899SCharles.Forsyth   } TT_CMap2SubHeaderRec, *TT_CMap2SubHeader;
945*37da2899SCharles.Forsyth 
946*37da2899SCharles.Forsyth 
947*37da2899SCharles.Forsyth   typedef struct  TT_CMap2Rec_
948*37da2899SCharles.Forsyth   {
949*37da2899SCharles.Forsyth     FT_ULong            language;     /* for Mac fonts (originally ushort) */
950*37da2899SCharles.Forsyth 
951*37da2899SCharles.Forsyth     FT_UShort*          subHeaderKeys;  /* high byte mapping table     */
952*37da2899SCharles.Forsyth                                         /* value = subHeader index * 8 */
953*37da2899SCharles.Forsyth     TT_CMap2SubHeader   subHeaders;
954*37da2899SCharles.Forsyth     FT_UShort*          glyphIdArray;
955*37da2899SCharles.Forsyth     FT_UShort           numGlyphId;   /* control value */
956*37da2899SCharles.Forsyth 
957*37da2899SCharles.Forsyth   } TT_CMap2Rec, *TT_CMap2;
958*37da2899SCharles.Forsyth 
959*37da2899SCharles.Forsyth 
960*37da2899SCharles.Forsyth   /* format 4 */
961*37da2899SCharles.Forsyth 
962*37da2899SCharles.Forsyth   typedef struct  TT_CMap4Segment_
963*37da2899SCharles.Forsyth   {
964*37da2899SCharles.Forsyth     FT_UShort  endCount;
965*37da2899SCharles.Forsyth     FT_UShort  startCount;
966*37da2899SCharles.Forsyth     FT_Short   idDelta;
967*37da2899SCharles.Forsyth     FT_UShort  idRangeOffset;
968*37da2899SCharles.Forsyth 
969*37da2899SCharles.Forsyth   } TT_CMap4SegmentRec, *TT_CMap4Segment;
970*37da2899SCharles.Forsyth 
971*37da2899SCharles.Forsyth 
972*37da2899SCharles.Forsyth   typedef struct  TT_CMap4Rec_
973*37da2899SCharles.Forsyth   {
974*37da2899SCharles.Forsyth     FT_ULong         language;       /* for Mac fonts (originally ushort) */
975*37da2899SCharles.Forsyth 
976*37da2899SCharles.Forsyth     FT_UShort        segCountX2;     /* number of segments * 2            */
977*37da2899SCharles.Forsyth     FT_UShort        searchRange;    /* these parameters can be used      */
978*37da2899SCharles.Forsyth     FT_UShort        entrySelector;  /* for a binary search               */
979*37da2899SCharles.Forsyth     FT_UShort        rangeShift;
980*37da2899SCharles.Forsyth 
981*37da2899SCharles.Forsyth     TT_CMap4Segment  segments;
982*37da2899SCharles.Forsyth     FT_UShort*       glyphIdArray;
983*37da2899SCharles.Forsyth     FT_UShort        numGlyphId;     /* control value */
984*37da2899SCharles.Forsyth 
985*37da2899SCharles.Forsyth     TT_CMap4Segment  last_segment;   /* last used segment; this is a small  */
986*37da2899SCharles.Forsyth                                      /* cache to potentially increase speed */
987*37da2899SCharles.Forsyth   } TT_CMap4Rec, *TT_CMap4;
988*37da2899SCharles.Forsyth 
989*37da2899SCharles.Forsyth 
990*37da2899SCharles.Forsyth   /* format 6 */
991*37da2899SCharles.Forsyth 
992*37da2899SCharles.Forsyth   typedef struct  TT_CMap6_
993*37da2899SCharles.Forsyth   {
994*37da2899SCharles.Forsyth     FT_ULong    language;       /* for Mac fonts (originally ushort)     */
995*37da2899SCharles.Forsyth 
996*37da2899SCharles.Forsyth     FT_UShort   firstCode;      /* first character code of subrange      */
997*37da2899SCharles.Forsyth     FT_UShort   entryCount;     /* number of character codes in subrange */
998*37da2899SCharles.Forsyth 
999*37da2899SCharles.Forsyth     FT_UShort*  glyphIdArray;
1000*37da2899SCharles.Forsyth 
1001*37da2899SCharles.Forsyth   } TT_CMap6Rec, *TT_CMap6;
1002*37da2899SCharles.Forsyth 
1003*37da2899SCharles.Forsyth 
1004*37da2899SCharles.Forsyth   /* auxiliary table for format 8 and 12 */
1005*37da2899SCharles.Forsyth 
1006*37da2899SCharles.Forsyth   typedef struct  TT_CMapGroupRec_
1007*37da2899SCharles.Forsyth   {
1008*37da2899SCharles.Forsyth     FT_ULong  startCharCode;
1009*37da2899SCharles.Forsyth     FT_ULong  endCharCode;
1010*37da2899SCharles.Forsyth     FT_ULong  startGlyphID;
1011*37da2899SCharles.Forsyth 
1012*37da2899SCharles.Forsyth   } TT_CMapGroupRec, *TT_CMapGroup;
1013*37da2899SCharles.Forsyth 
1014*37da2899SCharles.Forsyth 
1015*37da2899SCharles.Forsyth   /* FreeType handles format 8 and 12 identically.  It is not necessary to
1016*37da2899SCharles.Forsyth      cover mixed 16bit and 32bit codes since FreeType always uses FT_ULong
1017*37da2899SCharles.Forsyth      for input character codes -- converting Unicode surrogates to 32bit
1018*37da2899SCharles.Forsyth      character codes must be done by the application.                      */
1019*37da2899SCharles.Forsyth 
1020*37da2899SCharles.Forsyth   typedef struct  TT_CMap8_12Rec_
1021*37da2899SCharles.Forsyth   {
1022*37da2899SCharles.Forsyth     FT_ULong      language;        /* for Mac fonts */
1023*37da2899SCharles.Forsyth 
1024*37da2899SCharles.Forsyth     FT_ULong      nGroups;
1025*37da2899SCharles.Forsyth     TT_CMapGroup  groups;
1026*37da2899SCharles.Forsyth 
1027*37da2899SCharles.Forsyth     TT_CMapGroup  last_group;      /* last used group; this is a small    */
1028*37da2899SCharles.Forsyth                                    /* cache to potentially increase speed */
1029*37da2899SCharles.Forsyth   } TT_CMap8_12Rec, *TT_CMap8_12;
1030*37da2899SCharles.Forsyth 
1031*37da2899SCharles.Forsyth 
1032*37da2899SCharles.Forsyth   /* format 10 */
1033*37da2899SCharles.Forsyth 
1034*37da2899SCharles.Forsyth   typedef struct  TT_CMap10Rec_
1035*37da2899SCharles.Forsyth   {
1036*37da2899SCharles.Forsyth     FT_ULong    language;           /* for Mac fonts */
1037*37da2899SCharles.Forsyth 
1038*37da2899SCharles.Forsyth     FT_ULong    startCharCode;      /* first character covered */
1039*37da2899SCharles.Forsyth     FT_ULong    numChars;           /* number of characters covered */
1040*37da2899SCharles.Forsyth 
1041*37da2899SCharles.Forsyth     FT_UShort*  glyphs;
1042*37da2899SCharles.Forsyth 
1043*37da2899SCharles.Forsyth   } TT_CMap10Rec, *TT_CMap10;
1044*37da2899SCharles.Forsyth 
1045*37da2899SCharles.Forsyth 
1046*37da2899SCharles.Forsyth   typedef struct TT_CMapTableRec_*  TT_CMapTable;
1047*37da2899SCharles.Forsyth 
1048*37da2899SCharles.Forsyth 
1049*37da2899SCharles.Forsyth   typedef FT_UInt
1050*37da2899SCharles.Forsyth   (*TT_CharMap_Func)( TT_CMapTable  charmap,
1051*37da2899SCharles.Forsyth                       FT_ULong      char_code );
1052*37da2899SCharles.Forsyth 
1053*37da2899SCharles.Forsyth   typedef FT_ULong
1054*37da2899SCharles.Forsyth   (*TT_CharNext_Func)( TT_CMapTable  charmap,
1055*37da2899SCharles.Forsyth                        FT_ULong      char_code );
1056*37da2899SCharles.Forsyth 
1057*37da2899SCharles.Forsyth 
1058*37da2899SCharles.Forsyth   /* charmap table */
1059*37da2899SCharles.Forsyth   typedef struct  TT_CMapTableRec_
1060*37da2899SCharles.Forsyth   {
1061*37da2899SCharles.Forsyth     FT_UShort  platformID;
1062*37da2899SCharles.Forsyth     FT_UShort  platformEncodingID;
1063*37da2899SCharles.Forsyth     FT_UShort  format;
1064*37da2899SCharles.Forsyth     FT_ULong   length;          /* must be ulong for formats 8, 10, and 12 */
1065*37da2899SCharles.Forsyth 
1066*37da2899SCharles.Forsyth     FT_Bool    loaded;
1067*37da2899SCharles.Forsyth     FT_ULong   offset;
1068*37da2899SCharles.Forsyth 
1069*37da2899SCharles.Forsyth     union
1070*37da2899SCharles.Forsyth     {
1071*37da2899SCharles.Forsyth       TT_CMap0Rec     cmap0;
1072*37da2899SCharles.Forsyth       TT_CMap2Rec     cmap2;
1073*37da2899SCharles.Forsyth       TT_CMap4Rec     cmap4;
1074*37da2899SCharles.Forsyth       TT_CMap6Rec     cmap6;
1075*37da2899SCharles.Forsyth       TT_CMap8_12Rec  cmap8_12;
1076*37da2899SCharles.Forsyth       TT_CMap10Rec    cmap10;
1077*37da2899SCharles.Forsyth     } c;
1078*37da2899SCharles.Forsyth 
1079*37da2899SCharles.Forsyth     TT_CharMap_Func   get_index;
1080*37da2899SCharles.Forsyth     TT_CharNext_Func  get_next_char;
1081*37da2899SCharles.Forsyth 
1082*37da2899SCharles.Forsyth   } TT_CMapTableRec;
1083*37da2899SCharles.Forsyth 
1084*37da2899SCharles.Forsyth 
1085*37da2899SCharles.Forsyth   /*************************************************************************/
1086*37da2899SCharles.Forsyth   /*                                                                       */
1087*37da2899SCharles.Forsyth   /* <Struct>                                                              */
1088*37da2899SCharles.Forsyth   /*    TT_CharMapRec                                                      */
1089*37da2899SCharles.Forsyth   /*                                                                       */
1090*37da2899SCharles.Forsyth   /* <Description>                                                         */
1091*37da2899SCharles.Forsyth   /*    The TrueType character map object type.                            */
1092*37da2899SCharles.Forsyth   /*                                                                       */
1093*37da2899SCharles.Forsyth   /* <Fields>                                                              */
1094*37da2899SCharles.Forsyth   /*    root :: The parent character map structure.                        */
1095*37da2899SCharles.Forsyth   /*                                                                       */
1096*37da2899SCharles.Forsyth   /*    cmap :: The used character map.                                    */
1097*37da2899SCharles.Forsyth   /*                                                                       */
1098*37da2899SCharles.Forsyth   typedef struct  TT_CharMapRec_
1099*37da2899SCharles.Forsyth   {
1100*37da2899SCharles.Forsyth     FT_CharMapRec    root;
1101*37da2899SCharles.Forsyth     TT_CMapTableRec  cmap;
1102*37da2899SCharles.Forsyth 
1103*37da2899SCharles.Forsyth   } TT_CharMapRec;
1104*37da2899SCharles.Forsyth 
1105*37da2899SCharles.Forsyth 
1106*37da2899SCharles.Forsyth   /*************************************************************************/
1107*37da2899SCharles.Forsyth   /*************************************************************************/
1108*37da2899SCharles.Forsyth   /*************************************************************************/
1109*37da2899SCharles.Forsyth   /***                                                                   ***/
1110*37da2899SCharles.Forsyth   /***                                                                   ***/
1111*37da2899SCharles.Forsyth   /***                  ORIGINAL TT_FACE CLASS DEFINITION                ***/
1112*37da2899SCharles.Forsyth   /***                                                                   ***/
1113*37da2899SCharles.Forsyth   /***                                                                   ***/
1114*37da2899SCharles.Forsyth   /*************************************************************************/
1115*37da2899SCharles.Forsyth   /*************************************************************************/
1116*37da2899SCharles.Forsyth   /*************************************************************************/
1117*37da2899SCharles.Forsyth 
1118*37da2899SCharles.Forsyth 
1119*37da2899SCharles.Forsyth   /*************************************************************************/
1120*37da2899SCharles.Forsyth   /*                                                                       */
1121*37da2899SCharles.Forsyth   /* This structure/class is defined here because it is common to the      */
1122*37da2899SCharles.Forsyth   /* following formats: TTF, OpenType-TT, and OpenType-CFF.                */
1123*37da2899SCharles.Forsyth   /*                                                                       */
1124*37da2899SCharles.Forsyth   /* Note, however, that the classes TT_Size, TT_GlyphSlot, and TT_CharMap */
1125*37da2899SCharles.Forsyth   /* are not shared between font drivers, and are thus defined in          */
1126*37da2899SCharles.Forsyth   /* `ttobjs.h'.                                                           */
1127*37da2899SCharles.Forsyth   /*                                                                       */
1128*37da2899SCharles.Forsyth   /*************************************************************************/
1129*37da2899SCharles.Forsyth 
1130*37da2899SCharles.Forsyth 
1131*37da2899SCharles.Forsyth   /*************************************************************************/
1132*37da2899SCharles.Forsyth   /*                                                                       */
1133*37da2899SCharles.Forsyth   /* <Type>                                                                */
1134*37da2899SCharles.Forsyth   /*    TT_Face                                                            */
1135*37da2899SCharles.Forsyth   /*                                                                       */
1136*37da2899SCharles.Forsyth   /* <Description>                                                         */
1137*37da2899SCharles.Forsyth   /*    A handle to a TrueType face/font object.  A TT_Face encapsulates   */
1138*37da2899SCharles.Forsyth   /*    the resolution and scaling independent parts of a TrueType font    */
1139*37da2899SCharles.Forsyth   /*    resource.                                                          */
1140*37da2899SCharles.Forsyth   /*                                                                       */
1141*37da2899SCharles.Forsyth   /* <Note>                                                                */
1142*37da2899SCharles.Forsyth   /*    The TT_Face structure is also used as a `parent class' for the     */
1143*37da2899SCharles.Forsyth   /*    OpenType-CFF class (T2_Face).                                      */
1144*37da2899SCharles.Forsyth   /*                                                                       */
1145*37da2899SCharles.Forsyth   typedef struct TT_FaceRec_*  TT_Face;
1146*37da2899SCharles.Forsyth 
1147*37da2899SCharles.Forsyth 
1148*37da2899SCharles.Forsyth   /*************************************************************************/
1149*37da2899SCharles.Forsyth   /*                                                                       */
1150*37da2899SCharles.Forsyth   /* <Type>                                                                */
1151*37da2899SCharles.Forsyth   /*    TT_CharMap                                                         */
1152*37da2899SCharles.Forsyth   /*                                                                       */
1153*37da2899SCharles.Forsyth   /* <Description>                                                         */
1154*37da2899SCharles.Forsyth   /*    A handle to a TrueType character mapping object.                   */
1155*37da2899SCharles.Forsyth   /*                                                                       */
1156*37da2899SCharles.Forsyth   typedef struct TT_CharMapRec_*  TT_CharMap;
1157*37da2899SCharles.Forsyth 
1158*37da2899SCharles.Forsyth 
1159*37da2899SCharles.Forsyth   /* a function type used for the truetype bytecode interpreter hooks */
1160*37da2899SCharles.Forsyth   typedef FT_Error
1161*37da2899SCharles.Forsyth   (*TT_Interpreter)( void*  exec_context );
1162*37da2899SCharles.Forsyth 
1163*37da2899SCharles.Forsyth   /* forward declaration */
1164*37da2899SCharles.Forsyth   typedef struct TT_LoaderRec_*  TT_Loader;
1165*37da2899SCharles.Forsyth 
1166*37da2899SCharles.Forsyth 
1167*37da2899SCharles.Forsyth   /*************************************************************************/
1168*37da2899SCharles.Forsyth   /*                                                                       */
1169*37da2899SCharles.Forsyth   /* <FuncType>                                                            */
1170*37da2899SCharles.Forsyth   /*    TT_Loader_GotoTableFunc                                            */
1171*37da2899SCharles.Forsyth   /*                                                                       */
1172*37da2899SCharles.Forsyth   /* <Description>                                                         */
1173*37da2899SCharles.Forsyth   /*    Seeks a stream to the start of a given TrueType table.             */
1174*37da2899SCharles.Forsyth   /*                                                                       */
1175*37da2899SCharles.Forsyth   /* <Input>                                                               */
1176*37da2899SCharles.Forsyth   /*    face   :: A handle to the target face object.                      */
1177*37da2899SCharles.Forsyth   /*                                                                       */
1178*37da2899SCharles.Forsyth   /*    tag    :: A 4-byte tag used to name the table.                     */
1179*37da2899SCharles.Forsyth   /*                                                                       */
1180*37da2899SCharles.Forsyth   /*    stream :: The input stream.                                        */
1181*37da2899SCharles.Forsyth   /*                                                                       */
1182*37da2899SCharles.Forsyth   /* <Output>                                                              */
1183*37da2899SCharles.Forsyth   /*    length :: The length of the table in bytes.  Set to 0 if not       */
1184*37da2899SCharles.Forsyth   /*              needed.                                                  */
1185*37da2899SCharles.Forsyth   /*                                                                       */
1186*37da2899SCharles.Forsyth   /* <Return>                                                              */
1187*37da2899SCharles.Forsyth   /*    FreeType error code.  0 means success.                             */
1188*37da2899SCharles.Forsyth   /*                                                                       */
1189*37da2899SCharles.Forsyth   /* <Note>                                                                */
1190*37da2899SCharles.Forsyth   /*    The stream cursor must be at the font file's origin.               */
1191*37da2899SCharles.Forsyth   /*                                                                       */
1192*37da2899SCharles.Forsyth   typedef FT_Error
1193*37da2899SCharles.Forsyth   (*TT_Loader_GotoTableFunc)( TT_Face    face,
1194*37da2899SCharles.Forsyth                               FT_ULong   tag,
1195*37da2899SCharles.Forsyth                               FT_Stream  stream,
1196*37da2899SCharles.Forsyth                               FT_ULong*  length );
1197*37da2899SCharles.Forsyth 
1198*37da2899SCharles.Forsyth 
1199*37da2899SCharles.Forsyth   /*************************************************************************/
1200*37da2899SCharles.Forsyth   /*                                                                       */
1201*37da2899SCharles.Forsyth   /* <FuncType>                                                            */
1202*37da2899SCharles.Forsyth   /*    TT_Loader_StartGlyphFunc                                           */
1203*37da2899SCharles.Forsyth   /*                                                                       */
1204*37da2899SCharles.Forsyth   /* <Description>                                                         */
1205*37da2899SCharles.Forsyth   /*    Seeks a stream to the start of a given glyph element, and opens a  */
1206*37da2899SCharles.Forsyth   /*    frame for it.                                                      */
1207*37da2899SCharles.Forsyth   /*                                                                       */
1208*37da2899SCharles.Forsyth   /* <Input>                                                               */
1209*37da2899SCharles.Forsyth   /*    loader      :: The current TrueType glyph loader object.           */
1210*37da2899SCharles.Forsyth   /*                                                                       */
1211*37da2899SCharles.Forsyth   /*    glyph index :: The index of the glyph to access.                   */
1212*37da2899SCharles.Forsyth   /*                                                                       */
1213*37da2899SCharles.Forsyth   /*    offset      :: The offset of the glyph according to the            */
1214*37da2899SCharles.Forsyth   /*                   `locations' table.                                  */
1215*37da2899SCharles.Forsyth   /*                                                                       */
1216*37da2899SCharles.Forsyth   /*    byte_count  :: The size of the frame in bytes.                     */
1217*37da2899SCharles.Forsyth   /*                                                                       */
1218*37da2899SCharles.Forsyth   /* <Return>                                                              */
1219*37da2899SCharles.Forsyth   /*    FreeType error code.  0 means success.                             */
1220*37da2899SCharles.Forsyth   /*                                                                       */
1221*37da2899SCharles.Forsyth   /* <Note>                                                                */
1222*37da2899SCharles.Forsyth   /*    This function is normally equivalent to FT_STREAM_SEEK(offset)     */
1223*37da2899SCharles.Forsyth   /*    followed by FT_FRAME_ENTER(byte_count) with the loader's stream,   */
1224*37da2899SCharles.Forsyth   /*    but alternative formats (e.g. compressed ones) might use something */
1225*37da2899SCharles.Forsyth   /*    different.                                                         */
1226*37da2899SCharles.Forsyth   /*                                                                       */
1227*37da2899SCharles.Forsyth   typedef FT_Error
1228*37da2899SCharles.Forsyth   (*TT_Loader_StartGlyphFunc)( TT_Loader  loader,
1229*37da2899SCharles.Forsyth                                FT_UInt    glyph_index,
1230*37da2899SCharles.Forsyth                                FT_ULong   offset,
1231*37da2899SCharles.Forsyth                                FT_UInt    byte_count );
1232*37da2899SCharles.Forsyth 
1233*37da2899SCharles.Forsyth 
1234*37da2899SCharles.Forsyth   /*************************************************************************/
1235*37da2899SCharles.Forsyth   /*                                                                       */
1236*37da2899SCharles.Forsyth   /* <FuncType>                                                            */
1237*37da2899SCharles.Forsyth   /*    TT_Loader_ReadGlyphFunc                                            */
1238*37da2899SCharles.Forsyth   /*                                                                       */
1239*37da2899SCharles.Forsyth   /* <Description>                                                         */
1240*37da2899SCharles.Forsyth   /*    Reads one glyph element (its header, a simple glyph, or a          */
1241*37da2899SCharles.Forsyth   /*    composite) from the loader's current stream frame.                 */
1242*37da2899SCharles.Forsyth   /*                                                                       */
1243*37da2899SCharles.Forsyth   /* <Input>                                                               */
1244*37da2899SCharles.Forsyth   /*    loader :: The current TrueType glyph loader object.                */
1245*37da2899SCharles.Forsyth   /*                                                                       */
1246*37da2899SCharles.Forsyth   /* <Return>                                                              */
1247*37da2899SCharles.Forsyth   /*    FreeType error code.  0 means success.                             */
1248*37da2899SCharles.Forsyth   /*                                                                       */
1249*37da2899SCharles.Forsyth   typedef FT_Error
1250*37da2899SCharles.Forsyth   (*TT_Loader_ReadGlyphFunc)( TT_Loader  loader );
1251*37da2899SCharles.Forsyth 
1252*37da2899SCharles.Forsyth 
1253*37da2899SCharles.Forsyth   /*************************************************************************/
1254*37da2899SCharles.Forsyth   /*                                                                       */
1255*37da2899SCharles.Forsyth   /* <FuncType>                                                            */
1256*37da2899SCharles.Forsyth   /*    TT_Loader_EndGlyphFunc                                             */
1257*37da2899SCharles.Forsyth   /*                                                                       */
1258*37da2899SCharles.Forsyth   /* <Description>                                                         */
1259*37da2899SCharles.Forsyth   /*    Closes the current loader stream frame for the glyph.              */
1260*37da2899SCharles.Forsyth   /*                                                                       */
1261*37da2899SCharles.Forsyth   /* <Input>                                                               */
1262*37da2899SCharles.Forsyth   /*    loader :: The current TrueType glyph loader object.                */
1263*37da2899SCharles.Forsyth   /*                                                                       */
1264*37da2899SCharles.Forsyth   typedef void
1265*37da2899SCharles.Forsyth   (*TT_Loader_EndGlyphFunc)( TT_Loader  loader );
1266*37da2899SCharles.Forsyth 
1267*37da2899SCharles.Forsyth 
1268*37da2899SCharles.Forsyth   /*************************************************************************/
1269*37da2899SCharles.Forsyth   /*                                                                       */
1270*37da2899SCharles.Forsyth   /*                         TrueType Face Type                            */
1271*37da2899SCharles.Forsyth   /*                                                                       */
1272*37da2899SCharles.Forsyth   /* <Struct>                                                              */
1273*37da2899SCharles.Forsyth   /*    TT_Face                                                            */
1274*37da2899SCharles.Forsyth   /*                                                                       */
1275*37da2899SCharles.Forsyth   /* <Description>                                                         */
1276*37da2899SCharles.Forsyth   /*    The TrueType face class.  These objects model the resolution and   */
1277*37da2899SCharles.Forsyth   /*    point-size independent data found in a TrueType font file.         */
1278*37da2899SCharles.Forsyth   /*                                                                       */
1279*37da2899SCharles.Forsyth   /* <Fields>                                                              */
1280*37da2899SCharles.Forsyth   /*    root                 :: The base FT_Face structure, managed by the */
1281*37da2899SCharles.Forsyth   /*                            base layer.                                */
1282*37da2899SCharles.Forsyth   /*                                                                       */
1283*37da2899SCharles.Forsyth   /*    ttc_header           :: The TrueType collection header, used when  */
1284*37da2899SCharles.Forsyth   /*                            the file is a `ttc' rather than a `ttf'.   */
1285*37da2899SCharles.Forsyth   /*                            For ordinary font files, the field         */
1286*37da2899SCharles.Forsyth   /*                            `ttc_header.count' is set to 0.            */
1287*37da2899SCharles.Forsyth   /*                                                                       */
1288*37da2899SCharles.Forsyth   /*    format_tag           :: The font format tag.                       */
1289*37da2899SCharles.Forsyth   /*                                                                       */
1290*37da2899SCharles.Forsyth   /*    num_tables           :: The number of TrueType tables in this font */
1291*37da2899SCharles.Forsyth   /*                            file.                                      */
1292*37da2899SCharles.Forsyth   /*                                                                       */
1293*37da2899SCharles.Forsyth   /*    dir_tables           :: The directory of TrueType tables for this  */
1294*37da2899SCharles.Forsyth   /*                            font file.                                 */
1295*37da2899SCharles.Forsyth   /*                                                                       */
1296*37da2899SCharles.Forsyth   /*    header               :: The font's font header (`head' table).     */
1297*37da2899SCharles.Forsyth   /*                            Read on font opening.                      */
1298*37da2899SCharles.Forsyth   /*                                                                       */
1299*37da2899SCharles.Forsyth   /*    horizontal           :: The font's horizontal header (`hhea'       */
1300*37da2899SCharles.Forsyth   /*                            table).  This field also contains the      */
1301*37da2899SCharles.Forsyth   /*                            associated horizontal metrics table        */
1302*37da2899SCharles.Forsyth   /*                            (`hmtx').                                  */
1303*37da2899SCharles.Forsyth   /*                                                                       */
1304*37da2899SCharles.Forsyth   /*    max_profile          :: The font's maximum profile table.  Read on */
1305*37da2899SCharles.Forsyth   /*                            font opening.  Note that some maximum      */
1306*37da2899SCharles.Forsyth   /*                            values cannot be taken directly from this  */
1307*37da2899SCharles.Forsyth   /*                            table.  We thus define additional fields   */
1308*37da2899SCharles.Forsyth   /*                            below to hold the computed maxima.         */
1309*37da2899SCharles.Forsyth   /*                                                                       */
1310*37da2899SCharles.Forsyth   /*    max_components       :: The maximum number of glyph components     */
1311*37da2899SCharles.Forsyth   /*                            required to load any composite glyph from  */
1312*37da2899SCharles.Forsyth   /*                            this font.  Used to size the load stack.   */
1313*37da2899SCharles.Forsyth   /*                                                                       */
1314*37da2899SCharles.Forsyth   /*    vertical_info        :: A boolean which is set when the font file  */
1315*37da2899SCharles.Forsyth   /*                            contains vertical metrics.  If not, the    */
1316*37da2899SCharles.Forsyth   /*                            value of the `vertical' field is           */
1317*37da2899SCharles.Forsyth   /*                            undefined.                                 */
1318*37da2899SCharles.Forsyth   /*                                                                       */
1319*37da2899SCharles.Forsyth   /*    vertical             :: The font's vertical header (`vhea' table). */
1320*37da2899SCharles.Forsyth   /*                            This field also contains the associated    */
1321*37da2899SCharles.Forsyth   /*                            vertical metrics table (`vmtx'), if found. */
1322*37da2899SCharles.Forsyth   /*                            IMPORTANT: The contents of this field is   */
1323*37da2899SCharles.Forsyth   /*                            undefined if the `verticalInfo' field is   */
1324*37da2899SCharles.Forsyth   /*                            unset.                                     */
1325*37da2899SCharles.Forsyth   /*                                                                       */
1326*37da2899SCharles.Forsyth   /*    num_names            :: The number of name records within this     */
1327*37da2899SCharles.Forsyth   /*                            TrueType font.                             */
1328*37da2899SCharles.Forsyth   /*                                                                       */
1329*37da2899SCharles.Forsyth   /*    name_table           :: The table of name records (`name').        */
1330*37da2899SCharles.Forsyth   /*                                                                       */
1331*37da2899SCharles.Forsyth   /*    os2                  :: The font's OS/2 table (`OS/2').            */
1332*37da2899SCharles.Forsyth   /*                                                                       */
1333*37da2899SCharles.Forsyth   /*    postscript           :: The font's PostScript table (`post'        */
1334*37da2899SCharles.Forsyth   /*                            table).  The PostScript glyph names are    */
1335*37da2899SCharles.Forsyth   /*                            not loaded by the driver on face opening.  */
1336*37da2899SCharles.Forsyth   /*                            See the `ttpost' module for more details.  */
1337*37da2899SCharles.Forsyth   /*                                                                       */
1338*37da2899SCharles.Forsyth   /*    cmap_table           :: Address of the face's `cmap' SFNT table    */
1339*37da2899SCharles.Forsyth   /*                            in memory (it's an extracted frame).       */
1340*37da2899SCharles.Forsyth   /*                                                                       */
1341*37da2899SCharles.Forsyth   /*    cmap_size            :: The size in bytes of the `cmap_table'      */
1342*37da2899SCharles.Forsyth   /*                            described above.                           */
1343*37da2899SCharles.Forsyth   /*                                                                       */
1344*37da2899SCharles.Forsyth   /*    num_charmaps         :: The number of character mappings in the    */
1345*37da2899SCharles.Forsyth   /*                            font.                                      */
1346*37da2899SCharles.Forsyth   /*                                                                       */
1347*37da2899SCharles.Forsyth   /*    charmaps             :: The array of charmap objects for this font */
1348*37da2899SCharles.Forsyth   /*                            file.  Note that this field is a typeless  */
1349*37da2899SCharles.Forsyth   /*                            pointer.  The Reason is that the format of */
1350*37da2899SCharles.Forsyth   /*                            charmaps varies with the underlying font   */
1351*37da2899SCharles.Forsyth   /*                            format and cannot be determined here.      */
1352*37da2899SCharles.Forsyth   /*                                                                       */
1353*37da2899SCharles.Forsyth   /*    goto_table           :: A function called by each TrueType table   */
1354*37da2899SCharles.Forsyth   /*                            loader to position a stream's cursor to    */
1355*37da2899SCharles.Forsyth   /*                            the start of a given table according to    */
1356*37da2899SCharles.Forsyth   /*                            its tag.  It defaults to TT_Goto_Face but  */
1357*37da2899SCharles.Forsyth   /*                            can be different for strange formats (e.g. */
1358*37da2899SCharles.Forsyth   /*                            Type 42).                                  */
1359*37da2899SCharles.Forsyth   /*                                                                       */
1360*37da2899SCharles.Forsyth   /*    access_glyph_frame   :: A function used to access the frame of a   */
1361*37da2899SCharles.Forsyth   /*                            given glyph within the face's font file.   */
1362*37da2899SCharles.Forsyth   /*                                                                       */
1363*37da2899SCharles.Forsyth   /*    forget_glyph_frame   :: A function used to forget the frame of a   */
1364*37da2899SCharles.Forsyth   /*                            given glyph when all data has been loaded. */
1365*37da2899SCharles.Forsyth   /*                                                                       */
1366*37da2899SCharles.Forsyth   /*    read_glyph_header    :: A function used to read a glyph header.    */
1367*37da2899SCharles.Forsyth   /*                            It must be called between an `access' and  */
1368*37da2899SCharles.Forsyth   /*                            `forget'.                                  */
1369*37da2899SCharles.Forsyth   /*                                                                       */
1370*37da2899SCharles.Forsyth   /*    read_simple_glyph    :: A function used to read a simple glyph.    */
1371*37da2899SCharles.Forsyth   /*                            It must be called after the header was     */
1372*37da2899SCharles.Forsyth   /*                            read, and before the `forget'.             */
1373*37da2899SCharles.Forsyth   /*                                                                       */
1374*37da2899SCharles.Forsyth   /*    read_composite_glyph :: A function used to read a composite glyph. */
1375*37da2899SCharles.Forsyth   /*                            It must be called after the header was     */
1376*37da2899SCharles.Forsyth   /*                            read, and before the `forget'.             */
1377*37da2899SCharles.Forsyth   /*                                                                       */
1378*37da2899SCharles.Forsyth   /*    sfnt                 :: A pointer to the SFNT `driver' interface.  */
1379*37da2899SCharles.Forsyth   /*                                                                       */
1380*37da2899SCharles.Forsyth   /*    psnames              :: A pointer to the `PSNames' module          */
1381*37da2899SCharles.Forsyth   /*                            interface.                                 */
1382*37da2899SCharles.Forsyth   /*                                                                       */
1383*37da2899SCharles.Forsyth   /*    hdmx                 :: The face's horizontal device metrics       */
1384*37da2899SCharles.Forsyth   /*                            (`hdmx' table).  This table is optional in */
1385*37da2899SCharles.Forsyth   /*                            TrueType/OpenType fonts.                   */
1386*37da2899SCharles.Forsyth   /*                                                                       */
1387*37da2899SCharles.Forsyth   /*    gasp                 :: The grid-fitting and scaling properties    */
1388*37da2899SCharles.Forsyth   /*                            table (`gasp').  This table is optional in */
1389*37da2899SCharles.Forsyth   /*                            TrueType/OpenType fonts.                   */
1390*37da2899SCharles.Forsyth   /*                                                                       */
1391*37da2899SCharles.Forsyth   /*    pclt                 :: The `pclt' SFNT table.                     */
1392*37da2899SCharles.Forsyth   /*                                                                       */
1393*37da2899SCharles.Forsyth   /*    num_sbit_strikes     :: The number of sbit strikes, i.e., bitmap   */
1394*37da2899SCharles.Forsyth   /*                            sizes, embedded in this font.              */
1395*37da2899SCharles.Forsyth   /*                                                                       */
1396*37da2899SCharles.Forsyth   /*    sbit_strikes         :: An array of sbit strikes embedded in this  */
1397*37da2899SCharles.Forsyth   /*                            font.  This table is optional in a         */
1398*37da2899SCharles.Forsyth   /*                            TrueType/OpenType font.                    */
1399*37da2899SCharles.Forsyth   /*                                                                       */
1400*37da2899SCharles.Forsyth   /*    num_sbit_scales      :: The number of sbit scales for this font.   */
1401*37da2899SCharles.Forsyth   /*                                                                       */
1402*37da2899SCharles.Forsyth   /*    sbit_scales          :: Array of sbit scales embedded in this      */
1403*37da2899SCharles.Forsyth   /*                            font.  This table is optional in a         */
1404*37da2899SCharles.Forsyth   /*                            TrueType/OpenType font.                    */
1405*37da2899SCharles.Forsyth   /*                                                                       */
1406*37da2899SCharles.Forsyth   /*    postscript_names     :: A table used to store the Postscript names */
1407*37da2899SCharles.Forsyth   /*                            of  the glyphs for this font.  See the     */
1408*37da2899SCharles.Forsyth   /*                            file  `ttconfig.h' for comments on the     */
1409*37da2899SCharles.Forsyth   /*                            TT_CONFIG_OPTION_POSTSCRIPT_NAMES option.  */
1410*37da2899SCharles.Forsyth   /*                                                                       */
1411*37da2899SCharles.Forsyth   /*    num_locations        :: The number of glyph locations in this      */
1412*37da2899SCharles.Forsyth   /*                            TrueType file.  This should be             */
1413*37da2899SCharles.Forsyth   /*                            identical to the number of glyphs.         */
1414*37da2899SCharles.Forsyth   /*                            Ignored for Type 2 fonts.                  */
1415*37da2899SCharles.Forsyth   /*                                                                       */
1416*37da2899SCharles.Forsyth   /*    glyph_locations      :: An array of longs.  These are offsets to   */
1417*37da2899SCharles.Forsyth   /*                            glyph data within the `glyf' table.        */
1418*37da2899SCharles.Forsyth   /*                            Ignored for Type 2 font faces.             */
1419*37da2899SCharles.Forsyth   /*                                                                       */
1420*37da2899SCharles.Forsyth   /*    font_program_size    :: Size in bytecodes of the face's font       */
1421*37da2899SCharles.Forsyth   /*                            program.  0 if none defined.  Ignored for  */
1422*37da2899SCharles.Forsyth   /*                            Type 2 fonts.                              */
1423*37da2899SCharles.Forsyth   /*                                                                       */
1424*37da2899SCharles.Forsyth   /*    font_program         :: The face's font program (bytecode stream)  */
1425*37da2899SCharles.Forsyth   /*                            executed at load time, also used during    */
1426*37da2899SCharles.Forsyth   /*                            glyph rendering.  Comes from the `fpgm'    */
1427*37da2899SCharles.Forsyth   /*                            table.  Ignored for Type 2 font fonts.     */
1428*37da2899SCharles.Forsyth   /*                                                                       */
1429*37da2899SCharles.Forsyth   /*    cvt_program_size     :: The size in bytecodes of the face's cvt    */
1430*37da2899SCharles.Forsyth   /*                            program.  Ignored for Type 2 fonts.        */
1431*37da2899SCharles.Forsyth   /*                                                                       */
1432*37da2899SCharles.Forsyth   /*    cvt_program          :: The face's cvt program (bytecode stream)   */
1433*37da2899SCharles.Forsyth   /*                            executed each time an instance/size is     */
1434*37da2899SCharles.Forsyth   /*                            changed/reset.  Comes from the `prep'      */
1435*37da2899SCharles.Forsyth   /*                            table.  Ignored for Type 2 fonts.          */
1436*37da2899SCharles.Forsyth   /*                                                                       */
1437*37da2899SCharles.Forsyth   /*    cvt_size             :: Size of the control value table (in        */
1438*37da2899SCharles.Forsyth   /*                            entries).   Ignored for Type 2 fonts.      */
1439*37da2899SCharles.Forsyth   /*                                                                       */
1440*37da2899SCharles.Forsyth   /*    cvt                  :: The face's original control value table.   */
1441*37da2899SCharles.Forsyth   /*                            Coordinates are expressed in unscaled font */
1442*37da2899SCharles.Forsyth   /*                            units.  Comes from the `cvt ' table.       */
1443*37da2899SCharles.Forsyth   /*                            Ignored for Type 2 fonts.                  */
1444*37da2899SCharles.Forsyth   /*                                                                       */
1445*37da2899SCharles.Forsyth   /*    num_kern_pairs       :: The number of kerning pairs present in the */
1446*37da2899SCharles.Forsyth   /*                            font file.  The engine only loads the      */
1447*37da2899SCharles.Forsyth   /*                            first horizontal format 0 kern table it    */
1448*37da2899SCharles.Forsyth   /*                            finds in the font file.  Ignored for       */
1449*37da2899SCharles.Forsyth   /*                            Type 2 fonts.                              */
1450*37da2899SCharles.Forsyth   /*                                                                       */
1451*37da2899SCharles.Forsyth   /*    kern_table_index     :: The index of the kerning table in the font */
1452*37da2899SCharles.Forsyth   /*                            kerning directory.  Ignored for Type 2     */
1453*37da2899SCharles.Forsyth   /*                            fonts.                                     */
1454*37da2899SCharles.Forsyth   /*                                                                       */
1455*37da2899SCharles.Forsyth   /*    interpreter          :: A pointer to the TrueType bytecode         */
1456*37da2899SCharles.Forsyth   /*                            interpreters field is also used to hook    */
1457*37da2899SCharles.Forsyth   /*                            the debugger in `ttdebug'.                 */
1458*37da2899SCharles.Forsyth   /*                                                                       */
1459*37da2899SCharles.Forsyth   /*    extra                :: Reserved for third-party font drivers.     */
1460*37da2899SCharles.Forsyth   /*                                                                       */
1461*37da2899SCharles.Forsyth   typedef struct  TT_FaceRec_
1462*37da2899SCharles.Forsyth   {
1463*37da2899SCharles.Forsyth     FT_FaceRec            root;
1464*37da2899SCharles.Forsyth 
1465*37da2899SCharles.Forsyth     TTC_HeaderRec         ttc_header;
1466*37da2899SCharles.Forsyth 
1467*37da2899SCharles.Forsyth     FT_ULong              format_tag;
1468*37da2899SCharles.Forsyth     FT_UShort             num_tables;
1469*37da2899SCharles.Forsyth     TT_Table              dir_tables;
1470*37da2899SCharles.Forsyth 
1471*37da2899SCharles.Forsyth     TT_Header             header;       /* TrueType header table          */
1472*37da2899SCharles.Forsyth     TT_HoriHeader         horizontal;   /* TrueType horizontal header     */
1473*37da2899SCharles.Forsyth 
1474*37da2899SCharles.Forsyth     TT_MaxProfile         max_profile;
1475*37da2899SCharles.Forsyth     FT_ULong              max_components;
1476*37da2899SCharles.Forsyth 
1477*37da2899SCharles.Forsyth     FT_Bool               vertical_info;
1478*37da2899SCharles.Forsyth     TT_VertHeader         vertical;     /* TT Vertical header, if present */
1479*37da2899SCharles.Forsyth 
1480*37da2899SCharles.Forsyth     FT_UShort             num_names;    /* number of name records  */
1481*37da2899SCharles.Forsyth     TT_NameTableRec       name_table;   /* name table              */
1482*37da2899SCharles.Forsyth 
1483*37da2899SCharles.Forsyth     TT_OS2                os2;          /* TrueType OS/2 table            */
1484*37da2899SCharles.Forsyth     TT_Postscript         postscript;   /* TrueType Postscript table      */
1485*37da2899SCharles.Forsyth 
1486*37da2899SCharles.Forsyth     FT_Byte*              cmap_table;   /* extracted 'cmap' table */
1487*37da2899SCharles.Forsyth     FT_ULong              cmap_size;
1488*37da2899SCharles.Forsyth 
1489*37da2899SCharles.Forsyth     TT_Loader_GotoTableFunc   goto_table;
1490*37da2899SCharles.Forsyth 
1491*37da2899SCharles.Forsyth     TT_Loader_StartGlyphFunc  access_glyph_frame;
1492*37da2899SCharles.Forsyth     TT_Loader_EndGlyphFunc    forget_glyph_frame;
1493*37da2899SCharles.Forsyth     TT_Loader_ReadGlyphFunc   read_glyph_header;
1494*37da2899SCharles.Forsyth     TT_Loader_ReadGlyphFunc   read_simple_glyph;
1495*37da2899SCharles.Forsyth     TT_Loader_ReadGlyphFunc   read_composite_glyph;
1496*37da2899SCharles.Forsyth 
1497*37da2899SCharles.Forsyth     /* a typeless pointer to the SFNT_Interface table used to load     */
1498*37da2899SCharles.Forsyth     /* the basic TrueType tables in the face object                    */
1499*37da2899SCharles.Forsyth     void*                 sfnt;
1500*37da2899SCharles.Forsyth 
1501*37da2899SCharles.Forsyth     /* a typeless pointer to the PSNames_Interface table used to       */
1502*37da2899SCharles.Forsyth     /* handle glyph names <-> unicode & Mac values                     */
1503*37da2899SCharles.Forsyth     void*                 psnames;
1504*37da2899SCharles.Forsyth 
1505*37da2899SCharles.Forsyth     /***********************************************************************/
1506*37da2899SCharles.Forsyth     /*                                                                     */
1507*37da2899SCharles.Forsyth     /* Optional TrueType/OpenType tables                                   */
1508*37da2899SCharles.Forsyth     /*                                                                     */
1509*37da2899SCharles.Forsyth     /***********************************************************************/
1510*37da2899SCharles.Forsyth 
1511*37da2899SCharles.Forsyth     /* horizontal device metrics */
1512*37da2899SCharles.Forsyth     TT_HdmxRec            hdmx;
1513*37da2899SCharles.Forsyth 
1514*37da2899SCharles.Forsyth     /* grid-fitting and scaling table */
1515*37da2899SCharles.Forsyth     TT_GaspRec            gasp;                 /* the `gasp' table */
1516*37da2899SCharles.Forsyth 
1517*37da2899SCharles.Forsyth     /* PCL 5 table */
1518*37da2899SCharles.Forsyth     TT_PCLT               pclt;
1519*37da2899SCharles.Forsyth 
1520*37da2899SCharles.Forsyth     /* embedded bitmaps support */
1521*37da2899SCharles.Forsyth     FT_ULong              num_sbit_strikes;
1522*37da2899SCharles.Forsyth     TT_SBit_Strike        sbit_strikes;
1523*37da2899SCharles.Forsyth 
1524*37da2899SCharles.Forsyth     FT_ULong              num_sbit_scales;
1525*37da2899SCharles.Forsyth     TT_SBit_Scale         sbit_scales;
1526*37da2899SCharles.Forsyth 
1527*37da2899SCharles.Forsyth     /* postscript names table */
1528*37da2899SCharles.Forsyth     TT_Post_NamesRec      postscript_names;
1529*37da2899SCharles.Forsyth 
1530*37da2899SCharles.Forsyth 
1531*37da2899SCharles.Forsyth     /***********************************************************************/
1532*37da2899SCharles.Forsyth     /*                                                                     */
1533*37da2899SCharles.Forsyth     /* TrueType-specific fields (ignored by the OTF-Type2 driver)          */
1534*37da2899SCharles.Forsyth     /*                                                                     */
1535*37da2899SCharles.Forsyth     /***********************************************************************/
1536*37da2899SCharles.Forsyth 
1537*37da2899SCharles.Forsyth     /* the glyph locations */
1538*37da2899SCharles.Forsyth     FT_UShort             num_locations;
1539*37da2899SCharles.Forsyth     FT_Long*              glyph_locations;
1540*37da2899SCharles.Forsyth 
1541*37da2899SCharles.Forsyth     /* the font program, if any */
1542*37da2899SCharles.Forsyth     FT_ULong              font_program_size;
1543*37da2899SCharles.Forsyth     FT_Byte*              font_program;
1544*37da2899SCharles.Forsyth 
1545*37da2899SCharles.Forsyth     /* the cvt program, if any */
1546*37da2899SCharles.Forsyth     FT_ULong              cvt_program_size;
1547*37da2899SCharles.Forsyth     FT_Byte*              cvt_program;
1548*37da2899SCharles.Forsyth 
1549*37da2899SCharles.Forsyth     /* the original, unscaled, control value table */
1550*37da2899SCharles.Forsyth     FT_ULong              cvt_size;
1551*37da2899SCharles.Forsyth     FT_Short*             cvt;
1552*37da2899SCharles.Forsyth 
1553*37da2899SCharles.Forsyth     /* the format 0 kerning table, if any */
1554*37da2899SCharles.Forsyth     FT_Int                num_kern_pairs;
1555*37da2899SCharles.Forsyth     FT_Int                kern_table_index;
1556*37da2899SCharles.Forsyth     TT_Kern0_Pair         kern_pairs;
1557*37da2899SCharles.Forsyth 
1558*37da2899SCharles.Forsyth     /* A pointer to the bytecode interpreter to use.  This is also */
1559*37da2899SCharles.Forsyth     /* used to hook the debugger for the `ttdebug' utility.        */
1560*37da2899SCharles.Forsyth     TT_Interpreter        interpreter;
1561*37da2899SCharles.Forsyth 
1562*37da2899SCharles.Forsyth 
1563*37da2899SCharles.Forsyth     /***********************************************************************/
1564*37da2899SCharles.Forsyth     /*                                                                     */
1565*37da2899SCharles.Forsyth     /* Other tables or fields. This is used by derivative formats like     */
1566*37da2899SCharles.Forsyth     /* OpenType.                                                           */
1567*37da2899SCharles.Forsyth     /*                                                                     */
1568*37da2899SCharles.Forsyth     /***********************************************************************/
1569*37da2899SCharles.Forsyth 
1570*37da2899SCharles.Forsyth     FT_Generic            extra;
1571*37da2899SCharles.Forsyth 
1572*37da2899SCharles.Forsyth   } TT_FaceRec;
1573*37da2899SCharles.Forsyth 
1574*37da2899SCharles.Forsyth 
1575*37da2899SCharles.Forsyth   /*************************************************************************/
1576*37da2899SCharles.Forsyth   /*                                                                       */
1577*37da2899SCharles.Forsyth   /*  <Struct>                                                             */
1578*37da2899SCharles.Forsyth   /*     TT_GlyphZoneRec                                                   */
1579*37da2899SCharles.Forsyth   /*                                                                       */
1580*37da2899SCharles.Forsyth   /*  <Description>                                                        */
1581*37da2899SCharles.Forsyth   /*     A glyph zone is used to load, scale and hint glyph outline        */
1582*37da2899SCharles.Forsyth   /*     coordinates.                                                      */
1583*37da2899SCharles.Forsyth   /*                                                                       */
1584*37da2899SCharles.Forsyth   /*  <Fields>                                                             */
1585*37da2899SCharles.Forsyth   /*     memory       :: A handle to the memory manager.                   */
1586*37da2899SCharles.Forsyth   /*                                                                       */
1587*37da2899SCharles.Forsyth   /*     max_points   :: The maximal size in points of the zone.           */
1588*37da2899SCharles.Forsyth   /*                                                                       */
1589*37da2899SCharles.Forsyth   /*     max_contours :: Max size in links contours of thez one.           */
1590*37da2899SCharles.Forsyth   /*                                                                       */
1591*37da2899SCharles.Forsyth   /*     n_points     :: The current number of points in the zone.         */
1592*37da2899SCharles.Forsyth   /*                                                                       */
1593*37da2899SCharles.Forsyth   /*     n_contours   :: The current number of contours in the zone.       */
1594*37da2899SCharles.Forsyth   /*                                                                       */
1595*37da2899SCharles.Forsyth   /*     org          :: The original glyph coordinates (font              */
1596*37da2899SCharles.Forsyth   /*                     units/scaled).                                    */
1597*37da2899SCharles.Forsyth   /*                                                                       */
1598*37da2899SCharles.Forsyth   /*     cur          :: The current glyph coordinates (scaled/hinted).    */
1599*37da2899SCharles.Forsyth   /*                                                                       */
1600*37da2899SCharles.Forsyth   /*     tags         :: The point control tags.                           */
1601*37da2899SCharles.Forsyth   /*                                                                       */
1602*37da2899SCharles.Forsyth   /*     contours     :: The contours end points.                          */
1603*37da2899SCharles.Forsyth   /*                                                                       */
1604*37da2899SCharles.Forsyth   typedef struct  TT_GlyphZoneRec_
1605*37da2899SCharles.Forsyth   {
1606*37da2899SCharles.Forsyth     FT_Memory   memory;
1607*37da2899SCharles.Forsyth     FT_UShort   max_points;
1608*37da2899SCharles.Forsyth     FT_UShort   max_contours;
1609*37da2899SCharles.Forsyth     FT_UShort   n_points;   /* number of points in zone    */
1610*37da2899SCharles.Forsyth     FT_Short    n_contours; /* number of contours          */
1611*37da2899SCharles.Forsyth 
1612*37da2899SCharles.Forsyth     FT_Vector*  org;        /* original point coordinates  */
1613*37da2899SCharles.Forsyth     FT_Vector*  cur;        /* current point coordinates   */
1614*37da2899SCharles.Forsyth 
1615*37da2899SCharles.Forsyth     FT_Byte*    tags;       /* current touch flags         */
1616*37da2899SCharles.Forsyth     FT_UShort*  contours;   /* contour end points          */
1617*37da2899SCharles.Forsyth 
1618*37da2899SCharles.Forsyth   } TT_GlyphZoneRec, *TT_GlyphZone;
1619*37da2899SCharles.Forsyth 
1620*37da2899SCharles.Forsyth 
1621*37da2899SCharles.Forsyth   /* handle to execution context */
1622*37da2899SCharles.Forsyth   typedef struct TT_ExecContextRec_*  TT_ExecContext;
1623*37da2899SCharles.Forsyth 
1624*37da2899SCharles.Forsyth   /* glyph loader structure */
1625*37da2899SCharles.Forsyth   typedef struct  TT_LoaderRec_
1626*37da2899SCharles.Forsyth   {
1627*37da2899SCharles.Forsyth     FT_Face          face;
1628*37da2899SCharles.Forsyth     FT_Size          size;
1629*37da2899SCharles.Forsyth     FT_GlyphSlot     glyph;
1630*37da2899SCharles.Forsyth     FT_GlyphLoader   gloader;
1631*37da2899SCharles.Forsyth 
1632*37da2899SCharles.Forsyth     FT_ULong         load_flags;
1633*37da2899SCharles.Forsyth     FT_UInt          glyph_index;
1634*37da2899SCharles.Forsyth 
1635*37da2899SCharles.Forsyth     FT_Stream        stream;
1636*37da2899SCharles.Forsyth     FT_Int           byte_len;
1637*37da2899SCharles.Forsyth 
1638*37da2899SCharles.Forsyth     FT_Short         n_contours;
1639*37da2899SCharles.Forsyth     FT_BBox          bbox;
1640*37da2899SCharles.Forsyth     FT_Int           left_bearing;
1641*37da2899SCharles.Forsyth     FT_Int           advance;
1642*37da2899SCharles.Forsyth     FT_Int           linear;
1643*37da2899SCharles.Forsyth     FT_Bool          linear_def;
1644*37da2899SCharles.Forsyth     FT_Bool          preserve_pps;
1645*37da2899SCharles.Forsyth     FT_Vector        pp1;
1646*37da2899SCharles.Forsyth     FT_Vector        pp2;
1647*37da2899SCharles.Forsyth 
1648*37da2899SCharles.Forsyth     FT_ULong         glyf_offset;
1649*37da2899SCharles.Forsyth 
1650*37da2899SCharles.Forsyth     /* the zone where we load our glyphs */
1651*37da2899SCharles.Forsyth     TT_GlyphZoneRec  base;
1652*37da2899SCharles.Forsyth     TT_GlyphZoneRec  zone;
1653*37da2899SCharles.Forsyth 
1654*37da2899SCharles.Forsyth     TT_ExecContext   exec;
1655*37da2899SCharles.Forsyth     FT_Byte*         instructions;
1656*37da2899SCharles.Forsyth     FT_ULong         ins_pos;
1657*37da2899SCharles.Forsyth 
1658*37da2899SCharles.Forsyth     /* for possible extensibility in other formats */
1659*37da2899SCharles.Forsyth     void*            other;
1660*37da2899SCharles.Forsyth 
1661*37da2899SCharles.Forsyth   } TT_LoaderRec;
1662*37da2899SCharles.Forsyth 
1663*37da2899SCharles.Forsyth 
1664*37da2899SCharles.Forsyth FT_END_HEADER
1665*37da2899SCharles.Forsyth 
1666*37da2899SCharles.Forsyth #endif /* __TTTYPES_H__ */
1667*37da2899SCharles.Forsyth 
1668*37da2899SCharles.Forsyth 
1669*37da2899SCharles.Forsyth /* END */
1670