apirefx.txt   [plain text]


                        The FreeType Engine

                    Extension Library Reference


                -----------------------------------


  Table of Contents:

    I. Engine extensions
      1. kerning (ftxkern)
      2. PostScript names (ftxpost)
      3. TrueType Open (ftxopen)
         a. The `BASE' table (baseline data)
         b. The `GDEF' table (glyph definitions)
         c. The `GPOS' table (glyph positions)
         d. The `GSUB' table (glyph substitions)
         e. The `JSTF' table (justification data)
         f. auxiliary functions
      4. embedded bitmaps (ftxsbit)

    II. API extensions
      1. cmap iteration (ftxcmap)
      2. internationalized error messages (ftxerr18)
      3. access to the `gasp' table (ftxgasp)
      4. fast retrieval of glyph widths and heights (ftxwidth)

    III. Error codes


                        --------------------


Please read the file  `user.txt' for an introduction into FreeType's
extension  mechanism  and  the  difference between  engine  and  API
extensions.


I. Engine extensions
====================

To use  engine extensions you have  to compile the  library with the
macro TT_CONFIG_OPTION_EXTEND_ENGINE.  By default, this macro is set
and all engine extensions are linked to the FreeType library.


 1. kerning (ftxkern)
 --------------------

  TT_Init_Kerning_Extension( TT_Engine  engine )

    Initializes the kerning extension for a given engine.  This must
    be called  just after the  engine creation, and before  any face
    object allocation.  Example:

      TT_Init_FreeType( &engine );
      TT_Init_Kerning_Extension( engine );

  ..................................................................

  TT_Get_Kerning_Directory( TT_Face      face,
                            TT_Kerning*  directory )

    Queries the  kerning directory  found in a  face object.   If no
    kerning  table  is  found   in  the  TrueType  file,  the  error
    TT_Err_Table_Is_Missing will be returned.

    You  can  access  the  subtables  through the  pointers  of  the
    directory.  However, by default, the directory is only loaded if
    a  face object  is created.   You must  load the  subtables that
    interest you with a call to TT_Load_Kerning_Table().

    The  layout of  all kerning  structures is  defined in  the file
    `lib/extend/ftxkern.h'.   Formats 0  and  2 (as  defined in  the
    Microsoft TrueType specification) are exposed by this API.

    NOTE:

      This function  must be called after the  kerning extension has
      been initialized.

  ..................................................................

  TT_Load_Kerning_Table( TT_Face    face,
                         TT_UShort  kernIndex )

    Loads the kerning subtable number `kern_index' into memory.  The
    subtable can  be accessed through  the pointers provided  by the
    kerning  directory,  obtained  from   a  call  to  the  function
    TT_Get_Kerning_Directory().

    Note that the interpretation of  the kerning data is left to the
    client  application.  Read the  TrueType specification  for more
    information on kerning encoding.

    NOTE 1:

      This function must be  called after the kerning extension were
      initialized.

    NOTE 2:

      An example can be found in the file `test/ftstrtto.c'.


