1 /**************************************************************************** 2 * 3 * fttypes.h 4 * 5 * FreeType simple types definitions (specification only). 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 FTTYPES_H_ 20 #define FTTYPES_H_ 21 22 23 #include <ft2build.h> 24 #include FT_CONFIG_CONFIG_H 25 #include <freetype/ftsystem.h> 26 #include <freetype/ftimage.h> 27 28 #include <stddef.h> 29 30 31 FT_BEGIN_HEADER 32 33 34 /************************************************************************** 35 * 36 * @section: 37 * basic_types 38 * 39 * @title: 40 * Basic Data Types 41 * 42 * @abstract: 43 * The basic data types defined by the library. 44 * 45 * @description: 46 * This section contains the basic data types defined by FreeType~2, 47 * ranging from simple scalar types to bitmap descriptors. More 48 * font-specific structures are defined in a different section. 49 * 50 * @order: 51 * FT_Byte 52 * FT_Bytes 53 * FT_Char 54 * FT_Int 55 * FT_UInt 56 * FT_Int16 57 * FT_UInt16 58 * FT_Int32 59 * FT_UInt32 60 * FT_Int64 61 * FT_UInt64 62 * FT_Short 63 * FT_UShort 64 * FT_Long 65 * FT_ULong 66 * FT_Bool 67 * FT_Offset 68 * FT_PtrDist 69 * FT_String 70 * FT_Tag 71 * FT_Error 72 * FT_Fixed 73 * FT_Pointer 74 * FT_Pos 75 * FT_Vector 76 * FT_BBox 77 * FT_Matrix 78 * FT_FWord 79 * FT_UFWord 80 * FT_F2Dot14 81 * FT_UnitVector 82 * FT_F26Dot6 83 * FT_Data 84 * 85 * FT_MAKE_TAG 86 * 87 * FT_Generic 88 * FT_Generic_Finalizer 89 * 90 * FT_Bitmap 91 * FT_Pixel_Mode 92 * FT_Palette_Mode 93 * FT_Glyph_Format 94 * FT_IMAGE_TAG 95 * 96 */ 97 98 99 /************************************************************************** 100 * 101 * @type: 102 * FT_Bool 103 * 104 * @description: 105 * A typedef of unsigned char, used for simple booleans. As usual, 106 * values 1 and~0 represent true and false, respectively. 107 */ 108 typedef unsigned char FT_Bool; 109 110 111 /************************************************************************** 112 * 113 * @type: 114 * FT_FWord 115 * 116 * @description: 117 * A signed 16-bit integer used to store a distance in original font 118 * units. 119 */ 120 typedef signed short FT_FWord; /* distance in FUnits */ 121 122 123 /************************************************************************** 124 * 125 * @type: 126 * FT_UFWord 127 * 128 * @description: 129 * An unsigned 16-bit integer used to store a distance in original font 130 * units. 131 */ 132 typedef unsigned short FT_UFWord; /* unsigned distance */ 133 134 135 /************************************************************************** 136 * 137 * @type: 138 * FT_Char 139 * 140 * @description: 141 * A simple typedef for the _signed_ char type. 142 */ 143 typedef signed char FT_Char; 144 145 146 /************************************************************************** 147 * 148 * @type: 149 * FT_Byte 150 * 151 * @description: 152 * A simple typedef for the _unsigned_ char type. 153 */ 154 typedef unsigned char FT_Byte; 155 156 157 /************************************************************************** 158 * 159 * @type: 160 * FT_Bytes 161 * 162 * @description: 163 * A typedef for constant memory areas. 164 */ 165 typedef const FT_Byte* FT_Bytes; 166 167 168 /************************************************************************** 169 * 170 * @type: 171 * FT_Tag 172 * 173 * @description: 174 * A typedef for 32-bit tags (as used in the SFNT format). 175 */ 176 typedef FT_UInt32 FT_Tag; 177 178 179 /************************************************************************** 180 * 181 * @type: 182 * FT_String 183 * 184 * @description: 185 * A simple typedef for the char type, usually used for strings. 186 */ 187 typedef char FT_String; 188 189 190 /************************************************************************** 191 * 192 * @type: 193 * FT_Short 194 * 195 * @description: 196 * A typedef for signed short. 197 */ 198 typedef signed short FT_Short; 199 200 201 /************************************************************************** 202 * 203 * @type: 204 * FT_UShort 205 * 206 * @description: 207 * A typedef for unsigned short. 208 */ 209 typedef unsigned short FT_UShort; 210 211 212 /************************************************************************** 213 * 214 * @type: 215 * FT_Int 216 * 217 * @description: 218 * A typedef for the int type. 219 */ 220 typedef signed int FT_Int; 221 222 223 /************************************************************************** 224 * 225 * @type: 226 * FT_UInt 227 * 228 * @description: 229 * A typedef for the unsigned int type. 230 */ 231 typedef unsigned int FT_UInt; 232 233 234 /************************************************************************** 235 * 236 * @type: 237 * FT_Long 238 * 239 * @description: 240 * A typedef for signed long. 241 */ 242 typedef signed long FT_Long; 243 244 245 /************************************************************************** 246 * 247 * @type: 248 * FT_ULong 249 * 250 * @description: 251 * A typedef for unsigned long. 252 */ 253 typedef unsigned long FT_ULong; 254 255 256 /************************************************************************** 257 * 258 * @type: 259 * FT_F2Dot14 260 * 261 * @description: 262 * A signed 2.14 fixed-point type used for unit vectors. 263 */ 264 typedef signed short FT_F2Dot14; 265 266 267 /************************************************************************** 268 * 269 * @type: 270 * FT_F26Dot6 271 * 272 * @description: 273 * A signed 26.6 fixed-point type used for vectorial pixel coordinates. 274 */ 275 typedef signed long FT_F26Dot6; 276 277 278 /************************************************************************** 279 * 280 * @type: 281 * FT_Fixed 282 * 283 * @description: 284 * This type is used to store 16.16 fixed-point values, like scaling 285 * values or matrix coefficients. 286 */ 287 typedef signed long FT_Fixed; 288 289 290 /************************************************************************** 291 * 292 * @type: 293 * FT_Error 294 * 295 * @description: 296 * The FreeType error code type. A value of~0 is always interpreted as a 297 * successful operation. 298 */ 299 typedef int FT_Error; 300 301 302 /************************************************************************** 303 * 304 * @type: 305 * FT_Pointer 306 * 307 * @description: 308 * A simple typedef for a typeless pointer. 309 */ 310 typedef void* FT_Pointer; 311 312 313 /************************************************************************** 314 * 315 * @type: 316 * FT_Offset 317 * 318 * @description: 319 * This is equivalent to the ANSI~C `size_t` type, i.e., the largest 320 * _unsigned_ integer type used to express a file size or position, or a 321 * memory block size. 322 */ 323 typedef size_t FT_Offset; 324 325 326 /************************************************************************** 327 * 328 * @type: 329 * FT_PtrDist 330 * 331 * @description: 332 * This is equivalent to the ANSI~C `ptrdiff_t` type, i.e., the largest 333 * _signed_ integer type used to express the distance between two 334 * pointers. 335 */ 336 typedef ft_ptrdiff_t FT_PtrDist; 337 338 339 /************************************************************************** 340 * 341 * @struct: 342 * FT_UnitVector 343 * 344 * @description: 345 * A simple structure used to store a 2D vector unit vector. Uses 346 * FT_F2Dot14 types. 347 * 348 * @fields: 349 * x :: 350 * Horizontal coordinate. 351 * 352 * y :: 353 * Vertical coordinate. 354 */ 355 typedef struct FT_UnitVector_ 356 { 357 FT_F2Dot14 x; 358 FT_F2Dot14 y; 359 360 } FT_UnitVector; 361 362 363 /************************************************************************** 364 * 365 * @struct: 366 * FT_Matrix 367 * 368 * @description: 369 * A simple structure used to store a 2x2 matrix. Coefficients are in 370 * 16.16 fixed-point format. The computation performed is: 371 * 372 * ``` 373 * x' = x*xx + y*xy 374 * y' = x*yx + y*yy 375 * ``` 376 * 377 * @fields: 378 * xx :: 379 * Matrix coefficient. 380 * 381 * xy :: 382 * Matrix coefficient. 383 * 384 * yx :: 385 * Matrix coefficient. 386 * 387 * yy :: 388 * Matrix coefficient. 389 */ 390 typedef struct FT_Matrix_ 391 { 392 FT_Fixed xx, xy; 393 FT_Fixed yx, yy; 394 395 } FT_Matrix; 396 397 398 /************************************************************************** 399 * 400 * @struct: 401 * FT_Data 402 * 403 * @description: 404 * Read-only binary data represented as a pointer and a length. 405 * 406 * @fields: 407 * pointer :: 408 * The data. 409 * 410 * length :: 411 * The length of the data in bytes. 412 */ 413 typedef struct FT_Data_ 414 { 415 const FT_Byte* pointer; 416 FT_UInt length; 417 418 } FT_Data; 419 420 421 /************************************************************************** 422 * 423 * @functype: 424 * FT_Generic_Finalizer 425 * 426 * @description: 427 * Describe a function used to destroy the 'client' data of any FreeType 428 * object. See the description of the @FT_Generic type for details of 429 * usage. 430 * 431 * @input: 432 * The address of the FreeType object that is under finalization. Its 433 * client data is accessed through its `generic` field. 434 */ 435 typedef void (*FT_Generic_Finalizer)( void* object ); 436 437 438 /************************************************************************** 439 * 440 * @struct: 441 * FT_Generic 442 * 443 * @description: 444 * Client applications often need to associate their own data to a 445 * variety of FreeType core objects. For example, a text layout API 446 * might want to associate a glyph cache to a given size object. 447 * 448 * Some FreeType object contains a `generic` field, of type `FT_Generic`, 449 * which usage is left to client applications and font servers. 450 * 451 * It can be used to store a pointer to client-specific data, as well as 452 * the address of a 'finalizer' function, which will be called by 453 * FreeType when the object is destroyed (for example, the previous 454 * client example would put the address of the glyph cache destructor in 455 * the `finalizer` field). 456 * 457 * @fields: 458 * data :: 459 * A typeless pointer to any client-specified data. This field is 460 * completely ignored by the FreeType library. 461 * 462 * finalizer :: 463 * A pointer to a 'generic finalizer' function, which will be called 464 * when the object is destroyed. If this field is set to `NULL`, no 465 * code will be called. 466 */ 467 typedef struct FT_Generic_ 468 { 469 void* data; 470 FT_Generic_Finalizer finalizer; 471 472 } FT_Generic; 473 474 475 /************************************************************************** 476 * 477 * @macro: 478 * FT_MAKE_TAG 479 * 480 * @description: 481 * This macro converts four-letter tags that are used to label TrueType 482 * tables into an `FT_Tag` type, to be used within FreeType. 483 * 484 * @note: 485 * The produced values **must** be 32-bit integers. Don't redefine this 486 * macro. 487 */ 488 #define FT_MAKE_TAG( _x1, _x2, _x3, _x4 ) \ 489 ( ( FT_STATIC_BYTE_CAST( FT_Tag, _x1 ) << 24 ) | \ 490 ( FT_STATIC_BYTE_CAST( FT_Tag, _x2 ) << 16 ) | \ 491 ( FT_STATIC_BYTE_CAST( FT_Tag, _x3 ) << 8 ) | \ 492 FT_STATIC_BYTE_CAST( FT_Tag, _x4 ) ) 493 494 495 /*************************************************************************/ 496 /*************************************************************************/ 497 /* */ 498 /* L I S T M A N A G E M E N T */ 499 /* */ 500 /*************************************************************************/ 501 /*************************************************************************/ 502 503 504 /************************************************************************** 505 * 506 * @section: 507 * list_processing 508 * 509 */ 510 511 512 /************************************************************************** 513 * 514 * @type: 515 * FT_ListNode 516 * 517 * @description: 518 * Many elements and objects in FreeType are listed through an @FT_List 519 * record (see @FT_ListRec). As its name suggests, an FT_ListNode is a 520 * handle to a single list element. 521 */ 522 typedef struct FT_ListNodeRec_* FT_ListNode; 523 524 525 /************************************************************************** 526 * 527 * @type: 528 * FT_List 529 * 530 * @description: 531 * A handle to a list record (see @FT_ListRec). 532 */ 533 typedef struct FT_ListRec_* FT_List; 534 535 536 /************************************************************************** 537 * 538 * @struct: 539 * FT_ListNodeRec 540 * 541 * @description: 542 * A structure used to hold a single list element. 543 * 544 * @fields: 545 * prev :: 546 * The previous element in the list. `NULL` if first. 547 * 548 * next :: 549 * The next element in the list. `NULL` if last. 550 * 551 * data :: 552 * A typeless pointer to the listed object. 553 */ 554 typedef struct FT_ListNodeRec_ 555 { 556 FT_ListNode prev; 557 FT_ListNode next; 558 void* data; 559 560 } FT_ListNodeRec; 561 562 563 /************************************************************************** 564 * 565 * @struct: 566 * FT_ListRec 567 * 568 * @description: 569 * A structure used to hold a simple doubly-linked list. These are used 570 * in many parts of FreeType. 571 * 572 * @fields: 573 * head :: 574 * The head (first element) of doubly-linked list. 575 * 576 * tail :: 577 * The tail (last element) of doubly-linked list. 578 */ 579 typedef struct FT_ListRec_ 580 { 581 FT_ListNode head; 582 FT_ListNode tail; 583 584 } FT_ListRec; 585 586 /* */ 587 588 589 #define FT_IS_EMPTY( list ) ( (list).head == 0 ) 590 #define FT_BOOL( x ) FT_STATIC_CAST( FT_Bool, (x) != 0 ) 591 592 /* concatenate C tokens */ 593 #define FT_ERR_XCAT( x, y ) x ## y 594 #define FT_ERR_CAT( x, y ) FT_ERR_XCAT( x, y ) 595 596 /* see `ftmoderr.h` for descriptions of the following macros */ 597 598 #define FT_ERR( e ) FT_ERR_CAT( FT_ERR_PREFIX, e ) 599 600 #define FT_ERROR_BASE( x ) ( (x) & 0xFF ) 601 #define FT_ERROR_MODULE( x ) ( (x) & 0xFF00U ) 602 603 #define FT_ERR_EQ( x, e ) \ 604 ( FT_ERROR_BASE( x ) == FT_ERROR_BASE( FT_ERR( e ) ) ) 605 #define FT_ERR_NEQ( x, e ) \ 606 ( FT_ERROR_BASE( x ) != FT_ERROR_BASE( FT_ERR( e ) ) ) 607 608 609 FT_END_HEADER 610 611 #endif /* FTTYPES_H_ */ 612 613 614 /* END */ 615