From ac079164bd49df8e7ddd42772d2dc9113978acdd Mon Sep 17 00:00:00 2001 From: suzuki toshiya Date: Fri, 3 Jul 2009 18:01:41 +0900 Subject: [PATCH] cff: Type large constants > 0x7FFF as long for 16-bit systems. --- ChangeLog | 9 +++++++++ src/cff/cffload.c | 8 ++++---- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/ChangeLog b/ChangeLog index 8ab1d35b9..3ec73c697 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +2009-07-03 suzuki toshiya + + cff: Type large constants > 0x7FFF as long for 16-bit systems. + + * src/cff/cffload.c (cff_charset_load): Type large + constants > 0x7FFF as long, because normal constants + are typed signed integer that is less than 0x8000 on + 16-bit systems. + 2009-07-03 suzuki toshiya base: Remove an unused variable. diff --git a/src/cff/cffload.c b/src/cff/cffload.c index 1675ee4e5..f66d4e1a8 100644 --- a/src/cff/cffload.c +++ b/src/cff/cffload.c @@ -847,7 +847,7 @@ /* this constant is given in the CFF specification */ - if ( sid < 65000 ) + if ( sid < 65000L ) charset->sids[j] = sid; else { @@ -890,16 +890,16 @@ /* check whether the range contains at least one valid glyph; */ /* the constant is given in the CFF specification */ - if ( glyph_sid >= 65000 ) { + if ( glyph_sid >= 65000L ) { FT_ERROR(( "cff_charset_load: invalid SID range\n" )); error = CFF_Err_Invalid_File_Format; goto Exit; } /* try to rescue some of the SIDs if `nleft' is too large */ - if ( nleft > 65000 - 1 || glyph_sid >= 65000 - nleft ) { + if ( nleft > 65000L - 1L || glyph_sid >= 65000L - nleft ) { FT_ERROR(( "cff_charset_load: invalid SID range trimmed\n" )); - nleft = 65000 - 1 - glyph_sid; + nleft = ( FT_UInt )( 65000L - 1L - glyph_sid ); } /* Fill in the range of sids -- `nleft + 1' glyphs. */