* src/cff/cffload.c (CFF_Load_Charset): Improved error messages.
(CFF_Load_Charset, CFF_Load_Encoding): Remove unnecessary variable definition. * src/cff/t2gload.c (t2_lookup_glyph_by_stdcharcode, t2_operator_seac): Added these functions for use in implementing the seac emulation provided by the Type 2 endchar operator. (T2_Parse_CharStrings): Added seac emulation for the endchar operator. CFF_Done_Encoding, CFF_Done_Charset): Extended to load and parse the charset/encoding tables, and free the memory used by them when the CFF driver is finished with them. Added tables
This commit is contained in:
parent
e39266ab7c
commit
6b76663625
19
ChangeLog
19
ChangeLog
|
@ -1,3 +1,9 @@
|
|||
2000-12-30 Werner Lemberg <wl@gnu.org>
|
||||
|
||||
* src/cff/cffload.c (CFF_Load_Charset): Improved error messages.
|
||||
(CFF_Load_Charset, CFF_Load_Encoding): Remove unnecessary variable
|
||||
definition.
|
||||
|
||||
2000-12-30 Tom Kacvinsky <tjk@ams.org>
|
||||
|
||||
* include/freetype/internal/t2types.h,
|
||||
|
@ -5,15 +11,16 @@
|
|||
CFF_Encoding and CFF_Encoding for the new implementations of the
|
||||
charset and encoding parsers in the CFF driver.
|
||||
|
||||
* src/cff/t2gload.c (t2_lookup_glyph_by_stdcharcode, t2_operator_seac):
|
||||
Added these functions for use in implementing the seac emulation
|
||||
provided by the Type 2 endchar operator.
|
||||
(T2_Parse_CharStrings): Added seac emulation for the endchar operator.
|
||||
* src/cff/t2gload.c (t2_lookup_glyph_by_stdcharcode,
|
||||
t2_operator_seac): Added these functions for use in implementing the
|
||||
seac emulation provided by the Type 2 endchar operator.
|
||||
(T2_Parse_CharStrings): Added seac emulation for the endchar
|
||||
operator.
|
||||
|
||||
* src/cff/cffload.c (CFF_Load_Encoding, CFF_Load_Charset,
|
||||
CFF_Done_Encoding, CFF_Done_Charset): Extended to load and parse the
|
||||
charset/encoding tables, and free the memory used by them when the CFF
|
||||
driver is finished with them. Added tables
|
||||
charset/encoding tables, and free the memory used by them when the
|
||||
CFF driver is finished with them. Added tables
|
||||
|
||||
cff_isoadobe_charset
|
||||
cff_expert_charset
|
||||
|
|
|
@ -27,6 +27,7 @@
|
|||
#include FT_SOURCE_FILE(cff,cffload.h)
|
||||
#include FT_SOURCE_FILE(cff,cffparse.h)
|
||||
|
||||
|
||||
/*************************************************************************/
|
||||
/* */
|
||||
/* The macro FT_COMPONENT is used in trace mode. It is an implicit */
|
||||
|
@ -36,7 +37,9 @@
|
|||
#undef FT_COMPONENT
|
||||
#define FT_COMPONENT trace_t2load
|
||||
|
||||
static const FT_UShort cff_isoadobe_charset[229] =
|
||||
|
||||
static
|
||||
const FT_UShort cff_isoadobe_charset[229] =
|
||||
{
|
||||
0,
|
||||
1,
|
||||
|
@ -269,7 +272,8 @@
|
|||
228
|
||||
};
|
||||
|
||||
static const FT_UShort cff_expert_charset[166] =
|
||||
static
|
||||
const FT_UShort cff_expert_charset[166] =
|
||||
{
|
||||
0,
|
||||
1,
|
||||
|
@ -439,7 +443,8 @@
|
|||
378
|
||||
};
|
||||
|
||||
static const FT_UShort cff_expertsubset_charset[87] =
|
||||
static
|
||||
const FT_UShort cff_expertsubset_charset[87] =
|
||||
{
|
||||
0,
|
||||
1,
|
||||
|
@ -530,7 +535,8 @@
|
|||
346
|
||||
};
|
||||
|
||||
static const FT_UShort cff_standard_encoding[256] =
|
||||
static
|
||||
const FT_UShort cff_standard_encoding[256] =
|
||||
{
|
||||
0,
|
||||
0,
|
||||
|
@ -790,8 +796,8 @@
|
|||
0
|
||||
};
|
||||
|
||||
|
||||
static const FT_UShort cff_expert_encoding[256] =
|
||||
static
|
||||
const FT_UShort cff_expert_encoding[256] =
|
||||
{
|
||||
0,
|
||||
0,
|
||||
|
@ -1492,12 +1498,14 @@
|
|||
{
|
||||
FT_Memory memory = stream->memory;
|
||||
|
||||
|
||||
FREE( charset->sids );
|
||||
charset->format = 0;
|
||||
charset->offset = 0;
|
||||
charset->sids = 0;
|
||||
}
|
||||
|
||||
|
||||
static
|
||||
FT_Error CFF_Load_Charset( CFF_Charset* charset,
|
||||
FT_UInt num_glyphs,
|
||||
|
@ -1509,6 +1517,7 @@
|
|||
FT_Error error = 0;
|
||||
FT_UShort glyph_sid;
|
||||
|
||||
|
||||
charset->offset = base_offset + offset;
|
||||
|
||||
/* Get the format of the table. */
|
||||
|
@ -1522,8 +1531,9 @@
|
|||
{
|
||||
FT_UInt j;
|
||||
|
||||
|
||||
/* Allocate memory for sids. */
|
||||
if ( ALLOC( charset->sids, num_glyphs * sizeof( FT_UShort ) ) )
|
||||
if ( ALLOC( charset->sids, num_glyphs * sizeof ( FT_UShort ) ) )
|
||||
goto Exit;
|
||||
|
||||
/* assign the .notdef glyph */
|
||||
|
@ -1532,7 +1542,6 @@
|
|||
switch ( charset->format )
|
||||
{
|
||||
case 0:
|
||||
|
||||
for ( j = 1; j < num_glyphs; j++ )
|
||||
{
|
||||
if ( READ_UShort( glyph_sid ) )
|
||||
|
@ -1548,6 +1557,7 @@
|
|||
FT_UInt nleft;
|
||||
FT_UInt i;
|
||||
|
||||
|
||||
j = 1;
|
||||
|
||||
while ( j < num_glyphs )
|
||||
|
@ -1572,7 +1582,6 @@
|
|||
/* Fill in the range of sids -- `nleft + 1' glyphs. */
|
||||
for ( i = 0; i <= nleft; i++, j++, glyph_sid++ )
|
||||
charset->sids[j] = glyph_sid;
|
||||
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
@ -1582,85 +1591,80 @@
|
|||
error = FT_Err_Invalid_File_Format;
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
/* Parse default tables corresponding to offset == 0, 1, or 2. */
|
||||
/* CFF specification intimates the following: */
|
||||
/* */
|
||||
/* In order to use a predefined charset, the following must be */
|
||||
/* true: the charset constructed for the glyphs in the font's */
|
||||
/* true: The charset constructed for the glyphs in the font's */
|
||||
/* charstrings dictionary must match the predefined charset in */
|
||||
/* the first num_glyphs, and hence must match the predefined */
|
||||
/* charset *exactly*. */
|
||||
|
||||
switch ( offset )
|
||||
{
|
||||
|
||||
case 0:
|
||||
|
||||
if ( num_glyphs != 229 )
|
||||
{
|
||||
FT_ERROR(("CFF_Load_Charset: implicit charset not equal to predefined charset!\n" ));
|
||||
FT_ERROR(("CFF_Load_Charset: implicit charset not equal to\n"
|
||||
"predefined charset (Adobe ISO-Latin)!\n" ));
|
||||
error = FT_Err_Invalid_File_Format;
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* Allocate memory for sids. */
|
||||
if ( ALLOC( charset->sids, num_glyphs * sizeof( FT_UShort ) ) )
|
||||
if ( ALLOC( charset->sids, num_glyphs * sizeof ( FT_UShort ) ) )
|
||||
goto Exit;
|
||||
|
||||
/* Copy the predefined charset into the allocated memory. */
|
||||
MEM_Copy( charset->sids, cff_isoadobe_charset,
|
||||
num_glyphs * sizeof( FT_UShort ) );
|
||||
num_glyphs * sizeof ( FT_UShort ) );
|
||||
|
||||
break;
|
||||
|
||||
case 1:
|
||||
|
||||
if ( num_glyphs != 166 )
|
||||
{
|
||||
FT_ERROR(( "CFF_Load_Charset: implicit charset not equal to predefined charset!\n" ));
|
||||
FT_ERROR(( "CFF_Load_Charset: implicit charset not equal to\n"
|
||||
"predefined charset (Adobe Expert)!\n" ));
|
||||
error = FT_Err_Invalid_File_Format;
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* Allocate memory for sids. */
|
||||
if ( ALLOC( charset->sids, num_glyphs * sizeof( FT_UShort ) ) )
|
||||
if ( ALLOC( charset->sids, num_glyphs * sizeof ( FT_UShort ) ) )
|
||||
goto Exit;
|
||||
|
||||
/* Copy the predefined charset into the allocated memory. */
|
||||
MEM_Copy( charset->sids, cff_expert_charset,
|
||||
num_glyphs * sizeof( FT_UShort ) );
|
||||
num_glyphs * sizeof ( FT_UShort ) );
|
||||
|
||||
break;
|
||||
|
||||
case 2:
|
||||
|
||||
if ( num_glyphs != 87 )
|
||||
{
|
||||
FT_ERROR(( "CFF_Load_Charset: implicit charset not equal to predefined charset!\n" ));
|
||||
FT_ERROR(( "CFF_Load_Charset: implicit charset not equal to\n"
|
||||
"predefined charset (Adobe Expert Subset)!\n" ));
|
||||
error = FT_Err_Invalid_File_Format;
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* Allocate memory for sids. */
|
||||
if ( ALLOC( charset->sids, num_glyphs * sizeof( FT_UShort ) ) )
|
||||
if ( ALLOC( charset->sids, num_glyphs * sizeof ( FT_UShort ) ) )
|
||||
goto Exit;
|
||||
|
||||
/* Copy the predefined charset into the allocated memory. */
|
||||
MEM_Copy( charset->sids, cff_expertsubset_charset,
|
||||
num_glyphs * sizeof( FT_UShort ) );
|
||||
num_glyphs * sizeof ( FT_UShort ) );
|
||||
|
||||
break;
|
||||
|
||||
default:
|
||||
|
||||
error = FT_Err_Invalid_File_Format;
|
||||
goto Exit;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1670,8 +1674,6 @@
|
|||
if ( error )
|
||||
if ( charset->sids )
|
||||
{
|
||||
FT_Memory memory = stream->memory;
|
||||
|
||||
if ( charset->sids )
|
||||
FREE( charset->sids );
|
||||
charset->format = 0;
|
||||
|
@ -1682,6 +1684,7 @@
|
|||
return error;
|
||||
}
|
||||
|
||||
|
||||
static
|
||||
FT_Error CFF_Load_Encoding( CFF_Encoding* encoding,
|
||||
CFF_Charset* charset,
|
||||
|
@ -1697,6 +1700,7 @@
|
|||
FT_UShort glyph_sid;
|
||||
FT_Byte glyph_code;
|
||||
|
||||
|
||||
/* Check for charset->sids. If we do not have this, we fail. */
|
||||
if ( !charset->sids )
|
||||
{
|
||||
|
@ -1706,8 +1710,8 @@
|
|||
|
||||
/* Allocate memory for sids/codes -- there are at most 256 sids/codes */
|
||||
/* for an encoding. */
|
||||
if ( ALLOC( encoding->sids, 256 * sizeof( FT_UShort ) ) ||
|
||||
ALLOC( encoding->codes, 256 * sizeof( FT_UShort ) ) )
|
||||
if ( ALLOC( encoding->sids, 256 * sizeof ( FT_UShort ) ) ||
|
||||
ALLOC( encoding->codes, 256 * sizeof ( FT_UShort ) ) )
|
||||
goto Exit;
|
||||
|
||||
/* Zero out the code to gid/sid mappings. */
|
||||
|
@ -1717,7 +1721,7 @@
|
|||
encoding->codes[j] = 0;
|
||||
}
|
||||
|
||||
/* Note: the encoding table in a CFF font is indexed by glyph index, */
|
||||
/* Note: The encoding table in a CFF font is indexed by glyph index, */
|
||||
/* where the first encoded glyph index is 1. Hence, we read the char */
|
||||
/* code (`glyph_code') at index j and make the assignment: */
|
||||
/* */
|
||||
|
@ -1743,7 +1747,6 @@
|
|||
switch ( encoding->format & 0x7F )
|
||||
{
|
||||
case 0:
|
||||
|
||||
for ( j = 1; j <= count; j++ )
|
||||
{
|
||||
if ( READ_Byte( glyph_code ) )
|
||||
|
@ -1757,7 +1760,6 @@
|
|||
encoding->codes[glyph_code] = j;
|
||||
|
||||
/* Assign code to SID mapping. */
|
||||
|
||||
encoding->sids[glyph_code] = charset->sids[j];
|
||||
}
|
||||
|
||||
|
@ -1769,10 +1771,10 @@
|
|||
FT_Byte i = 1;
|
||||
FT_Byte k;
|
||||
|
||||
|
||||
/* Parse the Format1 ranges. */
|
||||
for ( j = 0; j < count; j++, i += nleft )
|
||||
{
|
||||
|
||||
/* Read the first glyph code of the range. */
|
||||
if ( READ_Byte( glyph_code ) )
|
||||
goto Exit;
|
||||
|
@ -1787,7 +1789,6 @@
|
|||
/* Fill in the range of codes/sids. */
|
||||
for ( k = i; k < nleft + i; k++, glyph_code++ )
|
||||
{
|
||||
|
||||
/* Make sure k is not too big. */
|
||||
if ( k > num_glyphs )
|
||||
goto Exit;
|
||||
|
@ -1797,15 +1798,13 @@
|
|||
|
||||
/* Assign code to SID mapping. */
|
||||
encoding->sids[glyph_code] = charset->sids[k];
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
default:
|
||||
FT_ERROR(( "CFF.Load_Encoding: invalid table format!\n" ));
|
||||
FT_ERROR(( "CFF_Load_Encoding: invalid table format!\n" ));
|
||||
error = FT_Err_Invalid_File_Format;
|
||||
goto Exit;
|
||||
}
|
||||
|
@ -1815,27 +1814,25 @@
|
|||
{
|
||||
FT_UInt glyph_id;
|
||||
|
||||
|
||||
/* count supplements */
|
||||
if ( READ_Byte( count ) )
|
||||
goto Exit;
|
||||
|
||||
for ( j = 0; j < count; j++ )
|
||||
{
|
||||
|
||||
/* Read supplemental glyph code. */
|
||||
if ( READ_Byte( glyph_code ) )
|
||||
goto Exit;
|
||||
|
||||
/* Read the SID associated with this glyph code */
|
||||
/* Read the SID associated with this glyph code. */
|
||||
if ( READ_UShort( glyph_sid ) )
|
||||
goto Exit;
|
||||
|
||||
/* Assign code to SID mapping. */
|
||||
encoding->sids[glyph_code] = glyph_sid;
|
||||
|
||||
/* Assign code to GID mapping. */
|
||||
|
||||
/* First, lookup GID which has been assigned */
|
||||
/* First, lookup GID which has been assigned to */
|
||||
/* SID glyph_sid. */
|
||||
for ( glyph_id = 0; glyph_id < num_glyphs; glyph_id++ )
|
||||
{
|
||||
|
@ -1845,15 +1842,14 @@
|
|||
|
||||
/* Now, make the assignment. */
|
||||
encoding->codes[glyph_code] = glyph_id;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
FT_UInt i;
|
||||
|
||||
|
||||
/* We take into account the fact a CFF font can use a predefined */
|
||||
/* encoding without containing all of the glyphs encoded by this */
|
||||
/* encoding (see the note at the end of section 12 in the CFF */
|
||||
|
@ -1861,12 +1857,10 @@
|
|||
|
||||
switch ( offset )
|
||||
{
|
||||
|
||||
case 0:
|
||||
|
||||
/* First, copy the code to SID mapping. */
|
||||
MEM_Copy( encoding->sids, cff_standard_encoding,
|
||||
256 * sizeof( FT_UShort ) );
|
||||
256 * sizeof ( FT_UShort ) );
|
||||
|
||||
/* Construct code to GID mapping from code */
|
||||
/* to SID mapping and charset. */
|
||||
|
@ -1875,7 +1869,6 @@
|
|||
/* If j is encoded, find the GID for it. */
|
||||
if ( encoding->sids[j] )
|
||||
{
|
||||
|
||||
for ( i = 1; i < num_glyphs; i++ )
|
||||
/* We matched, so break. */
|
||||
if ( charset->sids[i] == encoding->sids[j] )
|
||||
|
@ -1893,14 +1886,12 @@
|
|||
encoding->codes[j] = i;
|
||||
}
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
case 1:
|
||||
|
||||
/* First, copy the code to SID mapping. */
|
||||
MEM_Copy( encoding->sids, cff_expert_encoding,
|
||||
256 * sizeof( FT_UShort ) );
|
||||
256 * sizeof ( FT_UShort ) );
|
||||
|
||||
/* Construct code to GID mapping from code to SID mapping */
|
||||
/* and charset. */
|
||||
|
@ -1909,7 +1900,6 @@
|
|||
/* If j is encoded, find the GID for it. */
|
||||
if ( encoding->sids[j] )
|
||||
{
|
||||
|
||||
for ( i = 1; i < num_glyphs; i++ )
|
||||
/* We matched, so break. */
|
||||
if ( charset->sids[i] == encoding->sids[j] )
|
||||
|
@ -1927,15 +1917,13 @@
|
|||
encoding->codes[j] = i;
|
||||
}
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
default:
|
||||
FT_ERROR(( "CFF.Load_Encoding: invalid table format!\n" ));
|
||||
FT_ERROR(( "CFF_Load_Encoding: invalid table format!\n" ));
|
||||
error = FT_Err_Invalid_File_Format;
|
||||
goto Exit;
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1946,8 +1934,6 @@
|
|||
{
|
||||
if ( encoding->sids || encoding->codes )
|
||||
{
|
||||
FT_Memory memory = stream->memory;
|
||||
|
||||
if ( encoding->sids )
|
||||
FREE( encoding->sids );
|
||||
|
||||
|
@ -1961,7 +1947,6 @@
|
|||
}
|
||||
|
||||
return error;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
@ -2231,8 +2216,12 @@
|
|||
if ( error )
|
||||
goto Exit;
|
||||
|
||||
error = CFF_Load_Encoding( &font->encoding, &font->charset, font->num_glyphs,
|
||||
stream, base_offset, dict->encoding_offset );
|
||||
error = CFF_Load_Encoding( &font->encoding,
|
||||
&font->charset,
|
||||
font->num_glyphs,
|
||||
stream,
|
||||
base_offset,
|
||||
dict->encoding_offset );
|
||||
if ( error )
|
||||
goto Exit;
|
||||
|
||||
|
|
|
@ -310,6 +310,7 @@
|
|||
FT_Error error;
|
||||
FT_Fixed temp;
|
||||
|
||||
|
||||
error = T2_Err_Stack_Underflow;
|
||||
|
||||
if ( parser->top >= parser->stack + 6 )
|
||||
|
|
|
@ -513,6 +513,7 @@
|
|||
outline->contours[outline->n_contours - 1] = outline->n_points - 1;
|
||||
}
|
||||
|
||||
|
||||
static
|
||||
FT_Int t2_lookup_glyph_by_stdcharcode( CFF_Font* cff,
|
||||
FT_Int charcode )
|
||||
|
@ -520,6 +521,7 @@
|
|||
FT_UInt n;
|
||||
FT_UShort glyph_sid;
|
||||
|
||||
|
||||
/* check range of standard char code */
|
||||
if ( charcode < 0 || charcode > 255 )
|
||||
return -1;
|
||||
|
@ -530,7 +532,6 @@
|
|||
|
||||
for ( n = 0; n < cff->num_glyphs; n++ )
|
||||
{
|
||||
|
||||
if ( cff->charset.sids[n] == glyph_sid )
|
||||
return n;
|
||||
}
|
||||
|
@ -538,6 +539,7 @@
|
|||
return -1;
|
||||
}
|
||||
|
||||
|
||||
static
|
||||
FT_Error t2_operator_seac( T2_Decoder* decoder,
|
||||
FT_Pos adx,
|
||||
|
@ -554,6 +556,7 @@
|
|||
FT_Byte* charstring;
|
||||
FT_ULong charstring_len;
|
||||
|
||||
|
||||
bchar_index = t2_lookup_glyph_by_stdcharcode( cff, bchar );
|
||||
achar_index = t2_lookup_glyph_by_stdcharcode( cff, achar );
|
||||
|
||||
|
@ -564,7 +567,7 @@
|
|||
return T2_Err_Syntax_Error;
|
||||
}
|
||||
|
||||
/* if we are trying to load a composite glyph, do not load the */
|
||||
/* If we are trying to load a composite glyph, do not load the */
|
||||
/* accent character and return the array of subglyphs. */
|
||||
if ( decoder->builder.no_recurse )
|
||||
{
|
||||
|
@ -607,7 +610,6 @@
|
|||
&charstring, &charstring_len );
|
||||
if ( !error )
|
||||
{
|
||||
|
||||
error = T2_Parse_CharStrings( decoder, charstring, charstring_len );
|
||||
|
||||
if ( error )
|
||||
|
@ -618,7 +620,7 @@
|
|||
|
||||
n_base_points = base->n_points;
|
||||
|
||||
/* save the left bearing and width of the base character */
|
||||
/* Save the left bearing and width of the base character */
|
||||
/* as they will be erased by the next load. */
|
||||
|
||||
left_bearing = decoder->builder.left_bearing;
|
||||
|
@ -627,12 +629,11 @@
|
|||
decoder->builder.left_bearing.x = 0;
|
||||
decoder->builder.left_bearing.y = 0;
|
||||
|
||||
/* Now load `achar' on top of the base outline */
|
||||
/* Now load `achar' on top of the base outline. */
|
||||
error = CFF_Access_Element( &cff->charstrings_index, achar_index,
|
||||
&charstring, &charstring_len );
|
||||
if ( !error )
|
||||
{
|
||||
|
||||
error = T2_Parse_CharStrings( decoder, charstring, charstring_len );
|
||||
|
||||
if ( error )
|
||||
|
@ -641,15 +642,17 @@
|
|||
CFF_Forget_Element( &cff->charstrings_index, &charstring );
|
||||
}
|
||||
|
||||
/* restore the left side bearing and advance width of the base character */
|
||||
/* Restore the left side bearing and advance width */
|
||||
/* of the base character. */
|
||||
decoder->builder.left_bearing = left_bearing;
|
||||
decoder->builder.advance = advance;
|
||||
|
||||
/* Finally, move the accent */
|
||||
/* Finally, move the accent. */
|
||||
if ( decoder->builder.load_points )
|
||||
{
|
||||
FT_Outline dummy;
|
||||
|
||||
|
||||
dummy.n_points = base->n_points - n_base_points;
|
||||
dummy.points = base->points + n_base_points;
|
||||
|
||||
|
@ -1008,8 +1011,8 @@
|
|||
break;
|
||||
|
||||
case t2_op_endchar:
|
||||
/* If there is a width specified for endchar, we either have 1 */
|
||||
/* argument or 5 arguments. We like to argue. */
|
||||
/* If there is a width specified for endchar, we either have */
|
||||
/* 1 argument or 5 arguments. We like to argue. */
|
||||
set_width_ok = ( ( num_args == 5 ) || ( num_args == 1 ) );
|
||||
break;
|
||||
|
||||
|
@ -1579,9 +1582,8 @@
|
|||
FT_TRACE4(( " endchar" ));
|
||||
|
||||
/* We are going to emulate the seac operator. */
|
||||
if ( num_args == 4)
|
||||
if ( num_args == 4 )
|
||||
{
|
||||
|
||||
error = t2_operator_seac( decoder, args[0] >> 16, args[1] >> 16,
|
||||
args[2] >> 16, args[3] >> 16 );
|
||||
args += 4;
|
||||
|
@ -2099,6 +2101,7 @@
|
|||
FT_Matrix font_matrix;
|
||||
FT_Vector font_offset;
|
||||
|
||||
|
||||
if ( load_flags & FT_LOAD_NO_RECURSE )
|
||||
load_flags |= FT_LOAD_NO_SCALE | FT_LOAD_NO_HINTING;
|
||||
|
||||
|
@ -2151,13 +2154,13 @@
|
|||
/* bearing the yMax. */
|
||||
if ( !error )
|
||||
{
|
||||
|
||||
/* for composite glyphs, return only left side bearing and */
|
||||
/* advance width */
|
||||
/* For composite glyphs, return only left side bearing and */
|
||||
/* advance width. */
|
||||
if ( load_flags & FT_LOAD_NO_RECURSE )
|
||||
{
|
||||
FT_Slot_Internal internal = glyph->root.internal;
|
||||
|
||||
|
||||
glyph->root.metrics.horiBearingX = decoder.builder.left_bearing.x;
|
||||
glyph->root.metrics.horiAdvance = decoder.glyph_width;
|
||||
internal->glyph_matrix = font_matrix;
|
||||
|
|
Loading…
Reference in New Issue