====================================================================


 2. PostScript names (ftxpost)
 -----------------------------

  TT_Init_Post_Extension( TT_Engine  engine )

    Initializes the PostScript name extension to load the PostScript
    glyph names given in the `post' table.  This must be called just
    after  creation  of  the  engine,  and before  any  face  object
    allocation.  See description of TT_Get_PS_Name() for an example.

  ..................................................................

  TT_Load_PS_Names( TT_Face   face,
                    TT_Post*  post )

    Loads the PostScript glyph names into memory.  This must be done
    before  TT_Get_PS_Name() is  called.  In  case of  error, either
    TT_Err_Invalid_Post_Table or TT_Err_Invalid_Post_Table_Format is
    returned.  See description of TT_Get_PS_Name() for an example.

  ..................................................................

  TT_Get_PS_Name( TT_Face      face,
                  TT_UShort    index,
                  TT_String**  PSname )

    Get  the PostScript  glyph  name  for a  given  glyph index.   A
    pointer to the name is returned in `PSname'.  Example:

      ...
      TT_Post  post;
      char*    PSname;

      ...
      TT_Init_Post_Extension( engine );
      TT_Load_PS_Names( face, &post );

      ...
      TT_Get_PS_Name( face, index, &PSname );


    NOTE:

      You must  not alter the PostScript glyph  name string returned
      in `PSname'.


====================================================================


 3. TrueType Open (ftxopen)
 --------------------------

  Please note that TrueType Open specific error codes have the
  prefix `TTO_Err_' instead of `TT_Err_'.

  a. The `BASE' table (baseline data)

    Not yet supported.

  b. The `GDEF' table (glyph definitions)

    TT_Init_GDEF_Extension( TT_Engine  engine )

      Initializes the  GDEF extension  to load the  glyph definition
      data  given in  the `GDEF'  table.  This  must be  called just
      after  creation of  the  engine, and  before  any face  object
      allocation.  See the file `ftstrtto.c' for an example.

    ................................................................

    TT_Load_GDEF_Table( TT_Face          face,
                        TTO_GDEFHeader*  gdef )

      Loads  the GDEF  table into  `gdef' for  a given  face `face'.
      This must  be done before  any queries about  glyph properties
      with TT_GSUB_Get_Property().   Returns TT_Err_Table_Missing if
      there is no GDEF table in the font.

    ................................................................

    TT_GDEF_Get_Glyph_Property( TTO_GDEFHeader*  gdef,
                                TT_UShort        glyphID,
                                TT_UShort*       property )

      Use  this function  to get  glyph properties  in  the variable
      `property' for  the glyph with  index `glyphID' stored  in the
      `gdef'  table.   This data  is  essential  for  many fonts  to
      correctly apply contextual  substitution (both GSUB and GPOS).
      As a special case, zero is assigned to `property' if `gdef' is
      NULL or  the glyph has  no special glyph property  assigned to
      it.   The  other return  values  of  `property' are  TTO_BASE,
      TTO_LIGATURE,  TTO_MARK, and  TTO_COMPONENT; you  can directly
      apply the `LookupFlag' mask to check for certain properties:

        TTO_GDEFHeader*  gdef;
        TTO_Lookup*      lo;
        TT_UShort        glyph_ID;
        TT_UShort        p;      


        TT_GDEF_Get_Property( gdef, glyph_ID, &p );

        if ( p & lo->LookupFlag )
          return TTO_Err_Not_Covered;

      Usually, you  don't need to  take care of glyph  properties by
      yourself since TT_GSUB_Apply_String() will  do this for you by
      calling TT_GDEF_Get_Property().

      Some  fonts need  GDEF-like  data  even if  no  GDEF table  is
      provided  (for example,  the Arabic  script  needs information
      which glyphs are  base glyphs and which are  mark glyphs).  In
      such cases, you  should use TT_GDEF_Build_ClassDefinition() to
      build the necessary  structures so that TT_GDEF_Get_Property()
      returns meaningful values.

      See also TT_Load_GSUB_Table() and TT_Load_GPOS_Table().

    ................................................................

    TT_GDEF_Build_ClassDefinition( TTO_GDEFHeader*  gdef,
                                   TT_UShort        num_glyphs,
                                   TT_UShort        glyph_count,
                                   TT_UShort*       glyph_array,
                                   TT_UShort*       class_array )

      Fills    a    `gdef'    structure    with   data    to    make
      TT_GDEF_Get_Property()   work  in  case   no  GDEF   table  is
      available.  `num_glyphs' is the  number of glyphs in the font.

      `glyph_count' is the number  of glyphs resp.  class values (as
      specified  in  the GDEF  specification)  given  in the  arrays
      `glyph_array'  and  `class_array',  respectively.   The  glyph
      indices in  `glyph_array' must be all different  and sorted in
      ascending  order;  the   function  expects  that  glyph  index
      `glyph_array[n]' has its class value in `class_array[n]'.

      Note that mark  attach classes as defined in  OpenType 1.2 are
      not supported for constructed GDEF tables.

      See `arabic.c' for an example.


  c. The `GPOS' table (glyph positions)

    Not yet supported.


  d. The `GSUB' table (glyph substitions)

    For glyph substitution, a  string object of type TTO_GSUB_String
    is used.   The field  `length' holds the  length of  the string,
    `pos' points to the actual position in the glyph string `string'
    (for  input strings)  resp. the  position where  the substituted
    glyphs should be placed at (for output strings).

    Within the  `properties' array (which must always  have the same
    length as `string' if set), you can define properties for glyphs
    -- `string[n]' is associated  with `properties[n]'.  The idea is
    that  some  features  apply  to  specific glyphs  only.   As  an
    example, the  `fina' feature for  Arabic applies only  to glyphs
    which  appear at  the end  of  a word  (strictly speaking,  this
    feature is used  only for glyphs which have  a `final' property;
    such glyphs can occur in the middle of a word also under certain
    circumstances which  is dependent on Arabic  script rules).  The
    relationship between properties and  features can be set up with
    the function  TT_GSUB_Add_Feature().  If `properties'  is set to
    NULL, all  selected features  apply to all  glyphs in  the given
    string object.  If `properties' is non-NULL, the elements of the
    array  are treated as  bit fields.   A set  flag means  that the
    corresponding  feature (as  set  with the  TT_GSUB_Add_Feature()
    function) should not  be applied to the particular  glyph.  As a
    consequence,  a zero  value for  these  16 bits  means that  all
    features should be  applied, and a value of  0xFFFF implies that
    no feature at all should be used for the glyph.

    The field `allocated'  is for internal use only  and must not be
    modified.   If its  value is  larger than  zero, you  should use
    free()  to   deallocate  the   memory  used  by   `string'  (and
    `properties'   if  set)   in  case   you  want   to   destroy  a
    TTO_GSUB_String object (memory  for `string' and `properties' is
    allocated  automatically  e.g.   by  TT_GSUB_Apply_String()  for
    output string objects).

      struct  TTO_GSUB_String_
      {
        TT_ULong    length;
        TT_ULong    pos;
        TT_ULong    allocated;
        TT_UShort*  string;
        TT_UShort*  properties;
      };

      typedef struct TTO_GSUB_String_  TTO_GSUB_String;

    Note  that the `string'  field must  contain glyph  indices, not
    character codes.

    For  initializing an  input string  object, you  should  set the
    `length', `string',  and `properties' fields (the  last one only
    if necessary) to appropriate values.  `pos' has to be set to the
    position  where the substitution  lookups should  start (usually
    zero).  The `allocated' field will be ignored.

    For  initializing an  output string  object, all  fields (except
    `length' which  will be  ignored) must be  set to zero.   If you
    want to  reuse the object, set  `pos' to the  position where the
    substituted glyphs should be placed at (usually zero), but don't
    touch the `allocated', `string', and `properties' fields.

    ................................................................

    TT_Init_GSUB_Extension( TT_Engine  engine )

      Initializes the GSUB extension  to load the glyph substitution
      data  given in  the `GSUB'  table.  This  must be  called just
      after  creation of  the  engine, and  before  any face  object
      allocation.   See the  files `ftstrtto.c'  and  `ftdump.c' for
      detailed examples.

    ................................................................

    TT_Load_GSUB_Table( TT_Face          face,
                        TTO_GSUBHeader*  gsub,
                        TTO_GDEFHeader*  gdef )

      Loads  the GSUB  table into  `gsub' for  a given  face `face'.
      This must  be done  before any queries  about or  selection of
      scripts,      languages,      and      features.       Returns
      TT_Err_Table_Missing if there is no GSUB table in the font.

      `gdef' should  contain a pointer to an  associated GDEF table,
      either  a  native  one  loaded  with  TT_Load_GDEF_Table()  or
      emulated  with TT_GDEF_Build_ClassDefinition().  If  `gdef' is
      set to NULL, no GDEF data will be used.

    ................................................................

    TT_GSUB_Select_Script( TTO_GSUBHeader*  gsub,
                           TT_ULong         script_tag,
                           TT_UShort*       script_index )

      This  function sets  the script  index of  a given  script tag
      `script_tag' in the variable `script_index' for the GSUB table
      `gsub'.  Returns TTO_Err_Not_Covered  if the script tag cannot
      be found.  The  available script tags can be  queried with the
      function TT_GSUB_Query_Scripts().

    ................................................................

    TT_GSUB_Select_Language( TTO_GSUBHeader*  gsub,
                             TT_ULong         language_tag,
                             TT_UShort        script_index,
                             TT_UShort*       language_index,
                             TT_UShort*       req_feature_index )

      This function sets the language  index of a given language tag
      `language_tag' and script index `script_index' in the variable
      `language_index'   for  the   GSUB   table  `gsub'.    Returns
      TTO_Err_Not_Covered if the language  tag cannot be found.  The
      available  language  tags can  be  queried  with the  function
      TT_GSUB_Query_Languages().

      Additionally,  the  index of  the  required  feature for  this
      language system is returned in `req_feature_index'; it must be
      later registered for use with TT_GSUB_Add_Feature().

    ................................................................

    TT_GSUB_Select_Feature( TTO_GSUBHeader*  gsub,
                            TT_ULong         feature_tag,
                            TT_UShort        script_index,
                            TT_UShort        language_index,
                            TT_UShort*       feature_index )

      This  function  sets  the  feature  index  of  a  feature  tag
      `feature_tag', script index `script_index', and language index
      `language_index' in the  variable `feature_index' for the GSUB
      table `gsub'.  Returns  TTO_Err_Not_Covered if the feature tag
      cannot be  found.  The available  feature tags can  be queried
      with    the   function    TT_GSUB_Query_Features().    Setting
      language_index to 0xFFFF selects the default language system.

    ................................................................

    TT_GSUB_Query_Scripts( TTO_GSUBHeader*  gsub,
                           TT_ULong**       script_tag_list )

      Returns  the available  script  tags for  a  given GSUB  table
      `gsub' in the array `script_tag_list'.  The array can be later
      deallocated with free().

    ................................................................

    TT_GSUB_Query_Languages( TTO_GSUBHeader*  gsub,
                             TT_UShort        script_index,
                             TT_ULong**       language_tag_list )

      Returns  the available language  tags for  a given  GSUB table
      `gsub'   and  script   index  `script_index'   in   the  array
      `language_tag_list'.  The array  can be later deallocated with
      free().

    ................................................................

    TT_GSUB_Query_Features( TTO_GSUBHeader*  gsub,
                            TT_UShort        script_index,
                            TT_UShort        language_index,
                            TT_ULong**       feature_tag_list )

      Returns  the available  feature tags  for a  given  GSUB table
      `gsub',  script  index   `script_index',  and  language  index
      `language_index' in the array `feature_tag_list'.  If language
      index is  set to 0xFFFF,  the values for the  default language
      system are returned.  The  array can be later deallocated with
      free().

    ................................................................

    TT_GSUB_Add_Feature( TTO_GSUBHeader*  gsub,
                         TT_UShort        feature_index,
                         TT_UShort        property )

      To  prepare  a  call  to TT_GSUB_Apply_String()  which  should
      process  a given  feature with  index `feature_index'  and the
      property `property', you must  use this function.  Its task is
      to  mark the  lookup tables  used by  the feature  for further
      processing.

      `property'  defines a  relationship between  the  input string
      object and the specific  feature.  The client must handle this
      variable as a bit field, i.e., up to 16 user properties can be
      defined.  If `property' is set to ALL_GLYPHS (0xFFFF, the only
      predefined value),  or if the  input string object has  no set
      bits  in the `properties'  field, the  feature applies  to all
      glyphs.  If bit `x' is  set in `property', the feature applies
      only  to  glyphs  which  have  bit  `x'  not  set  in  glyph's
      `properties'   field  in   the  input   string   object.   See
      TT_GSUB_Apply_String() for an example.

      Returns TT_Err_Invalid_Argument in case of error.

    ................................................................

    TT_GSUB_Clear_Features( TTO_GSUBHeader*  gsub )

      Clears the  list of used  features and properties.   No lookup
      tables will be processed.

    ................................................................

    TT_GSUB_Register_Alternate_Function( TTO_GSUBHeader*  gsub,
                                         TTO_AltFunction  alt,
                                         void*            data )

      Installs   a    callback   function   to    handle   alternate
      substitutions.  `data' is a  generic pointer to a user-defined
      structure  which will  be  completely ignored  by the  ftxopen
      extension.  `alt' is a function pointer defined as

        typedef TT_UShort
                (*TTO_AltFunction)(TT_ULong    pos,
                                   TT_UShort   glyphID,
                                   TT_UShort   num_alternates,
                                   TT_UShort*  alternates,
                                   void*       data );

      If TT_GSUB_Apply_String() encounters an alternate lookup while
      processing the  input string, it will call  the function `alt'
      to find out which alternate  glyph it should use.  `pos' gives
      the  position in  the string,  `glyphID' the  glyph ID  of the
      glyph   to  be   replaced   with  an   alternate  glyph,   and
      `num_alternates'  the  number   of  alternate  glyphs  in  the
      `alternates'  array.   A pointer  to  the user-defined  `data'
      structure is also available.   `alt' must return an index into
      `alternates'.

      If  `alt' is NULL  or if  this function  isn't called  at all,
      TT_GSUB_Apply_String()  will always  use  the first  alternate
      glyph.

      Please note that theoretically  an alternate lookup can happen
      during any other lookup!  For example, a lookup chain like

        single subst -> alternate subst -> ligature subst

      *is* possible  (albeit rather unlikely).  Thus  be warned that
      `pos' does not necessarily reflect  the position of a glyph to
      be  displayed at  all, nor  does `glyphID'  specifies  a glyph
      which will be in the final output string.

    ................................................................

    TT_GSUB_Apply_String( TTO_GSUBHeader*   gsub,
                          TTO_GSUB_String*  in,
                          TTO_GSUB_String*  out )

      This  is the  very function  which handles  glyph substitution
      according to  the features set  up with TT_GSUB_Add_Feature(),
      using   both   GSUB  and   GDEF   data   (if  defined).    Two
      TTO_GSUB_String  objects `in' and  `out' (as  described above)
      are taken  for input and output;  after successful excecution,
      the  converted  glyph string  can  been  found  in `out',  and
      `out.length'  gives the  actual  length of  the output  string
      (counted from the begin of the array).

      Example:

        /* We assume that the feature `xxxx' has index 5, and  */
        /* feature `yyyy' has index 8, applying only to glyphs */
        /* with the property `FINAL_GLYPHS' set (0x1000 is an  */
        /* ad-hoc value just for this example).                */

        /* The order of calls to TT_GSUB_Add_Feature() is not  */
        /* significant.                                        */

        #define FINAL_GLYPHS  0x1000

        TT_GSUB_Clear_Features( &gsub );
        TT_GSUB_Add_Feature( &gsub, 8, FINAL_GLYPHS );
        TT_GSUB_Add_Feature( &gsub, 5, ALL_GLYPHS );

        TT_GSUB_Apply_String( &gsub, &in, &out );

      You must initialize both `in' and `out' structures; allocation
      necessary for the `out' object will be handled automatically.

      In  case you  don't register  a function  to  handle alternate
      substitutions  (GSUB  lookup 3),  always  the first  alternate
      glyph will be used.  See TT_GSUB_Register_Alternate_Function()
      above for more details.


  e. The `JSTF' table (justification data)

    Not yet supported.


  f. auxiliary functions

    TT_GSUB_Add_String( TTO_GSUB_String*  in,
                        TT_UShort         num_in,
                        TTO_GSUB_String*  out,
                        TT_UShort         num_out,
                        TT_UShort*        data )

      This function copies `num_out'  elements from `data' to `out',
      advancing the array pointer  `in.pos' by `num_in' elements and
      `out.pos'  by `num_out'  elements.  If  the string  (resp. the
      properties) array in `out' is empty or too small, it allocates
      resp.    reallocates  the   string  (and   properties)  array.
      Finally, it sets `out.length' equal to `out.pos'.

      The  properties for  all replaced  glyphs are  taken  from the
      glyph at position `in->pos'.

      TT_GSUB_Add_String()       is      normally       used      in
      TT_GSUB_Apply_String(); you will need  it for the special case
      to skip some glyphs (i.e.,  copy glyphs directly from the `in'
      to the `out' object), bypassing a possible GSUB substitution.

      Here an example which copies one glyph:

        TT_GSUB_Add_String( in, 1,
                            out, 1,
                            &in->string[in->pos] );


====================================================================

 
 4. embedded bitmaps (ftxsbit)
 -----------------------------

  TT_Init_SBit_Extension( TT_Engine  engine )

    Initializes  the embedded  bitmap extension  to load  the bitmap
    glyphs given in the various sbit tables: `EBLC', `bloc', `EBDT',
    and `bdat'  (`bloc' and `bdat'  tables are only in  Apple fonts;
    the  former is equivalent  to `EBLC',  the latter  equivalent to
    `EBDT').  This must be called just after creation of the engine,
    and  before  any face  object  allocation.   See description  of
    TT_Load_Glyph_Bitmap() for an example.

  ..................................................................

  TT_Get_Face_Bitmaps( TT_Face   face,
                       TT_EBLC*  eblc_table )

    Loads the `EBLC' (resp. `bloc')  table from a font file into the
    `eblc_table' structure.   Use this function  for testing whether
    embedded bitmaps are available or not.

    This function returns  TT_Err_Table_Missing if the font contains
    no embedded  bitmaps.  All fields  in `eblc_table' will  then be
    set to 0.

  ..................................................................

  TT_New_SBit_Image( TT_SBit_Image**  image )

    Allocates  a  new  embedded  bitmap  container,  pointed  to  by
    `image'.

  ..................................................................

  void  TT_Done_SBit_Image( TT_SBit_Image*  image )
  ^^^^

    Releases the embedded bitmap container `image'.

  ..................................................................

  TT_Get_SBit_Strike( TT_Face          face,
                      TT_Instance      instance,
                      TT_SBit_Strike*  strike )

    Loads a  suitable strike (i.e.  bitmap sizetable)  for the given
    instance.  Will return TT_Err_Invalid_PPem if there is no strike
    for the current x_ppem and y_ppem values.

  ..................................................................

  TT_Load_Glyph_Bitmap( TT_Face         face,
                        TT_Instance     instance,
                        TT_UShort       glyph_index,
                        TT_SBit_Image*  bitmap );

    Loads a glyph  bitmap for a given glyph  index `glyph_index' (in
    face `face'  and instance  `instance') into `bitmap'.   It calls
    TT_Get_SBit_Strike() internally for  checking the current x_ppem
    and y_ppem values.

    This function  returns an error  if there is no  embedded bitmap
    for the glyph at the given instance.

    Example (omitting the error handling):

      ...
      TT_SBit_Image*  bitmap;

      ...
      TT_Init_SBit_Extension( engine );
      TT_New_SBit_Image( &bitmap );
      ...
      TT_Load_Glyph_Bitmap( face, instance, glyph_index, bitmap );



--------------------------------------------------------------------
--------------------------------------------------------------------



II. API extensions
==================

To use  API extensions, simply  compile the specific  extension file
and  link  it to  the  library or  your  program.   By default,  all
extensions described below are linked to the library.


 1. cmap iteration (ftxcmap)
 ---------------------------

  TT_Long  TT_CharMap_First( TT_CharMap  charMap,
  ^^^^^^^                    TT_UShort*  glyph_index )


    Returns the first valid character  code in a given character map
    `charMap'.  Also  returns the corresponding glyph  index (in the
    parameter `*glyph_index').  In case  of failure, -1 is returned,
    and `*glyph_index' is undefined.

  ..................................................................

  TT_Long  TT_CharMap_Next( TT_CharMap  charMap,
  ^^^^^^^                   TT_UShort   last_char,
                            TT_UShort*  glyph_index )

    Returns the next  valid character code in a  given character map
    `charMap'   which  follows   `last_char'.    Also  returns   the
    corresponding glyph index (in the parameter `*glyph_index').  In
    case of failure, -1 is returned, and `glyph_index' is undefined.

  ..................................................................

  TT_Long  TT_CharMap_Last( TT_CharMap  charMap,
  ^^^^^^^                   TT_UShort*  glyph_index )


    Returns the last  valid character code in a  given character map
    `charMap'.  Also  returns the corresponding glyph  index (in the
    parameter `*glyph_index').  In case  of failure, -1 is returned,
    and `*glyph_index' is undefined.


====================================================================


 2. internationalized error messages (ftxerr18)
 ----------------------------------------------

  This extension  provides internationalized error  strings from the
  various  error  messages.   It   uses  the  `gettext'  package  if
  available  or  returns English/American  message  strings if  not.
  Currently,  the gettext  package  is only  available on  UNIX-like
  systems  like Linux;  this  means that  for  other platforms  only
  English error strings are returned.

  If  the gettext  package is  found on  your system,  the configure
  script  automatically includes it  by default.  In case  you don't
  want to use  it, or if you encounter  some problems compiling this
  file,  try to  disable nls  support by  configuring  FreeType with
  `./configure --disable-nls'.

  Please read the gettext info files for more information how to set
  up   your  system   for  internationalized   messages.    A  short
  introduction is also given in the file `i18n.txt'.


  TT_String*  TT_ErrToString18( TT_Error  i )
  ^^^^^^^^^^

    This function  returns an  error string for  a given  error code
    `i'.   The  type `TT_String'  usually  defaults  to `char';  see
    apiref.txt for more details.

    An  example how  to use  this function  (in connection  with the
    gettext interface) is given e.g. in test/ftdump.c.


====================================================================


 3. access to the `gasp' table (ftxgasp)
 ---------------------------------------

  The `gasp' table  is currently loaded by the  core engine, but the
  standard API doesn't give access to it.


  TT_Get_Face_Gasp_Flags( TT_Face    face,
                          TT_UShort  point_size,
                          TT_Bool*   grid_fit,
                          TT_Bool*   smooth_font )

    This function returns for a given `point_size' the values of the
    gasp  flags `grid_fit' and  `smooth_font'.  The  returned values
    are booleans (where 0 = NO, and 1 = YES).

    Note that this function  will return TT_Err_Table_Missing if the
    font file doesn't contain any gasp table.


====================================================================


 4. fast retrieval of glyph widths and heights (ftxwidth)
 --------------------------------------------------------

  This extension  is used  to parse the  `glyf' table of  a TrueType
  file in  order to  extract the  bounding box of  a given  range of
  glyphs.

  The  bounding box  is  then used  to  build font  unit widths  and
  heights that are returned in two parallel arrays.

  This extension is needed by the FreeType/2 OS/2 Font Driver.


  TT_Get_Face_Widths( TT_Face     face,
                      TT_UShort   first_glyph,
                      TT_UShort   last_glyph,
                      TT_UShort*  widths,
                      TT_UShort*  heights )

    Returns  the widths (in  array `widths')  and heights  (in array
    `heights') of  a glyph range  which starts at  `first_glyph' and
    ends at `last_glyph'.  All  returned values are returned in font
    units.   If  either `widths'  or  `heights'  is  set to  a  NULL
    pointer, no data will be returned for that particular array.

    Note: TT_Get_Face_Widths() does *not* allocate the two arrays!



--------------------------------------------------------------------
--------------------------------------------------------------------



III. Error Messages
===================

  Most functions return an error  code, typed to TT_Error.  A return
  value of zero indicates no error.  The error values are defined in
  the  various  extension header  files  (e.g.  ftxkern.h).  In  the
  following  table, the prefix  `TT_Err_' is  omitted, e.g.  `Ok' ->
  `TT_Err_Ok'.


  Error   Unprefixed               Error
  Code    Macro Name               Description
  ------------------------------------------------------------------

  0x0A00  Invalid_Kerning_Table_Format
                                   An invalid kerning subtable
                                   format was found in this font.

  0x0A01  Invalid_Kerning_Table    A kerning table contains illegal
                                   glyph indices.

  0x0B00  Invalid_Post_Table_Format
                                   The post table format specified
                                   in the font is invalid.

  0x0B01  Invalid_Post_Table       The post table contains illegal
                                   entries.


  Here the TrueType  Open error codes.  In the  following table, the
  prefix `TTO_Err_' is omitted.


  Error   Unprefixed               Error
  Code    Macro Name               Description
  ------------------------------------------------------------------
  0x1000  Invalid_SubTable_Format  The TrueType Open subtable format
                                   specified in the font is invalid.

  0x1001  Invalid_SubTable         A TrueType Open subtable contains
                                   illegal entries.

  0x1002  Not_Covered              The requested feature, glyph,
                                   etc. isn't covered by the actual
                                   function.

  0x1010  Invalid_GSUB_SubTable_Format
                                   The GSUB subtable format
                                   specified in the font is invalid.

  0x1011  Invalid_GSUB_SubTable    The GSUB subtable contains
                                   illegal entries.

  0x1020  Invalid_GPOS_SubTable_Format
                                   The GPOS subtable format
                                   specified in the font is invalid.

  0x1021  Invalid_GPOS_SubTable    The GPOS subtable contains
                                   illegal entries.


--- end of apirefx.txt ---