• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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