Home | History | Annotate | Download | only in include
      1 /***************************************************************************/
      2 /*                                                                         */
      3 /*  t1tables.h                                                             */
      4 /*                                                                         */
      5 /*    Basic Type 1/Type 2 tables definitions and interface (specification  */
      6 /*    only).                                                               */
      7 /*                                                                         */
      8 /*  Copyright 1996-2004, 2006, 2008, 2009, 2011 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 __T1TABLES_H__
     21 #define __T1TABLES_H__
     22 
     23 
     24 #include <ft2build.h>
     25 #include FT_FREETYPE_H
     26 
     27 #ifdef FREETYPE_H
     28 #error "freetype.h of FreeType 1 has been loaded!"
     29 #error "Please fix the directory search order for header files"
     30 #error "so that freetype.h of FreeType 2 is found first."
     31 #endif
     32 
     33 
     34 FT_BEGIN_HEADER
     35 
     36 
     37   /*************************************************************************/
     38   /*                                                                       */
     39   /* <Section>                                                             */
     40   /*    type1_tables                                                       */
     41   /*                                                                       */
     42   /* <Title>                                                               */
     43   /*    Type 1 Tables                                                      */
     44   /*                                                                       */
     45   /* <Abstract>                                                            */
     46   /*    Type~1 (PostScript) specific font tables.                          */
     47   /*                                                                       */
     48   /* <Description>                                                         */
     49   /*    This section contains the definition of Type 1-specific tables,    */
     50   /*    including structures related to other PostScript font formats.     */
     51   /*                                                                       */
     52   /*************************************************************************/
     53 
     54 
     55   /* Note that we separate font data in PS_FontInfoRec and PS_PrivateRec */
     56   /* structures in order to support Multiple Master fonts.               */
     57 
     58 
     59   /*************************************************************************/
     60   /*                                                                       */
     61   /* <Struct>                                                              */
     62   /*    PS_FontInfoRec                                                     */
     63   /*                                                                       */
     64   /* <Description>                                                         */
     65   /*    A structure used to model a Type~1 or Type~2 FontInfo dictionary.  */
     66   /*    Note that for Multiple Master fonts, each instance has its own     */
     67   /*    FontInfo dictionary.                                               */
     68   /*                                                                       */
     69   typedef struct  PS_FontInfoRec_
     70   {
     71     FT_String*  version;
     72     FT_String*  notice;
     73     FT_String*  full_name;
     74     FT_String*  family_name;
     75     FT_String*  weight;
     76     FT_Long     italic_angle;
     77     FT_Bool     is_fixed_pitch;
     78     FT_Short    underline_position;
     79     FT_UShort   underline_thickness;
     80 
     81   } PS_FontInfoRec;
     82 
     83 
     84   /*************************************************************************/
     85   /*                                                                       */
     86   /* <Struct>                                                              */
     87   /*    PS_FontInfo                                                        */
     88   /*                                                                       */
     89   /* <Description>                                                         */
     90   /*    A handle to a @PS_FontInfoRec structure.                           */
     91   /*                                                                       */
     92   typedef struct PS_FontInfoRec_*  PS_FontInfo;
     93 
     94 
     95   /*************************************************************************/
     96   /*                                                                       */
     97   /* <Struct>                                                              */
     98   /*    T1_FontInfo                                                        */
     99   /*                                                                       */
    100   /* <Description>                                                         */
    101   /*    This type is equivalent to @PS_FontInfoRec.  It is deprecated but  */
    102   /*    kept to maintain source compatibility between various versions of  */
    103   /*    FreeType.                                                          */
    104   /*                                                                       */
    105   typedef PS_FontInfoRec  T1_FontInfo;
    106 
    107 
    108   /*************************************************************************/
    109   /*                                                                       */
    110   /* <Struct>                                                              */
    111   /*    PS_PrivateRec                                                      */
    112   /*                                                                       */
    113   /* <Description>                                                         */
    114   /*    A structure used to model a Type~1 or Type~2 private dictionary.   */
    115   /*    Note that for Multiple Master fonts, each instance has its own     */
    116   /*    Private dictionary.                                                */
    117   /*                                                                       */
    118   typedef struct  PS_PrivateRec_
    119   {
    120     FT_Int     unique_id;
    121     FT_Int     lenIV;
    122 
    123     FT_Byte    num_blue_values;
    124     FT_Byte    num_other_blues;
    125     FT_Byte    num_family_blues;
    126     FT_Byte    num_family_other_blues;
    127 
    128     FT_Short   blue_values[14];
    129     FT_Short   other_blues[10];
    130 
    131     FT_Short   family_blues      [14];
    132     FT_Short   family_other_blues[10];
    133 
    134     FT_Fixed   blue_scale;
    135     FT_Int     blue_shift;
    136     FT_Int     blue_fuzz;
    137 
    138     FT_UShort  standard_width[1];
    139     FT_UShort  standard_height[1];
    140 
    141     FT_Byte    num_snap_widths;
    142     FT_Byte    num_snap_heights;
    143     FT_Bool    force_bold;
    144     FT_Bool    round_stem_up;
    145 
    146     FT_Short   snap_widths [13];  /* including std width  */
    147     FT_Short   snap_heights[13];  /* including std height */
    148 
    149     FT_Fixed   expansion_factor;
    150 
    151     FT_Long    language_group;
    152     FT_Long    password;
    153 
    154     FT_Short   min_feature[2];
    155 
    156   } PS_PrivateRec;
    157 
    158 
    159   /*************************************************************************/
    160   /*                                                                       */
    161   /* <Struct>                                                              */
    162   /*    PS_Private                                                         */
    163   /*                                                                       */
    164   /* <Description>                                                         */
    165   /*    A handle to a @PS_PrivateRec structure.                            */
    166   /*                                                                       */
    167   typedef struct PS_PrivateRec_*  PS_Private;
    168 
    169 
    170   /*************************************************************************/
    171   /*                                                                       */
    172   /* <Struct>                                                              */
    173   /*    T1_Private                                                         */
    174   /*                                                                       */
    175   /* <Description>                                                         */
    176   /*   This type is equivalent to @PS_PrivateRec.  It is deprecated but    */
    177   /*   kept to maintain source compatibility between various versions of   */
    178   /*   FreeType.                                                           */
    179   /*                                                                       */
    180   typedef PS_PrivateRec  T1_Private;
    181 
    182 
    183   /*************************************************************************/
    184   /*                                                                       */
    185   /* <Enum>                                                                */
    186   /*    T1_Blend_Flags                                                     */
    187   /*                                                                       */
    188   /* <Description>                                                         */
    189   /*    A set of flags used to indicate which fields are present in a      */
    190   /*    given blend dictionary (font info or private).  Used to support    */
    191   /*    Multiple Masters fonts.                                            */
    192   /*                                                                       */
    193   typedef enum  T1_Blend_Flags_
    194   {
    195     /*# required fields in a FontInfo blend dictionary */
    196     T1_BLEND_UNDERLINE_POSITION = 0,
    197     T1_BLEND_UNDERLINE_THICKNESS,
    198     T1_BLEND_ITALIC_ANGLE,
    199 
    200     /*# required fields in a Private blend dictionary */
    201     T1_BLEND_BLUE_VALUES,
    202     T1_BLEND_OTHER_BLUES,
    203     T1_BLEND_STANDARD_WIDTH,
    204     T1_BLEND_STANDARD_HEIGHT,
    205     T1_BLEND_STEM_SNAP_WIDTHS,
    206     T1_BLEND_STEM_SNAP_HEIGHTS,
    207     T1_BLEND_BLUE_SCALE,
    208     T1_BLEND_BLUE_SHIFT,
    209     T1_BLEND_FAMILY_BLUES,
    210     T1_BLEND_FAMILY_OTHER_BLUES,
    211     T1_BLEND_FORCE_BOLD,
    212 
    213     /*# never remove */
    214     T1_BLEND_MAX
    215 
    216   } T1_Blend_Flags;
    217 
    218   /* */
    219 
    220 
    221   /*# backwards compatible definitions */
    222 #define t1_blend_underline_position   T1_BLEND_UNDERLINE_POSITION
    223 #define t1_blend_underline_thickness  T1_BLEND_UNDERLINE_THICKNESS
    224 #define t1_blend_italic_angle         T1_BLEND_ITALIC_ANGLE
    225 #define t1_blend_blue_values          T1_BLEND_BLUE_VALUES
    226 #define t1_blend_other_blues          T1_BLEND_OTHER_BLUES
    227 #define t1_blend_standard_widths      T1_BLEND_STANDARD_WIDTH
    228 #define t1_blend_standard_height      T1_BLEND_STANDARD_HEIGHT
    229 #define t1_blend_stem_snap_widths     T1_BLEND_STEM_SNAP_WIDTHS
    230 #define t1_blend_stem_snap_heights    T1_BLEND_STEM_SNAP_HEIGHTS
    231 #define t1_blend_blue_scale           T1_BLEND_BLUE_SCALE
    232 #define t1_blend_blue_shift           T1_BLEND_BLUE_SHIFT
    233 #define t1_blend_family_blues         T1_BLEND_FAMILY_BLUES
    234 #define t1_blend_family_other_blues   T1_BLEND_FAMILY_OTHER_BLUES
    235 #define t1_blend_force_bold           T1_BLEND_FORCE_BOLD
    236 #define t1_blend_max                  T1_BLEND_MAX
    237 
    238 
    239   /* maximum number of Multiple Masters designs, as defined in the spec */
    240 #define T1_MAX_MM_DESIGNS     16
    241 
    242   /* maximum number of Multiple Masters axes, as defined in the spec */
    243 #define T1_MAX_MM_AXIS        4
    244 
    245   /* maximum number of elements in a design map */
    246 #define T1_MAX_MM_MAP_POINTS  20
    247 
    248 
    249   /* this structure is used to store the BlendDesignMap entry for an axis */
    250   typedef struct  PS_DesignMap_
    251   {
    252     FT_Byte    num_points;
    253     FT_Long*   design_points;
    254     FT_Fixed*  blend_points;
    255 
    256   } PS_DesignMapRec, *PS_DesignMap;
    257 
    258   /* backwards-compatible definition */
    259   typedef PS_DesignMapRec  T1_DesignMap;
    260 
    261 
    262   typedef struct  PS_BlendRec_
    263   {
    264     FT_UInt          num_designs;
    265     FT_UInt          num_axis;
    266 
    267     FT_String*       axis_names[T1_MAX_MM_AXIS];
    268     FT_Fixed*        design_pos[T1_MAX_MM_DESIGNS];
    269     PS_DesignMapRec  design_map[T1_MAX_MM_AXIS];
    270 
    271     FT_Fixed*        weight_vector;
    272     FT_Fixed*        default_weight_vector;
    273 
    274     PS_FontInfo      font_infos[T1_MAX_MM_DESIGNS + 1];
    275     PS_Private       privates  [T1_MAX_MM_DESIGNS + 1];
    276 
    277     FT_ULong         blend_bitflags;
    278 
    279     FT_BBox*         bboxes    [T1_MAX_MM_DESIGNS + 1];
    280 
    281     /* since 2.3.0 */
    282 
    283     /* undocumented, optional: the default design instance;   */
    284     /* corresponds to default_weight_vector --                */
    285     /* num_default_design_vector == 0 means it is not present */
    286     /* in the font and associated metrics files               */
    287     FT_UInt          default_design_vector[T1_MAX_MM_DESIGNS];
    288     FT_UInt          num_default_design_vector;
    289 
    290   } PS_BlendRec, *PS_Blend;
    291 
    292 
    293   /* backwards-compatible definition */
    294   typedef PS_BlendRec  T1_Blend;
    295 
    296 
    297   /*************************************************************************/
    298   /*                                                                       */
    299   /* <Struct>                                                              */
    300   /*    CID_FaceDictRec                                                    */
    301   /*                                                                       */
    302   /* <Description>                                                         */
    303   /*    A structure used to represent data in a CID top-level dictionary.  */
    304   /*                                                                       */
    305   typedef struct  CID_FaceDictRec_
    306   {
    307     PS_PrivateRec  private_dict;
    308 
    309     FT_UInt        len_buildchar;
    310     FT_Fixed       forcebold_threshold;
    311     FT_Pos         stroke_width;
    312     FT_Fixed       expansion_factor;
    313 
    314     FT_Byte        paint_type;
    315     FT_Byte        font_type;
    316     FT_Matrix      font_matrix;
    317     FT_Vector      font_offset;
    318 
    319     FT_UInt        num_subrs;
    320     FT_ULong       subrmap_offset;
    321     FT_Int         sd_bytes;
    322 
    323   } CID_FaceDictRec;
    324 
    325 
    326   /*************************************************************************/
    327   /*                                                                       */
    328   /* <Struct>                                                              */
    329   /*    CID_FaceDict                                                       */
    330   /*                                                                       */
    331   /* <Description>                                                         */
    332   /*    A handle to a @CID_FaceDictRec structure.                          */
    333   /*                                                                       */
    334   typedef struct CID_FaceDictRec_*  CID_FaceDict;
    335 
    336   /* */
    337 
    338 
    339   /* backwards-compatible definition */
    340   typedef CID_FaceDictRec  CID_FontDict;
    341 
    342 
    343   /*************************************************************************/
    344   /*                                                                       */
    345   /* <Struct>                                                              */
    346   /*    CID_FaceInfoRec                                                    */
    347   /*                                                                       */
    348   /* <Description>                                                         */
    349   /*    A structure used to represent CID Face information.                */
    350   /*                                                                       */
    351   typedef struct  CID_FaceInfoRec_
    352   {
    353     FT_String*      cid_font_name;
    354     FT_Fixed        cid_version;
    355     FT_Int          cid_font_type;
    356 
    357     FT_String*      registry;
    358     FT_String*      ordering;
    359     FT_Int          supplement;
    360 
    361     PS_FontInfoRec  font_info;
    362     FT_BBox         font_bbox;
    363     FT_ULong        uid_base;
    364 
    365     FT_Int          num_xuid;
    366     FT_ULong        xuid[16];
    367 
    368     FT_ULong        cidmap_offset;
    369     FT_Int          fd_bytes;
    370     FT_Int          gd_bytes;
    371     FT_ULong        cid_count;
    372 
    373     FT_Int          num_dicts;
    374     CID_FaceDict    font_dicts;
    375 
    376     FT_ULong        data_offset;
    377 
    378   } CID_FaceInfoRec;
    379 
    380 
    381   /*************************************************************************/
    382   /*                                                                       */
    383   /* <Struct>                                                              */
    384   /*    CID_FaceInfo                                                       */
    385   /*                                                                       */
    386   /* <Description>                                                         */
    387   /*    A handle to a @CID_FaceInfoRec structure.                          */
    388   /*                                                                       */
    389   typedef struct CID_FaceInfoRec_*  CID_FaceInfo;
    390 
    391 
    392   /*************************************************************************/
    393   /*                                                                       */
    394   /* <Struct>                                                              */
    395   /*    CID_Info                                                           */
    396   /*                                                                       */
    397   /* <Description>                                                         */
    398   /*   This type is equivalent to @CID_FaceInfoRec.  It is deprecated but  */
    399   /*   kept to maintain source compatibility between various versions of   */
    400   /*   FreeType.                                                           */
    401   /*                                                                       */
    402   typedef CID_FaceInfoRec  CID_Info;
    403 
    404 
    405   /************************************************************************
    406    *
    407    * @function:
    408    *    FT_Has_PS_Glyph_Names
    409    *
    410    * @description:
    411    *    Return true if a given face provides reliable PostScript glyph
    412    *    names.  This is similar to using the @FT_HAS_GLYPH_NAMES macro,
    413    *    except that certain fonts (mostly TrueType) contain incorrect
    414    *    glyph name tables.
    415    *
    416    *    When this function returns true, the caller is sure that the glyph
    417    *    names returned by @FT_Get_Glyph_Name are reliable.
    418    *
    419    * @input:
    420    *    face ::
    421    *       face handle
    422    *
    423    * @return:
    424    *    Boolean.  True if glyph names are reliable.
    425    *
    426    */
    427   FT_EXPORT( FT_Int )
    428   FT_Has_PS_Glyph_Names( FT_Face  face );
    429 
    430 
    431   /************************************************************************
    432    *
    433    * @function:
    434    *    FT_Get_PS_Font_Info
    435    *
    436    * @description:
    437    *    Retrieve the @PS_FontInfoRec structure corresponding to a given
    438    *    PostScript font.
    439    *
    440    * @input:
    441    *    face ::
    442    *       PostScript face handle.
    443    *
    444    * @output:
    445    *    afont_info ::
    446    *       Output font info structure pointer.
    447    *
    448    * @return:
    449    *    FreeType error code.  0~means success.
    450    *
    451    * @note:
    452    *    The string pointers within the font info structure are owned by
    453    *    the face and don't need to be freed by the caller.
    454    *
    455    *    If the font's format is not PostScript-based, this function will
    456    *    return the `FT_Err_Invalid_Argument' error code.
    457    *
    458    */
    459   FT_EXPORT( FT_Error )
    460   FT_Get_PS_Font_Info( FT_Face      face,
    461                        PS_FontInfo  afont_info );
    462 
    463 
    464   /************************************************************************
    465    *
    466    * @function:
    467    *    FT_Get_PS_Font_Private
    468    *
    469    * @description:
    470    *    Retrieve the @PS_PrivateRec structure corresponding to a given
    471    *    PostScript font.
    472    *
    473    * @input:
    474    *    face ::
    475    *       PostScript face handle.
    476    *
    477    * @output:
    478    *    afont_private ::
    479    *       Output private dictionary structure pointer.
    480    *
    481    * @return:
    482    *    FreeType error code.  0~means success.
    483    *
    484    * @note:
    485    *    The string pointers within the @PS_PrivateRec structure are owned by
    486    *    the face and don't need to be freed by the caller.
    487    *
    488    *    If the font's format is not PostScript-based, this function returns
    489    *    the `FT_Err_Invalid_Argument' error code.
    490    *
    491    */
    492   FT_EXPORT( FT_Error )
    493   FT_Get_PS_Font_Private( FT_Face     face,
    494                           PS_Private  afont_private );
    495 
    496 
    497   /*************************************************************************/
    498   /*                                                                       */
    499   /* <Enum>                                                                */
    500   /*    T1_EncodingType                                                    */
    501   /*                                                                       */
    502   /* <Description>                                                         */
    503   /*    An enumeration describing the `Encoding' entry in a Type 1         */
    504   /*    dictionary.                                                        */
    505   /*                                                                       */
    506   typedef enum  T1_EncodingType_
    507   {
    508     T1_ENCODING_TYPE_NONE = 0,
    509     T1_ENCODING_TYPE_ARRAY,
    510     T1_ENCODING_TYPE_STANDARD,
    511     T1_ENCODING_TYPE_ISOLATIN1,
    512     T1_ENCODING_TYPE_EXPERT
    513 
    514   } T1_EncodingType;
    515 
    516 
    517   /*************************************************************************/
    518   /*                                                                       */
    519   /* <Enum>                                                                */
    520   /*    PS_Dict_Keys                                                       */
    521   /*                                                                       */
    522   /* <Description>                                                         */
    523   /*    An enumeration used in calls to @FT_Get_PS_Font_Value to identify  */
    524   /*    the Type~1 dictionary entry to retrieve.                           */
    525   /*                                                                       */
    526   typedef enum  PS_Dict_Keys_
    527   {
    528     /* conventionally in the font dictionary */
    529     PS_DICT_FONT_TYPE,              /* FT_Byte         */
    530     PS_DICT_FONT_MATRIX,            /* FT_Fixed        */
    531     PS_DICT_FONT_BBOX,              /* FT_Fixed        */
    532     PS_DICT_PAINT_TYPE,             /* FT_Byte         */
    533     PS_DICT_FONT_NAME,              /* FT_String*      */
    534     PS_DICT_UNIQUE_ID,              /* FT_Int          */
    535     PS_DICT_NUM_CHAR_STRINGS,       /* FT_Int          */
    536     PS_DICT_CHAR_STRING_KEY,        /* FT_String*      */
    537     PS_DICT_CHAR_STRING,            /* FT_String*      */
    538     PS_DICT_ENCODING_TYPE,          /* T1_EncodingType */
    539     PS_DICT_ENCODING_ENTRY,         /* FT_String*      */
    540 
    541     /* conventionally in the font Private dictionary */
    542     PS_DICT_NUM_SUBRS,              /* FT_Int     */
    543     PS_DICT_SUBR,                   /* FT_String* */
    544     PS_DICT_STD_HW,                 /* FT_UShort  */
    545     PS_DICT_STD_VW,                 /* FT_UShort  */
    546     PS_DICT_NUM_BLUE_VALUES,        /* FT_Byte    */
    547     PS_DICT_BLUE_VALUE,             /* FT_Short   */
    548     PS_DICT_BLUE_FUZZ,              /* FT_Int     */
    549     PS_DICT_NUM_OTHER_BLUES,        /* FT_Byte    */
    550     PS_DICT_OTHER_BLUE,             /* FT_Short   */
    551     PS_DICT_NUM_FAMILY_BLUES,       /* FT_Byte    */
    552     PS_DICT_FAMILY_BLUE,            /* FT_Short   */
    553     PS_DICT_NUM_FAMILY_OTHER_BLUES, /* FT_Byte    */
    554     PS_DICT_FAMILY_OTHER_BLUE,      /* FT_Short   */
    555     PS_DICT_BLUE_SCALE,             /* FT_Fixed   */
    556     PS_DICT_BLUE_SHIFT,             /* FT_Int     */
    557     PS_DICT_NUM_STEM_SNAP_H,        /* FT_Byte    */
    558     PS_DICT_STEM_SNAP_H,            /* FT_Short   */
    559     PS_DICT_NUM_STEM_SNAP_V,        /* FT_Byte    */
    560     PS_DICT_STEM_SNAP_V,            /* FT_Short   */
    561     PS_DICT_FORCE_BOLD,             /* FT_Bool    */
    562     PS_DICT_RND_STEM_UP,            /* FT_Bool    */
    563     PS_DICT_MIN_FEATURE,            /* FT_Short   */
    564     PS_DICT_LEN_IV,                 /* FT_Int     */
    565     PS_DICT_PASSWORD,               /* FT_Long    */
    566     PS_DICT_LANGUAGE_GROUP,         /* FT_Long    */
    567 
    568     /* conventionally in the font FontInfo dictionary */
    569     PS_DICT_VERSION,                /* FT_String* */
    570     PS_DICT_NOTICE,                 /* FT_String* */
    571     PS_DICT_FULL_NAME,              /* FT_String* */
    572     PS_DICT_FAMILY_NAME,            /* FT_String* */
    573     PS_DICT_WEIGHT,                 /* FT_String* */
    574     PS_DICT_IS_FIXED_PITCH,         /* FT_Bool    */
    575     PS_DICT_UNDERLINE_POSITION,     /* FT_Short   */
    576     PS_DICT_UNDERLINE_THICKNESS,    /* FT_UShort  */
    577     PS_DICT_FS_TYPE,                /* FT_UShort  */
    578     PS_DICT_ITALIC_ANGLE,           /* FT_Long    */
    579 
    580     PS_DICT_MAX = PS_DICT_ITALIC_ANGLE
    581 
    582   } PS_Dict_Keys;
    583 
    584 
    585   /************************************************************************
    586    *
    587    * @function:
    588    *    FT_Get_PS_Font_Value
    589    *
    590    * @description:
    591    *    Retrieve the value for the supplied key from a PostScript font.
    592    *
    593    * @input:
    594    *    face ::
    595    *       PostScript face handle.
    596    *
    597    *    key ::
    598    *       An enumeration value representing the dictionary key to retrieve.
    599    *
    600    *    idx ::
    601    *       For array values, this specifies the index to be returned.
    602    *
    603    *    value ::
    604    *       A pointer to memory into which to write the value.
    605    *
    606    *    valen_len ::
    607    *       The size, in bytes, of the memory supplied for the value.
    608    *
    609    * @output:
    610    *    value ::
    611    *       The value matching the above key, if it exists.
    612    *
    613    * @return:
    614    *    The amount of memory (in bytes) required to hold the requested
    615    *    value (if it exists, -1 otherwise).
    616    *
    617    * @note:
    618    *    The values returned are not pointers into the internal structures of
    619    *    the face, but are `fresh' copies, so that the memory containing them
    620    *    belongs to the calling application.  This also enforces the
    621    *    `read-only' nature of these values, i.e., this function cannot be
    622    *    used to manipulate the face.
    623    *
    624    *    `value' is a void pointer because the values returned can be of
    625    *    various types.
    626    *
    627    *    If either `value' is NULL or `value_len' is too small, just the
    628    *    required memory size for the requested entry is returned.
    629    *
    630    *    The `idx' parameter is used, not only to retrieve elements of, for
    631    *    example, the FontMatrix or FontBBox, but also to retrieve name keys
    632    *    from the CharStrings dictionary, and the charstrings themselves.  It
    633    *    is ignored for atomic values.
    634    *
    635    *    PS_DICT_BLUE_SCALE returns a value that is scaled up by 1000.  To
    636    *    get the value as in the font stream, you need to divide by
    637    *    65536000.0 (to remove the FT_Fixed scale, and the x1000 scale).
    638    *
    639    *    IMPORTANT: Only key/value pairs read by the FreeType interpreter can
    640    *    be retrieved.  So, for example, PostScript procedures such as NP,
    641    *    ND, and RD are not available.  Arbitrary keys are, obviously, not be
    642    *    available either.
    643    *
    644    *    If the font's format is not PostScript-based, this function returns
    645    *    the `FT_Err_Invalid_Argument' error code.
    646    *
    647    */
    648   FT_EXPORT( FT_Long )
    649   FT_Get_PS_Font_Value( FT_Face       face,
    650                         PS_Dict_Keys  key,
    651                         FT_UInt       idx,
    652                         void         *value,
    653                         FT_Long       value_len );
    654 
    655   /* */
    656 
    657 FT_END_HEADER
    658 
    659 #endif /* __T1TABLES_H__ */
    660 
    661 
    662 /* END */
    663