1 /***************************************************************************/
5 /* TrueTypeGX/AAT mort table validation */
6 /* body for type5 (Contextual Glyph Insertion) subtable. */
8 /* Copyright 2005 by suzuki toshiya, Masatake YAMATO, Red Hat K.K., */
9 /* David Turner, Robert Wilhelm, and Werner Lemberg. */
11 /* This file is part of the FreeType project, and may only be used, */
12 /* modified, and distributed under the terms of the FreeType project */
13 /* license, LICENSE.TXT. By continuing to use, modify, or distribute */
14 /* this file you indicate that you have read the license and */
15 /* understand and accept it fully. */
17 /***************************************************************************/
19 /***************************************************************************/
21 /* gxvalid is derived from both gxlayout module and otvalid module. */
22 /* Development of gxlayout is supported by the Information-technology */
23 /* Promotion Agency(IPA), Japan. */
25 /***************************************************************************/
31 /*************************************************************************/
33 /* The macro FT_COMPONENT is used in trace mode. It is an implicit */
34 /* parameter of the FT_TRACE() and FT_ERROR() macros, used to print/log */
35 /* messages during execution. */
38 #define FT_COMPONENT trace_gxvmort
42 * mort subtable type5 (Contextual Glyph Insertion)
43 * has the format of StateTable with insertion-glyph-list,
44 * but without name. The offset is given by glyphOffset in
45 * entryTable. There is no table location declaration
49 typedef struct GXV_mort_subtable_type5_StateOptRec_
55 #define GXV_MORT_SUBTABLE_TYPE5_HEADER_SIZE GXV_STATETABLE_HEADER_SIZE
57 FT_UShort* classTable_length_p;
58 FT_UShort* stateArray_length_p;
59 FT_UShort* entryTable_length_p;
61 } GXV_mort_subtable_type5_StateOptRec,
62 *GXV_mort_subtable_type5_StateOptRecData;
66 gxv_mort_subtable_type5_subtable_setup( FT_UShort table_size,
70 FT_UShort* classTable_length_p,
71 FT_UShort* stateArray_length_p,
72 FT_UShort* entryTable_length_p,
75 GXV_mort_subtable_type5_StateOptRecData optdata =
76 (GXV_mort_subtable_type5_StateOptRecData)valid->statetable.optdata;
79 gxv_StateTable_subtable_setup( table_size,
88 optdata->classTable = classTable;
89 optdata->stateArray = stateArray;
90 optdata->entryTable = entryTable;
92 optdata->classTable_length_p = classTable_length_p;
93 optdata->stateArray_length_p = stateArray_length_p;
94 optdata->entryTable_length_p = entryTable_length_p;
99 gxv_mort_subtable_type5_InsertList_validate( FT_UShort offset,
103 GXV_Validator valid )
106 * We don't know the range of insertion-glyph-list.
107 * Set range by whole of state table.
109 FT_Bytes p = table + offset;
111 GXV_mort_subtable_type5_StateOptRecData optdata =
112 (GXV_mort_subtable_type5_StateOptRecData)valid->statetable.optdata;
114 if ( optdata->classTable < offset &&
115 offset < optdata->classTable + *(optdata->classTable_length_p) )
116 GXV_TRACE(( " offset runs into ClassTable" ));
117 if ( optdata->stateArray < offset &&
118 offset < optdata->stateArray + *(optdata->stateArray_length_p) )
119 GXV_TRACE(( " offset runs into StateArray" ));
120 if ( optdata->entryTable < offset &&
121 offset < optdata->entryTable + *(optdata->entryTable_length_p) )
122 GXV_TRACE(( " offset runs into EntryTable" ));
124 #ifndef GXV_LOAD_TRACE_VARS
125 GXV_LIMIT_CHECK( count * 2 );
127 while ( p < table + offset + ( count * 2 ) )
129 FT_UShort insert_glyphID;
132 GXV_LIMIT_CHECK( 2 );
133 insert_glyphID = FT_NEXT_USHORT( p );
134 GXV_TRACE(( " 0x%04x", insert_glyphID ));
142 gxv_mort_subtable_type5_entry_validate(
145 GXV_StateTable_GlyphOffsetCPtr glyphOffset,
148 GXV_Validator valid )
150 #ifdef GXV_LOAD_UNUSED_VARS
153 FT_Bool currentIsKashidaLike;
154 FT_Bool markedIsKashidaLike;
155 FT_Bool currentInsertBefore;
156 FT_Bool markedInsertBefore;
158 FT_Byte currentInsertCount;
159 FT_Byte markedInsertCount;
160 FT_UShort currentInsertList;
161 FT_UShort markedInsertList;
166 #ifdef GXV_LOAD_UNUSED_VARS
167 setMark = FT_BOOL( ( flags >> 15 ) & 1 );
168 dontAdvance = FT_BOOL( ( flags >> 14 ) & 1 );
169 currentIsKashidaLike = FT_BOOL( ( flags >> 13 ) & 1 );
170 markedIsKashidaLike = FT_BOOL( ( flags >> 12 ) & 1 );
171 currentInsertBefore = FT_BOOL( ( flags >> 11 ) & 1 );
172 markedInsertBefore = FT_BOOL( ( flags >> 10 ) & 1 );
175 currentInsertCount = (FT_Byte)( ( flags >> 5 ) & 0x1F );
176 markedInsertCount = (FT_Byte)( flags & 0x001F );
178 currentInsertList = (FT_UShort)( glyphOffset->ul >> 16 );
179 markedInsertList = (FT_UShort)( glyphOffset->ul );
181 if ( 0 != currentInsertList && 0 != currentInsertCount )
183 gxv_mort_subtable_type5_InsertList_validate( currentInsertList,
190 if ( 0 != markedInsertList && 0 != markedInsertCount )
192 gxv_mort_subtable_type5_InsertList_validate( markedInsertList,
202 gxv_mort_subtable_type5_validate( FT_Bytes table,
204 GXV_Validator valid )
208 GXV_mort_subtable_type5_StateOptRec et_rec;
209 GXV_mort_subtable_type5_StateOptRecData et = &et_rec;
212 GXV_NAME_ENTER( "mort chain subtable type5 (Glyph Insertion)" );
214 GXV_LIMIT_CHECK( GXV_MORT_SUBTABLE_TYPE5_HEADER_SIZE );
216 valid->statetable.optdata =
218 valid->statetable.optdata_load_func =
220 valid->statetable.subtable_setup_func =
221 gxv_mort_subtable_type5_subtable_setup;
222 valid->statetable.entry_glyphoffset_fmt =
223 GXV_GLYPHOFFSET_ULONG;
224 valid->statetable.entry_validate_func =
225 gxv_mort_subtable_type5_entry_validate;
227 gxv_StateTable_validate( p, limit, valid );