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