topical media & game development

talk show tell print

lib-of-vs-libs-free-type-2.1.4-include-freetype2-freetype-ftsnames.h / h



  
************************************************************************

  
  /*                                                                         */
  /*  ftsnames.h                                                             */
  /*                                                                         */
  /*    Simple interface to access SFNT name tables (which are used          */
  /*    to hold font names, copyright info, notices, etc.) (specification).  */
  /*                                                                         */
  /*    This is _not_ used to retrieve glyph names!                          */
  /*                                                                         */
  /*  Copyright 1996-2001, 2002 by                                           */
  /*  David Turner, Robert Wilhelm, and Werner Lemberg.                      */
  /*                                                                         */
  /*  This file is part of the FreeType project, and may only be used,       */
  /*  modified, and distributed under the terms of the FreeType project      */
  /*  license, LICENSE.TXT.  By continuing to use, modify, or distribute     */
  /*  this file you indicate that you have read the license and              */
  /*  understand and accept it fully.                                        */
  /*                                                                         */
  
************************************************************************

  
  
  ifndef __FT_SFNT_NAMES_H__
  define __FT_SFNT_NAMES_H__
  
  include <ft2build.h>
  include FT_FREETYPE_H
  
  FT_BEGIN_HEADER
  
    
**********************************************************************

  
    /*                                                                       */
    /* <Section>                                                             */
    /*    sfnt_names                                                         */
    /*                                                                       */
    /* <Title>                                                               */
    /*    SFNT Names                                                         */
    /*                                                                       */
    /* <Abstract>                                                            */
    /*    Access the names embedded in TrueType and OpenType files.          */
    /*                                                                       */
    /* <Description>                                                         */
    /*    The TrueType and OpenType specification allow the inclusion of     */
    /*    a special `names table' in font files.  This table contains        */
    /*    textual (and internationalized) information regarding the font,    */
    /*    like family name, copyright, version, etc.                         */
    /*                                                                       */
    /*    The definitions below are used to access them if available.        */
    /*                                                                       */
    /*    Note that this has nothing to do with glyph names!                 */
    /*                                                                       */
    
**********************************************************************

  
  
    
**********************************************************************

  
    /*                                                                       */
    /* <Struct>                                                              */
    /*    FT_SfntName                                                        */
    /*                                                                       */
    /* <Description>                                                         */
    /*    A structure used to model an SFNT `name' table entry.              */
    /*                                                                       */
    /* <Fields>                                                              */
    /*    platform_id :: The platform ID for `string'.                       */
    /*                                                                       */
    /*    encoding_id :: The encoding ID for `string'.                       */
    /*                                                                       */
    /*    language_id :: The language ID for `string'.                       */
    /*                                                                       */
    /*    name_id     :: An identifier for `string'.                         */
    /*                                                                       */
    /*    string      :: The `name' string.  Note that its format differs    */
    /*                   depending on the (platform,encoding) pair. It can   */
    /*                   be a Pascal String, a UTF-16 one, etc..             */
    /*                                                                       */
    /*                   Generally speaking, the string is not               */
    /*                   zero-terminated. Please refer to the TrueType       */
    /*                   specification for details..                         */
    /*                                                                       */
    /*    string_len  :: The length of `string' in bytes.                    */
    /*                                                                       */
    /* <Note>                                                                */
    /*    Possible values for `platform_id', `encoding_id', `language_id',   */
    /*    and `name_id' are given in the file `ttnameid.h'.  For details     */
    /*    please refer to the TrueType or OpenType specification.            */
    /*                                                                       */
    typedef struct  FT_SfntName_
    {
      FT_UShort  platform_id;
      FT_UShort  encoding_id;
      FT_UShort  language_id;
      FT_UShort  name_id;
  
      FT_Byte*   string;      /* this string is *not* null-terminated! */
      FT_UInt    string_len;  /* in bytes */
  
    } FT_SfntName;
  
    
**********************************************************************

  
    /*                                                                       */
    /* <Function>                                                            */
    /*    FT_Get_Sfnt_Name_Count                                             */
    /*                                                                       */
    /* <Description>                                                         */
    /*    Retrieves the number of name strings in the SFNT `name' table.     */
    /*                                                                       */
    /* <Input>                                                               */
    /*    face :: A handle to the source face.                               */
    /*                                                                       */
    /* <Return>                                                              */
    /*    The number of strings in the `name' table.                         */
    /*                                                                       */
    FT_EXPORT( FT_UInt )
    FT_Get_Sfnt_Name_Count( FT_Face  face );
  
    
**********************************************************************

  
    /*                                                                       */
    /* <Function>                                                            */
    /*    FT_Get_Sfnt_Name                                                   */
    /*                                                                       */
    /* <Description>                                                         */
    /*    Retrieves a string of the SFNT `name' table for a given index.     */
    /*                                                                       */
    /* <Input>                                                               */
    /*    face  :: A handle to the source face.                              */
    /*                                                                       */
    /*    idx   :: The index of the `name' string.                           */
    /*                                                                       */
    /* <Output>                                                              */
    /*    aname :: The indexed FT_SfntName structure.                        */
    /*                                                                       */
    /* <Return>                                                              */
    /*    FreeType error code.  0 means success.                             */
    /*                                                                       */
    /* <Note>                                                                */
    /*    The `string' array returned in the `aname' structure is not        */
    /*    null-terminated.                                                   */
    /*                                                                       */
    /*    Use FT_Get_Sfnt_Name_Count() to get the total number of available  */
    /*    `name' table entries, then do a loop until you get the right       */
    /*    platform, encoding, and name ID.                                   */
    /*                                                                       */
    FT_EXPORT( FT_Error )
    FT_Get_Sfnt_Name( FT_Face       face,
                      FT_UInt       idx,
                      FT_SfntName  *aname );
  
    /* */
  
  FT_END_HEADER
  
  endif /* __FT_SFNT_NAMES_H__ */
  
  /* END */
  


(C) Æliens 04/09/2009

You may not copy or print any of this material without explicit permission of the author or the publisher. In case of other copyright issues, contact the author.