(***************************************************************************) (* *) (* fttypes.h *) (* *) (* FreeType simple types definitions (specification only). *) (* *) (* Copyright 1996-2001, 2002, 2004, 2006, 2007 by *) (* David Turner, Robert Wilhelm, and Werner Lemberg. *) (* *) (* This file is part of the FreeType project, and may only be used, *) (* modified, and distributed under the terms of the FreeType project *) (* license, LICENSE.TXT. By continuing to use, modify, or distribute *) (* this file you indicate that you have read the license and *) (* understand and accept it fully. *) (* *) (***************************************************************************) (***************************************************************************) (* Pascal port by the UltraStar Deluxe Team *) (***************************************************************************) (*************************************************************************) (* *) (* <Section> *) (* basic_types *) (* *) (* <Title> *) (* Basic Data Types *) (* *) (* <Abstract> *) (* The basic data types defined by the library. *) (* *) (* <Description> *) (* This section contains the basic data types defined by FreeType 2, *) (* ranging from simple scalar types to bitmap descriptors. More *) (* font-specific structures are defined in a different section. *) (* *) (* <Order> *) (* FT_Byte *) (* FT_Bytes *) (* FT_Char *) (* FT_Int *) (* FT_UInt *) (* FT_Short *) (* FT_UShort *) (* FT_Long *) (* FT_ULong *) (* FT_Bool *) (* FT_Offset *) (* FT_PtrDist *) (* FT_String *) (* FT_Tag *) (* FT_Error *) (* FT_Fixed *) (* FT_Pointer *) (* FT_Pos *) (* FT_Vector *) (* FT_BBox *) (* FT_Matrix *) (* FT_FWord *) (* FT_UFWord *) (* FT_F2Dot14 *) (* FT_UnitVector *) (* FT_F26Dot6 *) (* *) (* *) (* FT_Generic *) (* FT_Generic_Finalizer *) (* *) (* FT_Bitmap *) (* FT_Pixel_Mode *) (* FT_Palette_Mode *) (* FT_Glyph_Format *) (* FT_IMAGE_TAG *) (* *) (*************************************************************************) {$IFDEF TYPE_DECL} (*************************************************************************) (* *) (* <Type> *) (* FT_Bool *) (* *) (* <Description> *) (* A typedef of unsigned char, used for simple booleans. As usual, *) (* values 1 and 0 represent true and false, respectively. *) (* *) FT_Bool = cuchar; {$ENDIF TYPE_DECL} {$IFNDEF TYPE_DECL} const FT_FALSE = 0; FT_TRUE = 1; {$ENDIF !TYPE_DECL} {$IFDEF TYPE_DECL} (*************************************************************************) (* *) (* <Type> *) (* FT_Byte *) (* *) (* <Description> *) (* A simple typedef for the _unsigned_ char type. *) (* *) FT_Byte = cuchar; PFT_Byte = ^FT_Byte; (*************************************************************************) (* *) (* <Type> *) (* FT_String *) (* *) (* <Description> *) (* A simple typedef for the char type, usually used for strings. *) (* *) FT_String = cchar; PFT_String = ^FT_String; (*************************************************************************) (* *) (* <Type> *) (* FT_Short *) (* *) (* <Description> *) (* A typedef for signed short. *) (* *) FT_Short = csshort; PFT_Short = ^FT_Short; PFT_ShortArray = ^FT_ShortArray; FT_ShortArray = array[0 .. (MaxInt div SizeOf(FT_Short))-1] of FT_Short; (*************************************************************************) (* *) (* <Type> *) (* FT_UShort *) (* *) (* <Description> *) (* A typedef for unsigned short. *) (* *) FT_UShort = cushort; (*************************************************************************) (* *) (* <Type> *) (* FT_Int *) (* *) (* <Description> *) (* A typedef for the int type. *) (* *) FT_Int = csint; (*************************************************************************) (* *) (* <Type> *) (* FT_UInt *) (* *) (* <Description> *) (* A typedef for the unsigned int type. *) (* *) FT_UInt = cuint; (*************************************************************************) (* *) (* <Type> *) (* FT_Long *) (* *) (* <Description> *) (* A typedef for signed long. *) (* *) FT_Long = cslong; (*************************************************************************) (* *) (* <Type> *) (* FT_ULong *) (* *) (* <Description> *) (* A typedef for unsigned long. *) (* *) FT_ULong = culong; (*************************************************************************) (* *) (* <Type> *) (* FT_F26Dot6 *) (* *) (* <Description> *) (* A signed 26.6 fixed float type used for vectorial pixel *) (* coordinates. *) (* *) FT_F26Dot6 = cslong; (*************************************************************************) (* *) (* <Type> *) (* FT_Fixed *) (* *) (* <Description> *) (* This type is used to store 16.16 fixed float values, like scaling *) (* values or matrix coefficients. *) (* *) FT_Fixed = cslong; (*************************************************************************) (* *) (* <Type> *) (* FT_Error *) (* *) (* <Description> *) (* The FreeType error code type. A value of 0 is always interpreted *) (* as a successful operation. *) (* *) FT_Error = cint; (*************************************************************************) (* *) (* <Struct> *) (* FT_Matrix *) (* *) (* <Description> *) (* A simple structure used to store a 2x2 matrix. Coefficients are *) (* in 16.16 fixed float format. The computation performed is: *) (* *) (* { *) (* x' = x*xx + y*xy *) (* y' = x*yx + y*yy *) (* } *) (* *) (* <Fields> *) (* xx :: Matrix coefficient. *) (* *) (* xy :: Matrix coefficient. *) (* *) (* yx :: Matrix coefficient. *) (* *) (* yy :: Matrix coefficient. *) (* *) PFT_Matrix = ^FT_Matrix; FT_Matrix = record xx, xy: FT_Fixed; yx, yy: FT_Fixed; end; (*************************************************************************) (* *) (* <FuncType> *) (* FT_Generic_Finalizer *) (* *) (* <Description> *) (* Describes a function used to destroy the `client' data of any *) (* FreeType object. See the description of the FT_Generic type for *) (* details of usage. *) (* *) (* <Input> *) (* The address of the FreeType object which is under finalization. *) (* Its client data is accessed through its `generic' field. *) (* *) FT_Generic_Finalizer = procedure(AnObject : pointer ); cdecl; (*************************************************************************) (* *) (* <Struct> *) (* FT_Generic *) (* *) (* <Description> *) (* Client applications often need to associate their own data to a *) (* variety of FreeType core objects. For example, a text layout API *) (* might want to associate a glyph cache to a given size object. *) (* *) (* Most FreeType object contains a `generic' field, of type *) (* FT_Generic, which usage is left to client applications and font *) (* servers. *) (* *) (* It can be used to store a pointer to client-specific data, as well *) (* as the address of a `finalizer' function, which will be called by *) (* FreeType when the object is destroyed (for example, the previous *) (* client example would put the address of the glyph cache destructor *) (* in the `finalizer' field). *) (* *) (* <Fields> *) (* data :: A typeless pointer to any client-specified data. This *) (* field is completely ignored by the FreeType library. *) (* *) (* finalizer :: A pointer to a `generic finalizer' function, which *) (* will be called when the object is destroyed. If this *) (* field is set to NULL, no code will be called. *) (* *) FT_Generic = record data: pointer; finalizer: FT_Generic_Finalizer; end; TByteArray = array [0 .. (MaxInt div SizeOf(byte))-1] of byte; PByteArray = ^TByteArray; {$ENDIF TYPE_DECL}