FreeType » Docs » Miscellaneous » OpenType Validation
OpenType Validation¶
Synopsis¶
This section contains the declaration of functions to validate some OpenType tables (BASE, GDEF, GPOS, GSUB, JSTF, MATH).
FT_OpenType_Validate¶
Defined in FT_OPENTYPE_VALIDATE_H (freetype/ftotval.h).
FT_EXPORT( FT_Error )
FT_OpenType_Validate( FT_Face face,
FT_UInt validation_flags,
FT_Bytes *BASE_table,
FT_Bytes *GDEF_table,
FT_Bytes *GPOS_table,
FT_Bytes *GSUB_table,
FT_Bytes *JSTF_table );
Validate various OpenType tables to assure that all offsets and indices are valid. The idea is that a higher-level library that actually does the text layout can access those tables without error checking (which can be quite time consuming).
input
face |
A handle to the input face. |
validation_flags |
A bit field that specifies the tables to be validated. See |
output
BASE_table |
A pointer to the BASE table. |
GDEF_table |
A pointer to the GDEF table. |
GPOS_table |
A pointer to the GPOS table. |
GSUB_table |
A pointer to the GSUB table. |
JSTF_table |
A pointer to the JSTF table. |
return
FreeType error code. 0 means success.
note
This function only works with OpenType fonts, returning an error otherwise.
After use, the application should deallocate the five tables with FT_OpenType_Free
. A NULL
value indicates that the table either doesn't exist in the font, or the application hasn't asked for validation.
FT_OpenType_Free¶
Defined in FT_OPENTYPE_VALIDATE_H (freetype/ftotval.h).
Free the buffer allocated by OpenType validator.
input
face |
A handle to the input face. |
table |
The pointer to the buffer that is allocated by |
note
This function must be used to free the buffer allocated by FT_OpenType_Validate
only.
FT_VALIDATE_OTXXX¶
Defined in FT_OPENTYPE_VALIDATE_H (freetype/ftotval.h).
#define FT_VALIDATE_BASE 0x0100
#define FT_VALIDATE_GDEF 0x0200
#define FT_VALIDATE_GPOS 0x0400
#define FT_VALIDATE_GSUB 0x0800
#define FT_VALIDATE_JSTF 0x1000
#define FT_VALIDATE_MATH 0x2000
#define FT_VALIDATE_OT ( FT_VALIDATE_BASE | \
FT_VALIDATE_GDEF | \
FT_VALIDATE_GPOS | \
FT_VALIDATE_GSUB | \
FT_VALIDATE_JSTF | \
FT_VALIDATE_MATH )
A list of bit-field constants used with FT_OpenType_Validate
to indicate which OpenType tables should be validated.
values
FT_VALIDATE_BASE |
Validate BASE table. |
FT_VALIDATE_GDEF |
Validate GDEF table. |
FT_VALIDATE_GPOS |
Validate GPOS table. |
FT_VALIDATE_GSUB |
Validate GSUB table. |
FT_VALIDATE_JSTF |
Validate JSTF table. |
FT_VALIDATE_MATH |
Validate MATH table. |
FT_VALIDATE_OT |
Validate all OpenType tables (BASE, GDEF, GPOS, GSUB, JSTF, MATH). |