diff --git a/ChangeLog b/ChangeLog index a06acb05c..a49b7e7de 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,9 +1,16 @@ +2005-08-02 Werner Lemberg + + * src/otvalid/otvcommn.h: Remove dead code. + 2005-07-31 Chia I Wu - * src/truetype/ttobjs.h (tt_size_run_fpgm, tt_size_run_prep): New functions. + * src/truetype/ttobjs.h (tt_size_run_fpgm, tt_size_run_prep): New + functions. - * src/truetype/ttobjs.c (tt_size_run_fpgm, tt_size_run_prep): New functions. - (tt_size_init): Add 4, instead of 2, (phantom) points to twilight zone. + * src/truetype/ttobjs.c (tt_size_run_fpgm, tt_size_run_prep): New + functions. + (tt_size_init): Add 4, instead of 2, (phantom) points to twilight + zone. Move code that runs fpgm to tt_size_run_fpgm. (Reset_Outline_Size): Move code that runs prep to tt_size_run_prep. (tt_glyphzone_new): Allocate right size of arrays. @@ -29,14 +36,27 @@ 2005-06-30 David Turner - * src/sfnt/ftbitmap.c, src/truetype/ttgload.c, src/sfnt/ttcmap.c: - removing compiler warnings (Visual C++ /W4) + * src/sfnt/ftbitmap.c, src/truetype/ttgload.c, src/sfnt/ttcmap.c: + Removing compiler warnings (Visual C++ /W4). - * Jamfile, src/otvalid/{otvcommn.h,otvgdef.c,otvgpos.c,otvgsub.c, - otvjstf.c}: modified the code to use a different pre-processor trick - to implement the OTV_NEST1, OTV_NEST2 and OTV_NEST3 macros. The code - now compiles neatly with Visual C++. The 'otvalid' module has been - put in the Jamfile build again. + + Implement a work-around for broken C preprocessor in Visual C++ (it + has been confirmed by the MS developers that it is indeed a bug + which won't be fixed in the very near future). + + * Jamfile (FT2_COMPONENTS): Include otvalid (again). + + * src/otvalid/otvcommn.h (OTV_NAME, OTV_FUNC): New macros. + (OTV_NEST1, OTV_NEST2, OTV_NEST3): Use OTV_NAME and OTV_FUNC to + avoid argument expansion by argument prescan. + Append `Func' to all affected macros and change them to take just a + single argument. Example: `AttachList' is renamed to + `AttachListFunc'. + + * src/otvalid/otvgdef.c, src/otvalid/otvgpos.c, + src/otvalid/otvgsub.c, src/otvjstf.c: Append `Func' to macros + affected by the changes to OTV_NESTx and modify them to take just a + single argument. 2005-06-20 Chia I Wu diff --git a/src/otvalid/otvcommn.h b/src/otvalid/otvcommn.h index 78087987b..be6ac69c2 100644 --- a/src/otvalid/otvcommn.h +++ b/src/otvalid/otvcommn.h @@ -117,34 +117,31 @@ FT_BEGIN_HEADER #ifdef FT_DEBUG_LEVEL_TRACE - /* use preprocessor's argument prescan to expand one argument into two */ #define OTV_NEST1( x ) \ FT_BEGIN_STMNT \ valid->nesting_level = 0; \ - valid->func[0] = OTV_FUNC(x); \ - valid->debug_function_name[0] = OTV_NAME(x); \ + valid->func[0] = OTV_FUNC( x ); \ + valid->debug_function_name[0] = OTV_NAME( x ); \ FT_END_STMNT - /* use preprocessor's argument prescan to expand two arguments into four */ -#define OTV_NEST2( x, y ) \ - FT_BEGIN_STMNT \ - valid->nesting_level = 0; \ - valid->func[0] = OTV_FUNC(x); \ - valid->func[1] = OTV_FUNC(y); \ - valid->debug_function_name[0] = OTV_NAME(x); \ - valid->debug_function_name[1] = OTV_NAME(y); \ +#define OTV_NEST2( x, y ) \ + FT_BEGIN_STMNT \ + valid->nesting_level = 0; \ + valid->func[0] = OTV_FUNC( x ); \ + valid->func[1] = OTV_FUNC( y ); \ + valid->debug_function_name[0] = OTV_NAME( x ); \ + valid->debug_function_name[1] = OTV_NAME( y ); \ FT_END_STMNT - /* use preprocessor's argument prescan to expand three arguments into six */ -#define OTV_NEST3( x, y, z ) \ - FT_BEGIN_STMNT \ - valid->nesting_level = 0; \ - valid->func[0] = OTV_FUNC(x); \ - valid->func[1] = OTV_FUNC(y); \ - valid->func[2] = OTV_FUNC(z); \ - valid->debug_function_name[0] = OTV_NAME(x); \ - valid->debug_function_name[1] = OTV_NAME(y); \ - valid->debug_function_name[2] = OTV_NAME(z); \ +#define OTV_NEST3( x, y, z ) \ + FT_BEGIN_STMNT \ + valid->nesting_level = 0; \ + valid->func[0] = OTV_FUNC( x ); \ + valid->func[1] = OTV_FUNC( y ); \ + valid->func[2] = OTV_FUNC( z ); \ + valid->debug_function_name[0] = OTV_NAME( x ); \ + valid->debug_function_name[1] = OTV_NAME( y ); \ + valid->debug_function_name[2] = OTV_NAME( z ); \ FT_END_STMNT #define OTV_INIT valid->debug_indent = 0 @@ -174,28 +171,25 @@ FT_BEGIN_HEADER #else /* !FT_DEBUG_LEVEL_TRACE */ - /* use preprocessor's argument prescan to expand one argument into two */ -#define OTV_NEST1( x ) \ - FT_BEGIN_STMNT \ - valid->nesting_level = 0; \ - valid->func[0] = OTV_FUNC(x); \ +#define OTV_NEST1( x ) \ + FT_BEGIN_STMNT \ + valid->nesting_level = 0; \ + valid->func[0] = OTV_FUNC( x ); \ FT_END_STMNT - /* use preprocessor's argument prescan to expand two arguments into four */ -#define OTV_NEST2( x, y ) \ - FT_BEGIN_STMNT \ - valid->nesting_level = 0; \ - valid->func[0] = OTV_FUNC(x); \ - valid->func[1] = OTV_FUNC(y); \ +#define OTV_NEST2( x, y ) \ + FT_BEGIN_STMNT \ + valid->nesting_level = 0; \ + valid->func[0] = OTV_FUNC( x ); \ + valid->func[1] = OTV_FUNC( y ); \ FT_END_STMNT - /* use preprocessor's argument prescan to expand three arguments into six */ -#define OTV_NEST3( x, y, z ) \ - FT_BEGIN_STMNT \ - valid->nesting_level = 0; \ - valid->func[0] = OTV_FUNC(x); \ - valid->func[1] = OTV_FUNC(y); \ - valid->func[2] = OTV_FUNC(z); \ +#define OTV_NEST3( x, y, z ) \ + FT_BEGIN_STMNT \ + valid->nesting_level = 0; \ + valid->func[0] = OTV_FUNC( x ); \ + valid->func[1] = OTV_FUNC( y ); \ + valid->func[2] = OTV_FUNC( z ); \ FT_END_STMNT #define OTV_INIT do ; while ( 0 ) @@ -338,22 +332,6 @@ FT_BEGIN_HEADER /*************************************************************************/ /*************************************************************************/ -#if 0 -#define ChainPosClassSet otv_x_Ox, "ChainPosClassSet" -#define ChainPosRuleSet otv_x_Ox, "ChainPosRuleSet" -#define ChainSubClassSet otv_x_Ox, "ChainSubClassSet" -#define ChainSubRuleSet otv_x_Ox, "ChainSubRuleSet" -#define JstfLangSys otv_x_Ox, "JstfLangSys" -#define JstfMax otv_x_Ox, "JstfMax" -#define LigGlyph otv_x_Ox, "LigGlyph" -#define LigatureArray otv_x_Ox, "LigatureArray" -#define LigatureSet otv_x_Ox, "LigatureSet" -#define PosClassSet otv_x_Ox, "PosClassSet" -#define PosRuleSet otv_x_Ox, "PosRuleSet" -#define SubClassSet otv_x_Ox, "SubClassSet" -#define SubRuleSet otv_x_Ox, "SubRuleSet" -#endif - #define ChainPosClassSetFunc otv_x_Ox #define ChainPosRuleSetFunc otv_x_Ox #define ChainSubClassSetFunc otv_x_Ox @@ -372,16 +350,6 @@ FT_BEGIN_HEADER otv_x_Ox ( FT_Bytes table, OTV_Validator valid ); -#if 0 -#define AlternateSubstFormat1 otv_u_C_x_Ox, "AlternateSubstFormat1" -#define ChainContextPosFormat1 otv_u_C_x_Ox, "ChainContextPosFormat1" -#define ChainContextSubstFormat1 otv_u_C_x_Ox, "ChainContextSubstFormat1" -#define ContextPosFormat1 otv_u_C_x_Ox, "ContextPosFormat1" -#define ContextSubstFormat1 otv_u_C_x_Ox, "ContextSubstFormat1" -#define LigatureSubstFormat1 otv_u_C_x_Ox, "LigatureSubstFormat1" -#define MultipleSubstFormat1 otv_u_C_x_Ox, "MultipleSubstFormat1" -#endif - #define AlternateSubstFormat1Func otv_u_C_x_Ox #define ChainContextPosFormat1Func otv_u_C_x_Ox #define ChainContextSubstFormat1Func otv_u_C_x_Ox @@ -390,19 +358,10 @@ FT_BEGIN_HEADER #define LigatureSubstFormat1Func otv_u_C_x_Ox #define MultipleSubstFormat1Func otv_u_C_x_Ox - FT_LOCAL( void ) otv_u_C_x_Ox( FT_Bytes table, OTV_Validator valid ); -#if 0 -#define AlternateSet otv_x_ux, "AlternateSet" -#define AttachPoint otv_x_ux, "AttachPoint" -#define ExtenderGlyph otv_x_ux, "ExtenderGlyph" -#define JstfGPOSModList otv_x_ux, "JstfGPOSModList" -#define JstfGSUBModList otv_x_ux, "JstfGSUBModList" -#define Sequence otv_x_ux, "Sequence" -#endif #define AlternateSetFunc otv_x_ux #define AttachPointFunc otv_x_ux #define ExtenderGlyphFunc otv_x_ux @@ -414,13 +373,6 @@ FT_BEGIN_HEADER otv_x_ux( FT_Bytes table, OTV_Validator valid ); -#if 0 -#define PosClassRule otv_x_y_ux_sy, "PosClassRule" -#define PosRule otv_x_y_ux_sy, "PosRule" -#define SubClassRule otv_x_y_ux_sy, "SubClassRule" -#define SubRule otv_x_y_ux_sy, "SubRule" -#endif - #define PosClassRuleFunc otv_x_y_ux_sy #define PosRuleFunc otv_x_y_ux_sy #define SubClassRuleFunc otv_x_y_ux_sy @@ -430,13 +382,6 @@ FT_BEGIN_HEADER otv_x_y_ux_sy( FT_Bytes table, OTV_Validator valid ); -#if 0 -#define ChainPosClassRule otv_x_ux_y_uy_z_uz_p_sp, "ChainPosClassRule" -#define ChainPosRule otv_x_ux_y_uy_z_uz_p_sp, "ChainPosRule" -#define ChainSubClassRule otv_x_ux_y_uy_z_uz_p_sp, "ChainSubClassRule" -#define ChainSubRule otv_x_ux_y_uy_z_uz_p_sp, "ChainSubRule" -#endif - #define ChainPosClassRuleFunc otv_x_ux_y_uy_z_uz_p_sp #define ChainPosRuleFunc otv_x_ux_y_uy_z_uz_p_sp #define ChainSubClassRuleFunc otv_x_ux_y_uy_z_uz_p_sp @@ -446,11 +391,6 @@ FT_BEGIN_HEADER otv_x_ux_y_uy_z_uz_p_sp( FT_Bytes table, OTV_Validator valid ); -#if 0 -#define ContextPosFormat2 otv_u_O_O_x_Onx, "ContextPosFormat2" -#define ContextSubstFormat2 otv_u_O_O_x_Onx, "ContextSubstFormat2" -#endif - #define ContextPosFormat2Func otv_u_O_O_x_Onx #define ContextSubstFormat2Func otv_u_O_O_x_Onx @@ -458,11 +398,6 @@ FT_BEGIN_HEADER otv_u_O_O_x_Onx( FT_Bytes table, OTV_Validator valid ); -#if 0 -#define ContextPosFormat3 otv_u_x_y_Ox_sy, "ContextPosFormat3" -#define ContextSubstFormat3 otv_u_x_y_Ox_sy, "ContextSubstFormat3" -#endif - #define ContextPosFormat3Func otv_u_x_y_Ox_sy #define ContextSubstFormat3Func otv_u_x_y_Ox_sy @@ -470,11 +405,6 @@ FT_BEGIN_HEADER otv_u_x_y_Ox_sy( FT_Bytes table, OTV_Validator valid ); -#if 0 -#define ChainContextPosFormat2 otv_u_O_O_O_O_x_Onx, "ChainContextPosFormat2" -#define ChainContextSubstFormat2 otv_u_O_O_O_O_x_Onx, "ChainContextSubstFormat2" -#endif - #define ChainContextPosFormat2Func otv_u_O_O_O_O_x_Onx #define ChainContextSubstFormat2Func otv_u_O_O_O_O_x_Onx @@ -482,11 +412,6 @@ FT_BEGIN_HEADER otv_u_O_O_O_O_x_Onx( FT_Bytes table, OTV_Validator valid ); -#if 0 -#define ChainContextPosFormat3 otv_u_x_Ox_y_Oy_z_Oz_p_sp, "ChainContextPosFormat3" -#define ChainContextSubstFormat3 otv_u_x_Ox_y_Oy_z_Oz_p_sp, "ChainContextSubstFormat3" -#endif - #define ChainContextPosFormat3Func otv_u_x_Ox_y_Oy_z_Oz_p_sp #define ChainContextSubstFormat3Func otv_u_x_Ox_y_Oy_z_Oz_p_sp diff --git a/src/otvalid/otvgdef.c b/src/otvalid/otvgdef.c index 60f75f51c..7d24902e8 100644 --- a/src/otvalid/otvgdef.c +++ b/src/otvalid/otvgdef.c @@ -88,7 +88,7 @@ /*************************************************************************/ /*************************************************************************/ -#define CaretValueFunc otv_CaretValue_validate +#define CaretValueFunc otv_CaretValue_validate static void otv_CaretValue_validate( FT_Bytes table, diff --git a/src/otvalid/otvgpos.c b/src/otvalid/otvgpos.c index a93a00786..b6bd6ed5f 100644 --- a/src/otvalid/otvgpos.c +++ b/src/otvalid/otvgpos.c @@ -861,7 +861,8 @@ /* context rules since even invalid glyph indices/classes return */ /* meaningful results */ - OTV_NEST3( ChainContextPosFormat2,ChainPosClassSet, ChainPosClassRule ); + OTV_NEST3( ChainContextPosFormat2, + ChainPosClassSet, ChainPosClassRule ); OTV_RUN( table, valid ); break; diff --git a/src/truetype/ttdriver.c b/src/truetype/ttdriver.c index 100e0dbdc..1511e260f 100644 --- a/src/truetype/ttdriver.c +++ b/src/truetype/ttdriver.c @@ -176,18 +176,19 @@ *metrics = size->root.metrics; /* This bit flag, when set, indicates that the pixel size must be */ - /* rounded to integer. Nearly all TrueType fonts have this bit */ + /* rounded to integer. Nearly all TrueType fonts have this bit */ /* set, as hinting won't work really well otherwise. */ /* */ if ( ( face->header.Flags & 8 ) != 0 ) { FT_Long dim_x, dim_y; + dim_x = ( char_width * horz_resolution + 36 ) / 72; dim_y = ( char_height * vert_resolution + 36 ) / 72; - dim_x = FT_PIX_ROUND(dim_x); - dim_y = FT_PIX_ROUND(dim_y); + dim_x = FT_PIX_ROUND( dim_x ); + dim_y = FT_PIX_ROUND( dim_y ); metrics->x_ppem = (FT_UShort)( dim_x >> 6 ); metrics->y_ppem = (FT_UShort)( dim_y >> 6 ); diff --git a/src/truetype/ttgload.c b/src/truetype/ttgload.c index 1c4bd2ef7..265595881 100644 --- a/src/truetype/ttgload.c +++ b/src/truetype/ttgload.c @@ -1778,8 +1778,8 @@ if ( face->os2.version != 0xFFFFU ) { /* sTypoDescender is negative */ - max_height = (FT_Short)(face->os2.sTypoAscender - - face->os2.sTypoDescender); + max_height = (FT_Short)(face->os2.sTypoAscender - + face->os2.sTypoDescender); top_bearing = (FT_Short)( ( max_height - height ) / 2 ); advance_height = (FT_UShort)( max_height + face->os2.sTypoLineGap ); diff --git a/src/truetype/ttobjs.c b/src/truetype/ttobjs.c index 540b4e3a1..4ad407244 100644 --- a/src/truetype/ttobjs.c +++ b/src/truetype/ttobjs.c @@ -133,7 +133,7 @@ } else { - zone->max_points = maxPoints; + zone->max_points = maxPoints; zone->max_contours = maxContours; } @@ -321,13 +321,14 @@ /*************************************************************************/ #ifdef TT_CONFIG_OPTION_BYTECODE_INTERPRETER + /*************************************************************************/ /* */ /* */ /* tt_size_run_fpgm */ /* */ /* */ - /* Run the font program */ + /* Run the font program. */ /* */ /* */ /* size :: A handle to the size object. */ @@ -415,7 +416,7 @@ /* tt_size_run_prep */ /* */ /* */ - /* Run the control value program */ + /* Run the control value program. */ /* */ /* */ /* size :: A handle to the size object. */ @@ -474,6 +475,7 @@ return error; } + #endif /* TT_CONFIG_OPTION_BYTECODE_INTERPRETER */ @@ -496,7 +498,9 @@ { TT_Size size = (TT_Size)ttsize; FT_Error error = TT_Err_Ok; + #ifdef TT_CONFIG_OPTION_BYTECODE_INTERPRETER + TT_Face face = (TT_Face)size->root.face; FT_Memory memory = face->root.memory; FT_Int i; @@ -605,7 +609,9 @@ tt_size_done( FT_Size ttsize ) /* TT_Size */ { TT_Size size = (TT_Size)ttsize; + #ifdef TT_CONFIG_OPTION_BYTECODE_INTERPRETER + FT_Memory memory = size->root.face->memory; @@ -712,6 +718,7 @@ #endif #ifdef TT_CONFIG_OPTION_BYTECODE_INTERPRETER + { FT_UInt i; @@ -738,6 +745,7 @@ error = tt_size_run_prep( size ); } + #endif /* TT_CONFIG_OPTION_BYTECODE_INTERPRETER */ if ( !error ) diff --git a/src/truetype/ttobjs.h b/src/truetype/ttobjs.h index b289d01ff..c33c1475f 100644 --- a/src/truetype/ttobjs.h +++ b/src/truetype/ttobjs.h @@ -4,7 +4,7 @@ /* */ /* Objects manager (specification). */ /* */ -/* Copyright 1996-2001, 2002, 2003, 2004 by */ +/* Copyright 1996-2001, 2002, 2003, 2004, 2005 by */ /* David Turner, Robert Wilhelm, and Werner Lemberg. */ /* */ /* This file is part of the FreeType project, and may only be used, */ @@ -418,11 +418,13 @@ FT_BEGIN_HEADER tt_size_done( FT_Size ttsize ); /* TT_Size */ #ifdef TT_CONFIG_OPTION_BYTECODE_INTERPRETER + FT_LOCAL( FT_Error ) tt_size_run_fpgm( TT_Size size ); FT_LOCAL( FT_Error ) tt_size_run_prep( TT_Size size ); + #endif /* TT_CONFIG_OPTION_BYTECODE_INTERPRETER */ FT_LOCAL( FT_Error )