misc/libfreetype/include/freetype/ftcache.h
changeset 5172 88f2e05288ba
equal deleted inserted replaced
5171:f9283dc4860d 5172:88f2e05288ba
       
     1 /***************************************************************************/
       
     2 /*                                                                         */
       
     3 /*  ftcache.h                                                              */
       
     4 /*                                                                         */
       
     5 /*    FreeType Cache subsystem (specification).                            */
       
     6 /*                                                                         */
       
     7 /*  Copyright 1996-2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2010 by */
       
     8 /*  David Turner, Robert Wilhelm, and Werner Lemberg.                      */
       
     9 /*                                                                         */
       
    10 /*  This file is part of the FreeType project, and may only be used,       */
       
    11 /*  modified, and distributed under the terms of the FreeType project      */
       
    12 /*  license, LICENSE.TXT.  By continuing to use, modify, or distribute     */
       
    13 /*  this file you indicate that you have read the license and              */
       
    14 /*  understand and accept it fully.                                        */
       
    15 /*                                                                         */
       
    16 /***************************************************************************/
       
    17 
       
    18 
       
    19 #ifndef __FTCACHE_H__
       
    20 #define __FTCACHE_H__
       
    21 
       
    22 
       
    23 #include <ft2build.h>
       
    24 #include FT_GLYPH_H
       
    25 
       
    26 
       
    27 FT_BEGIN_HEADER
       
    28 
       
    29 
       
    30   /*************************************************************************
       
    31    *
       
    32    * <Section>
       
    33    *    cache_subsystem
       
    34    *
       
    35    * <Title>
       
    36    *    Cache Sub-System
       
    37    *
       
    38    * <Abstract>
       
    39    *    How to cache face, size, and glyph data with FreeType~2.
       
    40    *
       
    41    * <Description>
       
    42    *   This section describes the FreeType~2 cache sub-system, which is used
       
    43    *   to limit the number of concurrently opened @FT_Face and @FT_Size
       
    44    *   objects, as well as caching information like character maps and glyph
       
    45    *   images while limiting their maximum memory usage.
       
    46    *
       
    47    *   Note that all types and functions begin with the `FTC_' prefix.
       
    48    *
       
    49    *   The cache is highly portable and thus doesn't know anything about the
       
    50    *   fonts installed on your system, or how to access them.  This implies
       
    51    *   the following scheme:
       
    52    *
       
    53    *   First, available or installed font faces are uniquely identified by
       
    54    *   @FTC_FaceID values, provided to the cache by the client.  Note that
       
    55    *   the cache only stores and compares these values, and doesn't try to
       
    56    *   interpret them in any way.
       
    57    *
       
    58    *   Second, the cache calls, only when needed, a client-provided function
       
    59    *   to convert an @FTC_FaceID into a new @FT_Face object.  The latter is
       
    60    *   then completely managed by the cache, including its termination
       
    61    *   through @FT_Done_Face.  To monitor termination of face objects, the
       
    62    *   finalizer callback in the `generic' field of the @FT_Face object can
       
    63    *   be used, which might also be used to store the @FTC_FaceID of the
       
    64    *   face.
       
    65    *
       
    66    *   Clients are free to map face IDs to anything else.  The most simple
       
    67    *   usage is to associate them to a (pathname,face_index) pair that is
       
    68    *   used to call @FT_New_Face.  However, more complex schemes are also
       
    69    *   possible.
       
    70    *
       
    71    *   Note that for the cache to work correctly, the face ID values must be
       
    72    *   *persistent*, which means that the contents they point to should not
       
    73    *   change at runtime, or that their value should not become invalid.
       
    74    *
       
    75    *   If this is unavoidable (e.g., when a font is uninstalled at runtime),
       
    76    *   you should call @FTC_Manager_RemoveFaceID as soon as possible, to let
       
    77    *   the cache get rid of any references to the old @FTC_FaceID it may
       
    78    *   keep internally.  Failure to do so will lead to incorrect behaviour
       
    79    *   or even crashes.
       
    80    *
       
    81    *   To use the cache, start with calling @FTC_Manager_New to create a new
       
    82    *   @FTC_Manager object, which models a single cache instance.  You can
       
    83    *   then look up @FT_Face and @FT_Size objects with
       
    84    *   @FTC_Manager_LookupFace and @FTC_Manager_LookupSize, respectively.
       
    85    *
       
    86    *   If you want to use the charmap caching, call @FTC_CMapCache_New, then
       
    87    *   later use @FTC_CMapCache_Lookup to perform the equivalent of
       
    88    *   @FT_Get_Char_Index, only much faster.
       
    89    *
       
    90    *   If you want to use the @FT_Glyph caching, call @FTC_ImageCache, then
       
    91    *   later use @FTC_ImageCache_Lookup to retrieve the corresponding
       
    92    *   @FT_Glyph objects from the cache.
       
    93    *
       
    94    *   If you need lots of small bitmaps, it is much more memory efficient
       
    95    *   to call @FTC_SBitCache_New followed by @FTC_SBitCache_Lookup.  This
       
    96    *   returns @FTC_SBitRec structures, which are used to store small
       
    97    *   bitmaps directly.  (A small bitmap is one whose metrics and
       
    98    *   dimensions all fit into 8-bit integers).
       
    99    *
       
   100    *   We hope to also provide a kerning cache in the near future.
       
   101    *
       
   102    *
       
   103    * <Order>
       
   104    *   FTC_Manager
       
   105    *   FTC_FaceID
       
   106    *   FTC_Face_Requester
       
   107    *
       
   108    *   FTC_Manager_New
       
   109    *   FTC_Manager_Reset
       
   110    *   FTC_Manager_Done
       
   111    *   FTC_Manager_LookupFace
       
   112    *   FTC_Manager_LookupSize
       
   113    *   FTC_Manager_RemoveFaceID
       
   114    *
       
   115    *   FTC_Node
       
   116    *   FTC_Node_Unref
       
   117    *
       
   118    *   FTC_ImageCache
       
   119    *   FTC_ImageCache_New
       
   120    *   FTC_ImageCache_Lookup
       
   121    *
       
   122    *   FTC_SBit
       
   123    *   FTC_SBitCache
       
   124    *   FTC_SBitCache_New
       
   125    *   FTC_SBitCache_Lookup
       
   126    *
       
   127    *   FTC_CMapCache
       
   128    *   FTC_CMapCache_New
       
   129    *   FTC_CMapCache_Lookup
       
   130    *
       
   131    *************************************************************************/
       
   132 
       
   133 
       
   134   /*************************************************************************/
       
   135   /*************************************************************************/
       
   136   /*************************************************************************/
       
   137   /*****                                                               *****/
       
   138   /*****                    BASIC TYPE DEFINITIONS                     *****/
       
   139   /*****                                                               *****/
       
   140   /*************************************************************************/
       
   141   /*************************************************************************/
       
   142   /*************************************************************************/
       
   143 
       
   144 
       
   145   /*************************************************************************
       
   146    *
       
   147    * @type: FTC_FaceID
       
   148    *
       
   149    * @description:
       
   150    *   An opaque pointer type that is used to identity face objects.  The
       
   151    *   contents of such objects is application-dependent.
       
   152    *
       
   153    *   These pointers are typically used to point to a user-defined
       
   154    *   structure containing a font file path, and face index.
       
   155    *
       
   156    * @note:
       
   157    *   Never use NULL as a valid @FTC_FaceID.
       
   158    *
       
   159    *   Face IDs are passed by the client to the cache manager, which calls,
       
   160    *   when needed, the @FTC_Face_Requester to translate them into new
       
   161    *   @FT_Face objects.
       
   162    *
       
   163    *   If the content of a given face ID changes at runtime, or if the value
       
   164    *   becomes invalid (e.g., when uninstalling a font), you should
       
   165    *   immediately call @FTC_Manager_RemoveFaceID before any other cache
       
   166    *   function.
       
   167    *
       
   168    *   Failure to do so will result in incorrect behaviour or even
       
   169    *   memory leaks and crashes.
       
   170    */
       
   171   typedef FT_Pointer  FTC_FaceID;
       
   172 
       
   173 
       
   174   /************************************************************************
       
   175    *
       
   176    * @functype:
       
   177    *   FTC_Face_Requester
       
   178    *
       
   179    * @description:
       
   180    *   A callback function provided by client applications.  It is used by
       
   181    *   the cache manager to translate a given @FTC_FaceID into a new valid
       
   182    *   @FT_Face object, on demand.
       
   183    *
       
   184    * <Input>
       
   185    *   face_id ::
       
   186    *     The face ID to resolve.
       
   187    *
       
   188    *   library ::
       
   189    *     A handle to a FreeType library object.
       
   190    *
       
   191    *   req_data ::
       
   192    *     Application-provided request data (see note below).
       
   193    *
       
   194    * <Output>
       
   195    *   aface ::
       
   196    *     A new @FT_Face handle.
       
   197    *
       
   198    * <Return>
       
   199    *   FreeType error code.  0~means success.
       
   200    *
       
   201    * <Note>
       
   202    *   The third parameter `req_data' is the same as the one passed by the
       
   203    *   client when @FTC_Manager_New is called.
       
   204    *
       
   205    *   The face requester should not perform funny things on the returned
       
   206    *   face object, like creating a new @FT_Size for it, or setting a
       
   207    *   transformation through @FT_Set_Transform!
       
   208    */
       
   209   typedef FT_Error
       
   210   (*FTC_Face_Requester)( FTC_FaceID  face_id,
       
   211                          FT_Library  library,
       
   212                          FT_Pointer  request_data,
       
   213                          FT_Face*    aface );
       
   214 
       
   215  /* */
       
   216 
       
   217 #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
       
   218 
       
   219   /* these macros are incompatible with LLP64, should not be used */
       
   220 
       
   221 #define FT_POINTER_TO_ULONG( p )  ( (FT_ULong)(FT_Pointer)(p) )
       
   222 
       
   223 #define FTC_FACE_ID_HASH( i )                                \
       
   224           ((FT_UInt32)(( FT_POINTER_TO_ULONG( i ) >> 3 ) ^   \
       
   225                        ( FT_POINTER_TO_ULONG( i ) << 7 ) ) )
       
   226 
       
   227 #endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
       
   228 
       
   229   /*************************************************************************/
       
   230   /*************************************************************************/
       
   231   /*************************************************************************/
       
   232   /*****                                                               *****/
       
   233   /*****                      CACHE MANAGER OBJECT                     *****/
       
   234   /*****                                                               *****/
       
   235   /*************************************************************************/
       
   236   /*************************************************************************/
       
   237   /*************************************************************************/
       
   238 
       
   239 
       
   240   /*************************************************************************/
       
   241   /*                                                                       */
       
   242   /* <Type>                                                                */
       
   243   /*    FTC_Manager                                                        */
       
   244   /*                                                                       */
       
   245   /* <Description>                                                         */
       
   246   /*    This object corresponds to one instance of the cache-subsystem.    */
       
   247   /*    It is used to cache one or more @FT_Face objects, along with       */
       
   248   /*    corresponding @FT_Size objects.                                    */
       
   249   /*                                                                       */
       
   250   /*    The manager intentionally limits the total number of opened        */
       
   251   /*    @FT_Face and @FT_Size objects to control memory usage.  See the    */
       
   252   /*    `max_faces' and `max_sizes' parameters of @FTC_Manager_New.        */
       
   253   /*                                                                       */
       
   254   /*    The manager is also used to cache `nodes' of various types while   */
       
   255   /*    limiting their total memory usage.                                 */
       
   256   /*                                                                       */
       
   257   /*    All limitations are enforced by keeping lists of managed objects   */
       
   258   /*    in most-recently-used order, and flushing old nodes to make room   */
       
   259   /*    for new ones.                                                      */
       
   260   /*                                                                       */
       
   261   typedef struct FTC_ManagerRec_*  FTC_Manager;
       
   262 
       
   263 
       
   264   /*************************************************************************/
       
   265   /*                                                                       */
       
   266   /* <Type>                                                                */
       
   267   /*    FTC_Node                                                           */
       
   268   /*                                                                       */
       
   269   /* <Description>                                                         */
       
   270   /*    An opaque handle to a cache node object.  Each cache node is       */
       
   271   /*    reference-counted.  A node with a count of~0 might be flushed      */
       
   272   /*    out of a full cache whenever a lookup request is performed.        */
       
   273   /*                                                                       */
       
   274   /*    If you look up nodes, you have the ability to `acquire' them,      */
       
   275   /*    i.e., to increment their reference count.  This will prevent the   */
       
   276   /*    node from being flushed out of the cache until you explicitly      */
       
   277   /*    `release' it (see @FTC_Node_Unref).                                */
       
   278   /*                                                                       */
       
   279   /*    See also @FTC_SBitCache_Lookup and @FTC_ImageCache_Lookup.         */
       
   280   /*                                                                       */
       
   281   typedef struct FTC_NodeRec_*  FTC_Node;
       
   282 
       
   283 
       
   284   /*************************************************************************/
       
   285   /*                                                                       */
       
   286   /* <Function>                                                            */
       
   287   /*    FTC_Manager_New                                                    */
       
   288   /*                                                                       */
       
   289   /* <Description>                                                         */
       
   290   /*    Create a new cache manager.                                        */
       
   291   /*                                                                       */
       
   292   /* <Input>                                                               */
       
   293   /*    library   :: The parent FreeType library handle to use.            */
       
   294   /*                                                                       */
       
   295   /*    max_faces :: Maximum number of opened @FT_Face objects managed by  */
       
   296   /*                 this cache instance.  Use~0 for defaults.             */
       
   297   /*                                                                       */
       
   298   /*    max_sizes :: Maximum number of opened @FT_Size objects managed by  */
       
   299   /*                 this cache instance.  Use~0 for defaults.             */
       
   300   /*                                                                       */
       
   301   /*    max_bytes :: Maximum number of bytes to use for cached data nodes. */
       
   302   /*                 Use~0 for defaults.  Note that this value does not    */
       
   303   /*                 account for managed @FT_Face and @FT_Size objects.    */
       
   304   /*                                                                       */
       
   305   /*    requester :: An application-provided callback used to translate    */
       
   306   /*                 face IDs into real @FT_Face objects.                  */
       
   307   /*                                                                       */
       
   308   /*    req_data  :: A generic pointer that is passed to the requester     */
       
   309   /*                 each time it is called (see @FTC_Face_Requester).     */
       
   310   /*                                                                       */
       
   311   /* <Output>                                                              */
       
   312   /*    amanager  :: A handle to a new manager object.  0~in case of       */
       
   313   /*                 failure.                                              */
       
   314   /*                                                                       */
       
   315   /* <Return>                                                              */
       
   316   /*    FreeType error code.  0~means success.                             */
       
   317   /*                                                                       */
       
   318   FT_EXPORT( FT_Error )
       
   319   FTC_Manager_New( FT_Library          library,
       
   320                    FT_UInt             max_faces,
       
   321                    FT_UInt             max_sizes,
       
   322                    FT_ULong            max_bytes,
       
   323                    FTC_Face_Requester  requester,
       
   324                    FT_Pointer          req_data,
       
   325                    FTC_Manager        *amanager );
       
   326 
       
   327 
       
   328   /*************************************************************************/
       
   329   /*                                                                       */
       
   330   /* <Function>                                                            */
       
   331   /*    FTC_Manager_Reset                                                  */
       
   332   /*                                                                       */
       
   333   /* <Description>                                                         */
       
   334   /*    Empty a given cache manager.  This simply gets rid of all the      */
       
   335   /*    currently cached @FT_Face and @FT_Size objects within the manager. */
       
   336   /*                                                                       */
       
   337   /* <InOut>                                                               */
       
   338   /*    manager :: A handle to the manager.                                */
       
   339   /*                                                                       */
       
   340   FT_EXPORT( void )
       
   341   FTC_Manager_Reset( FTC_Manager  manager );
       
   342 
       
   343 
       
   344   /*************************************************************************/
       
   345   /*                                                                       */
       
   346   /* <Function>                                                            */
       
   347   /*    FTC_Manager_Done                                                   */
       
   348   /*                                                                       */
       
   349   /* <Description>                                                         */
       
   350   /*    Destroy a given manager after emptying it.                         */
       
   351   /*                                                                       */
       
   352   /* <Input>                                                               */
       
   353   /*    manager :: A handle to the target cache manager object.            */
       
   354   /*                                                                       */
       
   355   FT_EXPORT( void )
       
   356   FTC_Manager_Done( FTC_Manager  manager );
       
   357 
       
   358 
       
   359   /*************************************************************************/
       
   360   /*                                                                       */
       
   361   /* <Function>                                                            */
       
   362   /*    FTC_Manager_LookupFace                                             */
       
   363   /*                                                                       */
       
   364   /* <Description>                                                         */
       
   365   /*    Retrieve the @FT_Face object that corresponds to a given face ID   */
       
   366   /*    through a cache manager.                                           */
       
   367   /*                                                                       */
       
   368   /* <Input>                                                               */
       
   369   /*    manager :: A handle to the cache manager.                          */
       
   370   /*                                                                       */
       
   371   /*    face_id :: The ID of the face object.                              */
       
   372   /*                                                                       */
       
   373   /* <Output>                                                              */
       
   374   /*    aface   :: A handle to the face object.                            */
       
   375   /*                                                                       */
       
   376   /* <Return>                                                              */
       
   377   /*    FreeType error code.  0~means success.                             */
       
   378   /*                                                                       */
       
   379   /* <Note>                                                                */
       
   380   /*    The returned @FT_Face object is always owned by the manager.  You  */
       
   381   /*    should never try to discard it yourself.                           */
       
   382   /*                                                                       */
       
   383   /*    The @FT_Face object doesn't necessarily have a current size object */
       
   384   /*    (i.e., face->size can be 0).  If you need a specific `font size',  */
       
   385   /*    use @FTC_Manager_LookupSize instead.                               */
       
   386   /*                                                                       */
       
   387   /*    Never change the face's transformation matrix (i.e., never call    */
       
   388   /*    the @FT_Set_Transform function) on a returned face!  If you need   */
       
   389   /*    to transform glyphs, do it yourself after glyph loading.           */
       
   390   /*                                                                       */
       
   391   /*    When you perform a lookup, out-of-memory errors are detected       */
       
   392   /*    _within_ the lookup and force incremental flushes of the cache     */
       
   393   /*    until enough memory is released for the lookup to succeed.         */
       
   394   /*                                                                       */
       
   395   /*    If a lookup fails with `FT_Err_Out_Of_Memory' the cache has        */
       
   396   /*    already been completely flushed, and still no memory was available */
       
   397   /*    for the operation.                                                 */
       
   398   /*                                                                       */
       
   399   FT_EXPORT( FT_Error )
       
   400   FTC_Manager_LookupFace( FTC_Manager  manager,
       
   401                           FTC_FaceID   face_id,
       
   402                           FT_Face     *aface );
       
   403 
       
   404 
       
   405   /*************************************************************************/
       
   406   /*                                                                       */
       
   407   /* <Struct>                                                              */
       
   408   /*    FTC_ScalerRec                                                      */
       
   409   /*                                                                       */
       
   410   /* <Description>                                                         */
       
   411   /*    A structure used to describe a given character size in either      */
       
   412   /*    pixels or points to the cache manager.  See                        */
       
   413   /*    @FTC_Manager_LookupSize.                                           */
       
   414   /*                                                                       */
       
   415   /* <Fields>                                                              */
       
   416   /*    face_id :: The source face ID.                                     */
       
   417   /*                                                                       */
       
   418   /*    width   :: The character width.                                    */
       
   419   /*                                                                       */
       
   420   /*    height  :: The character height.                                   */
       
   421   /*                                                                       */
       
   422   /*    pixel   :: A Boolean.  If 1, the `width' and `height' fields are   */
       
   423   /*               interpreted as integer pixel character sizes.           */
       
   424   /*               Otherwise, they are expressed as 1/64th of points.      */
       
   425   /*                                                                       */
       
   426   /*    x_res   :: Only used when `pixel' is value~0 to indicate the       */
       
   427   /*               horizontal resolution in dpi.                           */
       
   428   /*                                                                       */
       
   429   /*    y_res   :: Only used when `pixel' is value~0 to indicate the       */
       
   430   /*               vertical resolution in dpi.                             */
       
   431   /*                                                                       */
       
   432   /* <Note>                                                                */
       
   433   /*    This type is mainly used to retrieve @FT_Size objects through the  */
       
   434   /*    cache manager.                                                     */
       
   435   /*                                                                       */
       
   436   typedef struct  FTC_ScalerRec_
       
   437   {
       
   438     FTC_FaceID  face_id;
       
   439     FT_UInt     width;
       
   440     FT_UInt     height;
       
   441     FT_Int      pixel;
       
   442     FT_UInt     x_res;
       
   443     FT_UInt     y_res;
       
   444 
       
   445   } FTC_ScalerRec;
       
   446 
       
   447 
       
   448   /*************************************************************************/
       
   449   /*                                                                       */
       
   450   /* <Struct>                                                              */
       
   451   /*    FTC_Scaler                                                         */
       
   452   /*                                                                       */
       
   453   /* <Description>                                                         */
       
   454   /*    A handle to an @FTC_ScalerRec structure.                           */
       
   455   /*                                                                       */
       
   456   typedef struct FTC_ScalerRec_*  FTC_Scaler;
       
   457 
       
   458 
       
   459   /*************************************************************************/
       
   460   /*                                                                       */
       
   461   /* <Function>                                                            */
       
   462   /*    FTC_Manager_LookupSize                                             */
       
   463   /*                                                                       */
       
   464   /* <Description>                                                         */
       
   465   /*    Retrieve the @FT_Size object that corresponds to a given           */
       
   466   /*    @FTC_ScalerRec pointer through a cache manager.                    */
       
   467   /*                                                                       */
       
   468   /* <Input>                                                               */
       
   469   /*    manager :: A handle to the cache manager.                          */
       
   470   /*                                                                       */
       
   471   /*    scaler  :: A scaler handle.                                        */
       
   472   /*                                                                       */
       
   473   /* <Output>                                                              */
       
   474   /*    asize   :: A handle to the size object.                            */
       
   475   /*                                                                       */
       
   476   /* <Return>                                                              */
       
   477   /*    FreeType error code.  0~means success.                             */
       
   478   /*                                                                       */
       
   479   /* <Note>                                                                */
       
   480   /*    The returned @FT_Size object is always owned by the manager.  You  */
       
   481   /*    should never try to discard it by yourself.                        */
       
   482   /*                                                                       */
       
   483   /*    You can access the parent @FT_Face object simply as `size->face'   */
       
   484   /*    if you need it.  Note that this object is also owned by the        */
       
   485   /*    manager.                                                           */
       
   486   /*                                                                       */
       
   487   /* <Note>                                                                */
       
   488   /*    When you perform a lookup, out-of-memory errors are detected       */
       
   489   /*    _within_ the lookup and force incremental flushes of the cache     */
       
   490   /*    until enough memory is released for the lookup to succeed.         */
       
   491   /*                                                                       */
       
   492   /*    If a lookup fails with `FT_Err_Out_Of_Memory' the cache has        */
       
   493   /*    already been completely flushed, and still no memory is available  */
       
   494   /*    for the operation.                                                 */
       
   495   /*                                                                       */
       
   496   FT_EXPORT( FT_Error )
       
   497   FTC_Manager_LookupSize( FTC_Manager  manager,
       
   498                           FTC_Scaler   scaler,
       
   499                           FT_Size     *asize );
       
   500 
       
   501 
       
   502   /*************************************************************************/
       
   503   /*                                                                       */
       
   504   /* <Function>                                                            */
       
   505   /*    FTC_Node_Unref                                                     */
       
   506   /*                                                                       */
       
   507   /* <Description>                                                         */
       
   508   /*    Decrement a cache node's internal reference count.  When the count */
       
   509   /*    reaches 0, it is not destroyed but becomes eligible for subsequent */
       
   510   /*    cache flushes.                                                     */
       
   511   /*                                                                       */
       
   512   /* <Input>                                                               */
       
   513   /*    node    :: The cache node handle.                                  */
       
   514   /*                                                                       */
       
   515   /*    manager :: The cache manager handle.                               */
       
   516   /*                                                                       */
       
   517   FT_EXPORT( void )
       
   518   FTC_Node_Unref( FTC_Node     node,
       
   519                   FTC_Manager  manager );
       
   520 
       
   521 
       
   522   /*************************************************************************
       
   523    *
       
   524    * @function:
       
   525    *   FTC_Manager_RemoveFaceID
       
   526    *
       
   527    * @description:
       
   528    *   A special function used to indicate to the cache manager that
       
   529    *   a given @FTC_FaceID is no longer valid, either because its
       
   530    *   content changed, or because it was deallocated or uninstalled.
       
   531    *
       
   532    * @input:
       
   533    *   manager ::
       
   534    *     The cache manager handle.
       
   535    *
       
   536    *   face_id ::
       
   537    *     The @FTC_FaceID to be removed.
       
   538    *
       
   539    * @note:
       
   540    *   This function flushes all nodes from the cache corresponding to this
       
   541    *   `face_id', with the exception of nodes with a non-null reference
       
   542    *   count.
       
   543    *
       
   544    *   Such nodes are however modified internally so as to never appear
       
   545    *   in later lookups with the same `face_id' value, and to be immediately
       
   546    *   destroyed when released by all their users.
       
   547    *
       
   548    */
       
   549   FT_EXPORT( void )
       
   550   FTC_Manager_RemoveFaceID( FTC_Manager  manager,
       
   551                             FTC_FaceID   face_id );
       
   552 
       
   553 
       
   554   /*************************************************************************/
       
   555   /*                                                                       */
       
   556   /* <Section>                                                             */
       
   557   /*    cache_subsystem                                                    */
       
   558   /*                                                                       */
       
   559   /*************************************************************************/
       
   560 
       
   561   /*************************************************************************
       
   562    *
       
   563    * @type:
       
   564    *   FTC_CMapCache
       
   565    *
       
   566    * @description:
       
   567    *   An opaque handle used to model a charmap cache.  This cache is to
       
   568    *   hold character codes -> glyph indices mappings.
       
   569    *
       
   570    */
       
   571   typedef struct FTC_CMapCacheRec_*  FTC_CMapCache;
       
   572 
       
   573 
       
   574   /*************************************************************************
       
   575    *
       
   576    * @function:
       
   577    *   FTC_CMapCache_New
       
   578    *
       
   579    * @description:
       
   580    *   Create a new charmap cache.
       
   581    *
       
   582    * @input:
       
   583    *   manager ::
       
   584    *     A handle to the cache manager.
       
   585    *
       
   586    * @output:
       
   587    *   acache ::
       
   588    *     A new cache handle.  NULL in case of error.
       
   589    *
       
   590    * @return:
       
   591    *   FreeType error code.  0~means success.
       
   592    *
       
   593    * @note:
       
   594    *   Like all other caches, this one will be destroyed with the cache
       
   595    *   manager.
       
   596    *
       
   597    */
       
   598   FT_EXPORT( FT_Error )
       
   599   FTC_CMapCache_New( FTC_Manager     manager,
       
   600                      FTC_CMapCache  *acache );
       
   601 
       
   602 
       
   603   /************************************************************************
       
   604    *
       
   605    * @function:
       
   606    *   FTC_CMapCache_Lookup
       
   607    *
       
   608    * @description:
       
   609    *   Translate a character code into a glyph index, using the charmap
       
   610    *   cache.
       
   611    *
       
   612    * @input:
       
   613    *   cache ::
       
   614    *     A charmap cache handle.
       
   615    *
       
   616    *   face_id ::
       
   617    *     The source face ID.
       
   618    *
       
   619    *   cmap_index ::
       
   620    *     The index of the charmap in the source face.  Any negative value
       
   621    *     means to use the cache @FT_Face's default charmap.
       
   622    *
       
   623    *   char_code ::
       
   624    *     The character code (in the corresponding charmap).
       
   625    *
       
   626    * @return:
       
   627    *    Glyph index.  0~means `no glyph'.
       
   628    *
       
   629    */
       
   630   FT_EXPORT( FT_UInt )
       
   631   FTC_CMapCache_Lookup( FTC_CMapCache  cache,
       
   632                         FTC_FaceID     face_id,
       
   633                         FT_Int         cmap_index,
       
   634                         FT_UInt32      char_code );
       
   635 
       
   636 
       
   637   /*************************************************************************/
       
   638   /*                                                                       */
       
   639   /* <Section>                                                             */
       
   640   /*    cache_subsystem                                                    */
       
   641   /*                                                                       */
       
   642   /*************************************************************************/
       
   643 
       
   644 
       
   645   /*************************************************************************/
       
   646   /*************************************************************************/
       
   647   /*************************************************************************/
       
   648   /*****                                                               *****/
       
   649   /*****                       IMAGE CACHE OBJECT                      *****/
       
   650   /*****                                                               *****/
       
   651   /*************************************************************************/
       
   652   /*************************************************************************/
       
   653   /*************************************************************************/
       
   654 
       
   655 
       
   656   /*************************************************************************
       
   657    *
       
   658    * @struct:
       
   659    *   FTC_ImageTypeRec
       
   660    *
       
   661    * @description:
       
   662    *   A structure used to model the type of images in a glyph cache.
       
   663    *
       
   664    * @fields:
       
   665    *   face_id ::
       
   666    *     The face ID.
       
   667    *
       
   668    *   width ::
       
   669    *     The width in pixels.
       
   670    *
       
   671    *   height ::
       
   672    *     The height in pixels.
       
   673    *
       
   674    *   flags ::
       
   675    *     The load flags, as in @FT_Load_Glyph.
       
   676    *
       
   677    */
       
   678   typedef struct  FTC_ImageTypeRec_
       
   679   {
       
   680     FTC_FaceID  face_id;
       
   681     FT_Int      width;
       
   682     FT_Int      height;
       
   683     FT_Int32    flags;
       
   684 
       
   685   } FTC_ImageTypeRec;
       
   686 
       
   687 
       
   688   /*************************************************************************
       
   689    *
       
   690    * @type:
       
   691    *   FTC_ImageType
       
   692    *
       
   693    * @description:
       
   694    *   A handle to an @FTC_ImageTypeRec structure.
       
   695    *
       
   696    */
       
   697   typedef struct FTC_ImageTypeRec_*  FTC_ImageType;
       
   698 
       
   699 
       
   700   /* */
       
   701 
       
   702 
       
   703 #define FTC_IMAGE_TYPE_COMPARE( d1, d2 )      \
       
   704           ( (d1)->face_id == (d2)->face_id && \
       
   705             (d1)->width   == (d2)->width   && \
       
   706             (d1)->flags   == (d2)->flags   )
       
   707 
       
   708 #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
       
   709 
       
   710   /* this macro is incompatible with LLP64, should not be used */
       
   711 
       
   712 #define FTC_IMAGE_TYPE_HASH( d )                          \
       
   713           (FT_UFast)( FTC_FACE_ID_HASH( (d)->face_id )  ^ \
       
   714                       ( (d)->width << 8 ) ^ (d)->height ^ \
       
   715                       ( (d)->flags << 4 )               )
       
   716 
       
   717 #endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
       
   718 
       
   719 
       
   720   /*************************************************************************/
       
   721   /*                                                                       */
       
   722   /* <Type>                                                                */
       
   723   /*    FTC_ImageCache                                                     */
       
   724   /*                                                                       */
       
   725   /* <Description>                                                         */
       
   726   /*    A handle to an glyph image cache object.  They are designed to     */
       
   727   /*    hold many distinct glyph images while not exceeding a certain      */
       
   728   /*    memory threshold.                                                  */
       
   729   /*                                                                       */
       
   730   typedef struct FTC_ImageCacheRec_*  FTC_ImageCache;
       
   731 
       
   732 
       
   733   /*************************************************************************/
       
   734   /*                                                                       */
       
   735   /* <Function>                                                            */
       
   736   /*    FTC_ImageCache_New                                                 */
       
   737   /*                                                                       */
       
   738   /* <Description>                                                         */
       
   739   /*    Create a new glyph image cache.                                    */
       
   740   /*                                                                       */
       
   741   /* <Input>                                                               */
       
   742   /*    manager :: The parent manager for the image cache.                 */
       
   743   /*                                                                       */
       
   744   /* <Output>                                                              */
       
   745   /*    acache  :: A handle to the new glyph image cache object.           */
       
   746   /*                                                                       */
       
   747   /* <Return>                                                              */
       
   748   /*    FreeType error code.  0~means success.                             */
       
   749   /*                                                                       */
       
   750   FT_EXPORT( FT_Error )
       
   751   FTC_ImageCache_New( FTC_Manager      manager,
       
   752                       FTC_ImageCache  *acache );
       
   753 
       
   754 
       
   755   /*************************************************************************/
       
   756   /*                                                                       */
       
   757   /* <Function>                                                            */
       
   758   /*    FTC_ImageCache_Lookup                                              */
       
   759   /*                                                                       */
       
   760   /* <Description>                                                         */
       
   761   /*    Retrieve a given glyph image from a glyph image cache.             */
       
   762   /*                                                                       */
       
   763   /* <Input>                                                               */
       
   764   /*    cache  :: A handle to the source glyph image cache.                */
       
   765   /*                                                                       */
       
   766   /*    type   :: A pointer to a glyph image type descriptor.              */
       
   767   /*                                                                       */
       
   768   /*    gindex :: The glyph index to retrieve.                             */
       
   769   /*                                                                       */
       
   770   /* <Output>                                                              */
       
   771   /*    aglyph :: The corresponding @FT_Glyph object.  0~in case of        */
       
   772   /*              failure.                                                 */
       
   773   /*                                                                       */
       
   774   /*    anode  :: Used to return the address of of the corresponding cache */
       
   775   /*              node after incrementing its reference count (see note    */
       
   776   /*              below).                                                  */
       
   777   /*                                                                       */
       
   778   /* <Return>                                                              */
       
   779   /*    FreeType error code.  0~means success.                             */
       
   780   /*                                                                       */
       
   781   /* <Note>                                                                */
       
   782   /*    The returned glyph is owned and managed by the glyph image cache.  */
       
   783   /*    Never try to transform or discard it manually!  You can however    */
       
   784   /*    create a copy with @FT_Glyph_Copy and modify the new one.          */
       
   785   /*                                                                       */
       
   786   /*    If `anode' is _not_ NULL, it receives the address of the cache     */
       
   787   /*    node containing the glyph image, after increasing its reference    */
       
   788   /*    count.  This ensures that the node (as well as the @FT_Glyph) will */
       
   789   /*    always be kept in the cache until you call @FTC_Node_Unref to      */
       
   790   /*    `release' it.                                                      */
       
   791   /*                                                                       */
       
   792   /*    If `anode' is NULL, the cache node is left unchanged, which means  */
       
   793   /*    that the @FT_Glyph could be flushed out of the cache on the next   */
       
   794   /*    call to one of the caching sub-system APIs.  Don't assume that it  */
       
   795   /*    is persistent!                                                     */
       
   796   /*                                                                       */
       
   797   FT_EXPORT( FT_Error )
       
   798   FTC_ImageCache_Lookup( FTC_ImageCache  cache,
       
   799                          FTC_ImageType   type,
       
   800                          FT_UInt         gindex,
       
   801                          FT_Glyph       *aglyph,
       
   802                          FTC_Node       *anode );
       
   803 
       
   804 
       
   805   /*************************************************************************/
       
   806   /*                                                                       */
       
   807   /* <Function>                                                            */
       
   808   /*    FTC_ImageCache_LookupScaler                                        */
       
   809   /*                                                                       */
       
   810   /* <Description>                                                         */
       
   811   /*    A variant of @FTC_ImageCache_Lookup that uses an @FTC_ScalerRec    */
       
   812   /*    to specify the face ID and its size.                               */
       
   813   /*                                                                       */
       
   814   /* <Input>                                                               */
       
   815   /*    cache      :: A handle to the source glyph image cache.            */
       
   816   /*                                                                       */
       
   817   /*    scaler     :: A pointer to a scaler descriptor.                    */
       
   818   /*                                                                       */
       
   819   /*    load_flags :: The corresponding load flags.                        */
       
   820   /*                                                                       */
       
   821   /*    gindex     :: The glyph index to retrieve.                         */
       
   822   /*                                                                       */
       
   823   /* <Output>                                                              */
       
   824   /*    aglyph     :: The corresponding @FT_Glyph object.  0~in case of    */
       
   825   /*                  failure.                                             */
       
   826   /*                                                                       */
       
   827   /*    anode      :: Used to return the address of of the corresponding   */
       
   828   /*                  cache node after incrementing its reference count    */
       
   829   /*                  (see note below).                                    */
       
   830   /*                                                                       */
       
   831   /* <Return>                                                              */
       
   832   /*    FreeType error code.  0~means success.                             */
       
   833   /*                                                                       */
       
   834   /* <Note>                                                                */
       
   835   /*    The returned glyph is owned and managed by the glyph image cache.  */
       
   836   /*    Never try to transform or discard it manually!  You can however    */
       
   837   /*    create a copy with @FT_Glyph_Copy and modify the new one.          */
       
   838   /*                                                                       */
       
   839   /*    If `anode' is _not_ NULL, it receives the address of the cache     */
       
   840   /*    node containing the glyph image, after increasing its reference    */
       
   841   /*    count.  This ensures that the node (as well as the @FT_Glyph) will */
       
   842   /*    always be kept in the cache until you call @FTC_Node_Unref to      */
       
   843   /*    `release' it.                                                      */
       
   844   /*                                                                       */
       
   845   /*    If `anode' is NULL, the cache node is left unchanged, which means  */
       
   846   /*    that the @FT_Glyph could be flushed out of the cache on the next   */
       
   847   /*    call to one of the caching sub-system APIs.  Don't assume that it  */
       
   848   /*    is persistent!                                                     */
       
   849   /*                                                                       */
       
   850   /*    Calls to @FT_Set_Char_Size and friends have no effect on cached    */
       
   851   /*    glyphs; you should always use the FreeType cache API instead.      */
       
   852   /*                                                                       */
       
   853   FT_EXPORT( FT_Error )
       
   854   FTC_ImageCache_LookupScaler( FTC_ImageCache  cache,
       
   855                                FTC_Scaler      scaler,
       
   856                                FT_ULong        load_flags,
       
   857                                FT_UInt         gindex,
       
   858                                FT_Glyph       *aglyph,
       
   859                                FTC_Node       *anode );
       
   860 
       
   861 
       
   862   /*************************************************************************/
       
   863   /*                                                                       */
       
   864   /* <Type>                                                                */
       
   865   /*    FTC_SBit                                                           */
       
   866   /*                                                                       */
       
   867   /* <Description>                                                         */
       
   868   /*    A handle to a small bitmap descriptor.  See the @FTC_SBitRec       */
       
   869   /*    structure for details.                                             */
       
   870   /*                                                                       */
       
   871   typedef struct FTC_SBitRec_*  FTC_SBit;
       
   872 
       
   873 
       
   874   /*************************************************************************/
       
   875   /*                                                                       */
       
   876   /* <Struct>                                                              */
       
   877   /*    FTC_SBitRec                                                        */
       
   878   /*                                                                       */
       
   879   /* <Description>                                                         */
       
   880   /*    A very compact structure used to describe a small glyph bitmap.    */
       
   881   /*                                                                       */
       
   882   /* <Fields>                                                              */
       
   883   /*    width     :: The bitmap width in pixels.                           */
       
   884   /*                                                                       */
       
   885   /*    height    :: The bitmap height in pixels.                          */
       
   886   /*                                                                       */
       
   887   /*    left      :: The horizontal distance from the pen position to the  */
       
   888   /*                 left bitmap border (a.k.a. `left side bearing', or    */
       
   889   /*                 `lsb').                                               */
       
   890   /*                                                                       */
       
   891   /*    top       :: The vertical distance from the pen position (on the   */
       
   892   /*                 baseline) to the upper bitmap border (a.k.a. `top     */
       
   893   /*                 side bearing').  The distance is positive for upwards */
       
   894   /*                 y~coordinates.                                        */
       
   895   /*                                                                       */
       
   896   /*    format    :: The format of the glyph bitmap (monochrome or gray).  */
       
   897   /*                                                                       */
       
   898   /*    max_grays :: Maximum gray level value (in the range 1 to~255).     */
       
   899   /*                                                                       */
       
   900   /*    pitch     :: The number of bytes per bitmap line.  May be positive */
       
   901   /*                 or negative.                                          */
       
   902   /*                                                                       */
       
   903   /*    xadvance  :: The horizontal advance width in pixels.               */
       
   904   /*                                                                       */
       
   905   /*    yadvance  :: The vertical advance height in pixels.                */
       
   906   /*                                                                       */
       
   907   /*    buffer    :: A pointer to the bitmap pixels.                       */
       
   908   /*                                                                       */
       
   909   typedef struct  FTC_SBitRec_
       
   910   {
       
   911     FT_Byte   width;
       
   912     FT_Byte   height;
       
   913     FT_Char   left;
       
   914     FT_Char   top;
       
   915 
       
   916     FT_Byte   format;
       
   917     FT_Byte   max_grays;
       
   918     FT_Short  pitch;
       
   919     FT_Char   xadvance;
       
   920     FT_Char   yadvance;
       
   921 
       
   922     FT_Byte*  buffer;
       
   923 
       
   924   } FTC_SBitRec;
       
   925 
       
   926 
       
   927   /*************************************************************************/
       
   928   /*                                                                       */
       
   929   /* <Type>                                                                */
       
   930   /*    FTC_SBitCache                                                      */
       
   931   /*                                                                       */
       
   932   /* <Description>                                                         */
       
   933   /*    A handle to a small bitmap cache.  These are special cache objects */
       
   934   /*    used to store small glyph bitmaps (and anti-aliased pixmaps) in a  */
       
   935   /*    much more efficient way than the traditional glyph image cache     */
       
   936   /*    implemented by @FTC_ImageCache.                                    */
       
   937   /*                                                                       */
       
   938   typedef struct FTC_SBitCacheRec_*  FTC_SBitCache;
       
   939 
       
   940 
       
   941   /*************************************************************************/
       
   942   /*                                                                       */
       
   943   /* <Function>                                                            */
       
   944   /*    FTC_SBitCache_New                                                  */
       
   945   /*                                                                       */
       
   946   /* <Description>                                                         */
       
   947   /*    Create a new cache to store small glyph bitmaps.                   */
       
   948   /*                                                                       */
       
   949   /* <Input>                                                               */
       
   950   /*    manager :: A handle to the source cache manager.                   */
       
   951   /*                                                                       */
       
   952   /* <Output>                                                              */
       
   953   /*    acache  :: A handle to the new sbit cache.  NULL in case of error. */
       
   954   /*                                                                       */
       
   955   /* <Return>                                                              */
       
   956   /*    FreeType error code.  0~means success.                             */
       
   957   /*                                                                       */
       
   958   FT_EXPORT( FT_Error )
       
   959   FTC_SBitCache_New( FTC_Manager     manager,
       
   960                      FTC_SBitCache  *acache );
       
   961 
       
   962 
       
   963   /*************************************************************************/
       
   964   /*                                                                       */
       
   965   /* <Function>                                                            */
       
   966   /*    FTC_SBitCache_Lookup                                               */
       
   967   /*                                                                       */
       
   968   /* <Description>                                                         */
       
   969   /*    Look up a given small glyph bitmap in a given sbit cache and       */
       
   970   /*    `lock' it to prevent its flushing from the cache until needed.     */
       
   971   /*                                                                       */
       
   972   /* <Input>                                                               */
       
   973   /*    cache  :: A handle to the source sbit cache.                       */
       
   974   /*                                                                       */
       
   975   /*    type   :: A pointer to the glyph image type descriptor.            */
       
   976   /*                                                                       */
       
   977   /*    gindex :: The glyph index.                                         */
       
   978   /*                                                                       */
       
   979   /* <Output>                                                              */
       
   980   /*    sbit   :: A handle to a small bitmap descriptor.                   */
       
   981   /*                                                                       */
       
   982   /*    anode  :: Used to return the address of of the corresponding cache */
       
   983   /*              node after incrementing its reference count (see note    */
       
   984   /*              below).                                                  */
       
   985   /*                                                                       */
       
   986   /* <Return>                                                              */
       
   987   /*    FreeType error code.  0~means success.                             */
       
   988   /*                                                                       */
       
   989   /* <Note>                                                                */
       
   990   /*    The small bitmap descriptor and its bit buffer are owned by the    */
       
   991   /*    cache and should never be freed by the application.  They might    */
       
   992   /*    as well disappear from memory on the next cache lookup, so don't   */
       
   993   /*    treat them as persistent data.                                     */
       
   994   /*                                                                       */
       
   995   /*    The descriptor's `buffer' field is set to~0 to indicate a missing  */
       
   996   /*    glyph bitmap.                                                      */
       
   997   /*                                                                       */
       
   998   /*    If `anode' is _not_ NULL, it receives the address of the cache     */
       
   999   /*    node containing the bitmap, after increasing its reference count.  */
       
  1000   /*    This ensures that the node (as well as the image) will always be   */
       
  1001   /*    kept in the cache until you call @FTC_Node_Unref to `release' it.  */
       
  1002   /*                                                                       */
       
  1003   /*    If `anode' is NULL, the cache node is left unchanged, which means  */
       
  1004   /*    that the bitmap could be flushed out of the cache on the next      */
       
  1005   /*    call to one of the caching sub-system APIs.  Don't assume that it  */
       
  1006   /*    is persistent!                                                     */
       
  1007   /*                                                                       */
       
  1008   FT_EXPORT( FT_Error )
       
  1009   FTC_SBitCache_Lookup( FTC_SBitCache    cache,
       
  1010                         FTC_ImageType    type,
       
  1011                         FT_UInt          gindex,
       
  1012                         FTC_SBit        *sbit,
       
  1013                         FTC_Node        *anode );
       
  1014 
       
  1015 
       
  1016   /*************************************************************************/
       
  1017   /*                                                                       */
       
  1018   /* <Function>                                                            */
       
  1019   /*    FTC_SBitCache_LookupScaler                                         */
       
  1020   /*                                                                       */
       
  1021   /* <Description>                                                         */
       
  1022   /*    A variant of @FTC_SBitCache_Lookup that uses an @FTC_ScalerRec     */
       
  1023   /*    to specify the face ID and its size.                               */
       
  1024   /*                                                                       */
       
  1025   /* <Input>                                                               */
       
  1026   /*    cache      :: A handle to the source sbit cache.                   */
       
  1027   /*                                                                       */
       
  1028   /*    scaler     :: A pointer to the scaler descriptor.                  */
       
  1029   /*                                                                       */
       
  1030   /*    load_flags :: The corresponding load flags.                        */
       
  1031   /*                                                                       */
       
  1032   /*    gindex     :: The glyph index.                                     */
       
  1033   /*                                                                       */
       
  1034   /* <Output>                                                              */
       
  1035   /*    sbit       :: A handle to a small bitmap descriptor.               */
       
  1036   /*                                                                       */
       
  1037   /*    anode      :: Used to return the address of of the corresponding   */
       
  1038   /*                  cache node after incrementing its reference count    */
       
  1039   /*                  (see note below).                                    */
       
  1040   /*                                                                       */
       
  1041   /* <Return>                                                              */
       
  1042   /*    FreeType error code.  0~means success.                             */
       
  1043   /*                                                                       */
       
  1044   /* <Note>                                                                */
       
  1045   /*    The small bitmap descriptor and its bit buffer are owned by the    */
       
  1046   /*    cache and should never be freed by the application.  They might    */
       
  1047   /*    as well disappear from memory on the next cache lookup, so don't   */
       
  1048   /*    treat them as persistent data.                                     */
       
  1049   /*                                                                       */
       
  1050   /*    The descriptor's `buffer' field is set to~0 to indicate a missing  */
       
  1051   /*    glyph bitmap.                                                      */
       
  1052   /*                                                                       */
       
  1053   /*    If `anode' is _not_ NULL, it receives the address of the cache     */
       
  1054   /*    node containing the bitmap, after increasing its reference count.  */
       
  1055   /*    This ensures that the node (as well as the image) will always be   */
       
  1056   /*    kept in the cache until you call @FTC_Node_Unref to `release' it.  */
       
  1057   /*                                                                       */
       
  1058   /*    If `anode' is NULL, the cache node is left unchanged, which means  */
       
  1059   /*    that the bitmap could be flushed out of the cache on the next      */
       
  1060   /*    call to one of the caching sub-system APIs.  Don't assume that it  */
       
  1061   /*    is persistent!                                                     */
       
  1062   /*                                                                       */
       
  1063   FT_EXPORT( FT_Error )
       
  1064   FTC_SBitCache_LookupScaler( FTC_SBitCache  cache,
       
  1065                               FTC_Scaler     scaler,
       
  1066                               FT_ULong       load_flags,
       
  1067                               FT_UInt        gindex,
       
  1068                               FTC_SBit      *sbit,
       
  1069                               FTC_Node      *anode );
       
  1070 
       
  1071 
       
  1072  /* */
       
  1073 
       
  1074 #ifdef FT_CONFIG_OPTION_OLD_INTERNALS
       
  1075 
       
  1076   /*@***********************************************************************/
       
  1077   /*                                                                       */
       
  1078   /* <Struct>                                                              */
       
  1079   /*    FTC_FontRec                                                        */
       
  1080   /*                                                                       */
       
  1081   /* <Description>                                                         */
       
  1082   /*    A simple structure used to describe a given `font' to the cache    */
       
  1083   /*    manager.  Note that a `font' is the combination of a given face    */
       
  1084   /*    with a given character size.                                       */
       
  1085   /*                                                                       */
       
  1086   /* <Fields>                                                              */
       
  1087   /*    face_id    :: The ID of the face to use.                           */
       
  1088   /*                                                                       */
       
  1089   /*    pix_width  :: The character width in integer pixels.               */
       
  1090   /*                                                                       */
       
  1091   /*    pix_height :: The character height in integer pixels.              */
       
  1092   /*                                                                       */
       
  1093   typedef struct  FTC_FontRec_
       
  1094   {
       
  1095     FTC_FaceID  face_id;
       
  1096     FT_UShort   pix_width;
       
  1097     FT_UShort   pix_height;
       
  1098 
       
  1099   } FTC_FontRec;
       
  1100 
       
  1101 
       
  1102   /* */
       
  1103 
       
  1104 
       
  1105 #define FTC_FONT_COMPARE( f1, f2 )                  \
       
  1106           ( (f1)->face_id    == (f2)->face_id    && \
       
  1107             (f1)->pix_width  == (f2)->pix_width  && \
       
  1108             (f1)->pix_height == (f2)->pix_height )
       
  1109 
       
  1110   /* this macro is incompatible with LLP64, should not be used */
       
  1111 #define FTC_FONT_HASH( f )                              \
       
  1112           (FT_UInt32)( FTC_FACE_ID_HASH((f)->face_id) ^ \
       
  1113                        ((f)->pix_width << 8)          ^ \
       
  1114                        ((f)->pix_height)              )
       
  1115 
       
  1116   typedef FTC_FontRec*  FTC_Font;
       
  1117 
       
  1118 
       
  1119   FT_EXPORT( FT_Error )
       
  1120   FTC_Manager_Lookup_Face( FTC_Manager  manager,
       
  1121                            FTC_FaceID   face_id,
       
  1122                            FT_Face     *aface );
       
  1123 
       
  1124   FT_EXPORT( FT_Error )
       
  1125   FTC_Manager_Lookup_Size( FTC_Manager  manager,
       
  1126                            FTC_Font     font,
       
  1127                            FT_Face     *aface,
       
  1128                            FT_Size     *asize );
       
  1129 
       
  1130 #endif /* FT_CONFIG_OPTION_OLD_INTERNALS */
       
  1131 
       
  1132 
       
  1133  /* */
       
  1134 
       
  1135 FT_END_HEADER
       
  1136 
       
  1137 #endif /* __FTCACHE_H__ */
       
  1138 
       
  1139 
       
  1140 /* END */