/***************************************************************************/ /* */ /* ftdriver.h */ /* */ /* FreeType driver interface (specification). */ /* */ /* Copyright 1996-1999 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. */ /* */ /***************************************************************************/ #ifndef FTDRIVER_H #define FTDRIVER_H #include /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /**** ****/ /**** ****/ /**** D R I V E R S ****/ /**** ****/ /**** ****/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /* */ /* */ /* FTDriver_initDriver */ /* */ /* */ /* A driver method used to create a new driver object for a given */ /* format. */ /* */ /* */ /* driver :: A handle to the `new' driver object. The fields */ /* `library', `system', and `lock' are already set when the */ /* base layer calls this method. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ typedef FT_Error (*FTDriver_initDriver)( FT_Driver driver ); /*************************************************************************/ /* */ /* */ /* FTDriver_doneEngine */ /* */ /* */ /* A driver method used to finalize a given driver object. Note that */ /* all faces and resources for this driver have been released before */ /* this call, and that this function should NOT destroy the driver */ /* object. */ /* */ /* */ /* driver :: A handle to target driver object. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ typedef FT_Error (*FTDriver_doneDriver)( FT_Driver driver ); /*************************************************************************/ /* */ /* */ /* FTDriver_getInterface */ /* */ /* */ /* Each driver can provide one or more extensions to the base */ /* FreeType API. These can be used to access format specific */ /* features (e.g., all TrueType/OpenType resources share a common */ /* file structure and common tables which can be accessed through the */ /* `sfnt' interface), or more simply generic ones (e.g., the */ /* `postscript names' interface which can be used to retrieve the */ /* PostScript name of a given glyph index). */ /* */ /* */ /* driver :: A handle to a driver object. */ /* interface :: A string designing the interface. Examples */ /* are `sfnt', `post_names', `charmaps', etc. */ /* */ /* */ /* A typeless pointer to the extension's interface (normally a table */ /* of function pointers). Returns NULL when the requested extension */ /* isn't available (i.e., wasn't compiled in the driver at build */ /* time). */ /* */ typedef void* (*FTDriver_getInterface)( FT_Driver driver, const FT_String* interface ); /*************************************************************************/ /* */ /* */ /* FTDriver_formatInterface */ /* */ /* */ /* A driver interface field whose value is a driver-specific */ /* interface method tables. This table contains entry points to */ /* various functions that are strictly related to the driver's */ /* format. */ /* */ typedef void* FT_FormatInterface; /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /**** ****/ /**** ****/ /**** F A C E S ****/ /**** ****/ /**** ****/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /* */ /* */ /* FTDriver_initFace */ /* */ /* */ /* A driver method used to initialize a new face object. The object */ /* must be created by the caller. */ /* */ /* */ /* driver :: A handle to the source driver object. */ /* resource :: A handle to the source resource. */ /* typeface_index :: The index of face in the font resource. Used to */ /* access individual faces in collections. */ /* */ /* face :: A handle to the new target face. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ /* */ /* The `typeface_index' parameter field will be set to -1 when the */ /* engine only wants to test the format of the resource. This means */ /* that font drivers should simply check the font format, then return */ /* immediately with an error code of 0 (meaning success). The field */ /* `num_faces' should be set. */ /* */ /* done_face() will be called subsequently, whatever the result was. */ /* */ typedef FT_Error (*FTDriver_initFace)( FT_Stream stream, FT_Long typeface_index, FT_Face face ); /*************************************************************************/ /* */ /* */ /* FTDriver_doneFace */ /* */ /* */ /* A driver method used to finalize a given face object. This */ /* function does NOT destroy the object, that is the responsibility */ /* of the caller. */ /* */ /* */ /* face :: A handle to the target face object. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ typedef void (*FTDriver_doneFace)( FT_Face face ); /*************************************************************************/ /* */ /* */ /* FTDriver_getKerning */ /* */ /* */ /* A driver method used to return the kerning vector between two */ /* glyphs of the same face. */ /* */ /* */ /* face :: A handle to the source face object. */ /* */ /* left_glyph :: The index of the left glyph in the kern pair. */ /* */ /* right_glyph :: The index of the right glyph in the kern pair. */ /* */ /* */ /* kerning :: The kerning vector. This is in font units for */ /* scalable formats, and in pixels for fixed-sizes */ /* formats. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ /* */ /* Only horizontal layouts (left-to-right & right-to-left) are */ /* supported by this method. Other layouts, or more sophisticated */ /* kernings are out of the scope of this method (the basic driver */ /* interface is meant to be simple). */ /* */ /* They can be implemented through format-specific interfaces. */ /* */ typedef FT_Error (*FTDriver_getKerning)( FT_Face face, FT_UInt left_glyph, FT_UInt right_glyph, FT_Vector* kerning ); /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /**** ****/ /**** ****/ /**** S I Z E S ****/ /**** ****/ /**** ****/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /* */ /* */ /* FTDriver_initSize */ /* */ /* */ /* A driver method used to initialize a new size object. The object */ /* must be created by the caller. */ /* */ /* */ /* face :: A handle to the parent face object. */ /* size :: A handle to the new size object. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ /* */ /* This function should return an error if the face's format isn't */ /* scalable. */ /* */ typedef FT_Error (*FTDriver_initSize)( FT_Size size ); /*************************************************************************/ /* */ /* */ /* FTDriver_setCharSizes */ /* */ /* */ /* A driver method used to reset a size's character sizes (horizontal */ /* and vertical) expressed in fractional points. */ /* */ /* */ /* size :: A handle to the target size object. */ /* char_width :: The character width expressed in 26.6 fractional */ /* points. */ /* char_height :: The character height expressed in 26.6 fractional */ /* points. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ /* */ /* This function should always FAIL if the face format isn't */ /* scalable! */ /* */ typedef FT_Error (*FTDriver_setCharSizes)( FT_Size size, FT_F26Dot6 char_width, FT_F26Dot6 char_height, FT_UInt horz_resolution, FT_UInt vert_resolution ); /*************************************************************************/ /* */ /* */ /* FTDriver_setPixelSizes */ /* */ /* */ /* A driver method used to reset a size's character sizes (horizontal */ /* and vertical) expressed in integer pixels. */ /* */ /* */ /* size :: A handle to the target size object. */ /* */ /* pixel_width :: The character width expressed in 26.6 fractional */ /* pixels. */ /* */ /* pixel_height :: The character height expressed in 26.6 fractional */ /* pixels. */ /* */ /* point_size :: The corresponding character size in points. This */ /* value is only sent to the TrueType bytecode */ /* interpreter, even though 99% of glyph programs */ /* will simply ignore it. A safe value there is the */ /* maximum of the pixel width and height (multiplied */ /* by 64 to make it a 26.6 fixed float). */ /* */ /* FreeType error code. 0 means success. */ /* */ /* */ /* This function should work with all kinds of `Size' objects, either */ /* fixed or scalable ones. The `point_size' parameter will simply be */ /* ignored in case of fixed formats. */ /* */ typedef FT_Error (*FTDriver_setPixelSizes)( FT_Size size, FT_UInt pixel_width, FT_UInt pixel_height ); /*************************************************************************/ /* */ /* */ /* FTDriver_doneSize */ /* */ /* */ /* A driver method used to finalize a given size object. This method */ /* does NOT destroy the object; this is the responsibility of the */ /* caller. */ /* */ /* */ /* size :: A handle to the target size object. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ typedef void (*FTDriver_doneSize)( FT_Size size ); /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /**** ****/ /**** ****/ /**** G L Y P H S L O T S ****/ /**** ****/ /**** ****/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /* */ /* */ /* FTDriver_initGlyphSlot */ /* */ /* */ /* A driver method used to initialize a new glyph slot object. The */ /* object must be created by the caller. The glyph slot is a */ /* container where a single glyph can be loaded, either in outline or */ /* bitmap format. */ /* */ /* */ /* face :: A handle to the parent face object. */ /* slot :: A handle to the new glyph slot object. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ typedef FT_Error (*FTDriver_initGlyphSlot)( FT_GlyphSlot slot ); /*************************************************************************/ /* */ /* */ /* FTDriver_doneGlyphSlot */ /* */ /* */ /* A driver method used to finalize a given glyph slot. The object */ /* is not destroyed by this function. */ /* */ /* */ /* face :: A handle to the parent face object. */ /* slot :: A handle to the new glyph slot object. */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ typedef void (*FTDriver_doneGlyphSlot)( FT_GlyphSlot slot ); /*************************************************************************/ /* */ /* */ /* FTDriver_loadGlyph */ /* */ /* */ /* A driver method used to load a glyph within a given glyph slot. */ /* */ /* */ /* slot :: A handle to target slot object where the glyph will */ /* be loaded. */ /* */ /* size :: A handle to the source face size at which the glyph */ /* must be scaled/loaded. */ /* */ /* glyph_index :: The index of the glyph in the font file. */ /* */ /* load_flags :: A flag indicating what to load for this glyph. The */ /* FTLOAD_??? constants can be used to control the */ /* glyph loading process (e.g., whether the outline */ /* should be scaled, whether to load bitmaps or not, */ /* whether to hint the outline, etc). */ /* */ /* result :: A set of bit flags indicating the type of data that */ /* was loaded in the glyph slot (outline, bitmap, */ /* pixmap, etc). */ /* */ /* */ /* FreeType error code. 0 means success. */ /* */ typedef FT_Error (*FTDriver_loadGlyph)( FT_GlyphSlot slot, FT_Size size, FT_UInt glyph_index, FT_Int load_flags ); /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /**** ****/ /**** ****/ /**** C H A R A C T E R M A P S ****/ /**** ****/ /**** ****/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /*************************************************************************/ /* */ /* */ /* FTDriver_getCharIndex */ /* */ /* */ /* Uses a charmap to return a given character code's glyph index. */ /* */ /* */ /* charmap :: A handle to the source charmap object. */ /* charcode :: The character code. */ /* */ /* */ /* The glyph index. 0 means `undefined character code'. */ /* */ typedef FT_UInt (*FTDriver_getCharIndex)( FT_CharMap charmap, FT_Long charcode ); /*************************************************************************/ /* */ /* */ /* FT_DriverInterface */ /* */ /* */ /* A structure which holds a font driver's basic interface used by */ /* the high-level parts of FreeType (or other applications). */ /* */ /* Most scalable drivers provide a specialized interface to access */ /* format specific features. It can be retrieved with a call to */ /* `get_format_interface()', and should be defined in each font */ /* driver header (e.g., ttdriver.h, t1driver.h, etc). */ /* */ /* All fields are function pointers. */ /* */ /* */ /* driver_object_size :: The size in bytes of a single driver */ /* object. */ /* */ /* face_object_size :: The size in bytes of a single face object. */ /* */ /* size_object_size :: The size in bytes of a single size object. */ /* */ /* slot_object_size :: The size in bytes of a single glyph slot */ /* object. */ /* */ /* driver_name :: a string to describe the driver to the */ /* system. It doesn't necessarily describe */ /* in detail all the font formats the driver */ /* may support. */ /* */ /* driver_version :: driver version number. starts at 1 */ /* */ /* driver_requires :: the FreeType major version this driver is */ /* written for. This number should be equal */ /* to or greater than 2 ! */ /* */ /* format_interface :: A pointer to the driver's format-specific */ /* interface. */ /* */ /* init_driver :: Used to initialize a given driver object. */ /* */ /* done_driver :: Used to finalize and destroy a given */ /* driver object. */ /* */ /* get_extension :: Returns an interface for a given driver */ /* extension. */ /* */ /* init_face :: Initializes a given face object. */ /* */ /* done_face :: Discards a face object, as well as all */ /* child objects (sizes, charmaps, glyph */ /* slots). */ /* */ /* get_kerning :: Returns the kerning vector corresponding */ /* to a pair of glyphs, expressed in unscaled */ /* font units. */ /* */ /* init_size :: Initializes a given size object. */ /* */ /* done_size :: Finalizes a given size object. */ /* */ /* set_size_char_sizes :: Resets a scalable size object's character */ /* size. */ /* */ /* set_pixel_sizes :: Resets a face size object's pixel */ /* dimensions. Applies to both scalable and */ /* fixed faces. */ /* */ /* init_glyph_slot :: Initializes a given glyph slot object. */ /* */ /* done_glyph_slot :: Finalizes a given glyph slot. */ /* */ /* load_glyph :: Loads a given glyph into a given slot. */ /* */ typedef struct FT_DriverInterface_ { FT_Int driver_object_size; FT_Int face_object_size; FT_Int size_object_size; FT_Int slot_object_size; FT_String* driver_name; FT_Int driver_version; FT_Int driver_requires; void* format_interface; FTDriver_initDriver init_driver; FTDriver_doneDriver done_driver; FTDriver_getInterface get_interface; FTDriver_initFace init_face; FTDriver_doneFace done_face; FTDriver_getKerning get_kerning; FTDriver_initSize init_size; FTDriver_doneSize done_size; FTDriver_setCharSizes set_char_sizes; FTDriver_setPixelSizes set_pixel_sizes; FTDriver_initGlyphSlot init_glyph_slot; FTDriver_doneGlyphSlot done_glyph_slot; FTDriver_loadGlyph load_glyph; FTDriver_getCharIndex get_char_index; } FT_DriverInterface; /*************************************************************************/ /* */ /* */ /* FT_DriverChain */ /* */ /* */ /* A very structure used exclusively by "ftinit.c" in the function */ /* FT_Add_Default_Drivers. This function is in charge of loading the */ /* set of "default" font drivers into each new library object. */ /* */ /* The set itself is determined at _compile_ time through various */ /* macro definitions. */ /* */ /* */ /* next :: pointer to next element in driver list chain */ /* interface :: pointer to the driver's interface */ /* */ typedef struct FT_DriverChain_ FT_DriverChain; struct FT_DriverChain_ { const FT_DriverChain* next; const FT_DriverInterface* interface; }; /************************************************************************* * * Here is a template of the code that should appear in each * font driver's _interface_ file (the one included by "ftinit.c"). * * It is used to build, at compile time, a simple linked list of * the interfaces of the drivers which have been #included in * "ftinit.c". See the source code of the latter file for details * * (Note that this is only required when you want your driver included * in the set of default drivers loaded by FT_Init_FreeType. Other * drivers can still be added manually at runtime with FT_Add_Driver. * * { * #ifdef FTINIT_DRIVER_CHAIN * * static * const FT_DriverChain ftinit__driver_chain = * { * FT_INIT_LAST_DRIVER_CHAIN, * &_driver_interface * }; * * #undef FT_INIT_LAST_DRIVER_CHAIN * #define FT_INIT_LAST_DRIVER_CHAIN &ftinit__driver_chain * * #endif * } * * replace with your driver's prefix * *************************************************************************/ #endif /* FTDRIVER_H */ /* END */