Subversion Repositories Kolibri OS

Rev

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

  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 */
  1141.