Subversion Repositories Kolibri OS

Rev

Go to most recent revision | Blame | Last modification | View Log | RSS feed

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