From 056ecd0e5d06f5c3933b0bb72380264f6488dee5 Mon Sep 17 00:00:00 2001 From: Werner Lemberg Date: Sun, 12 May 2002 19:59:17 +0000 Subject: [PATCH] * src/sfnt/ttload.c (TT_LookUp_Table): Protect against tables with a zero length value. * builds/beos/beos.mk: Include `link-std.mk'. * src/type1/t1load.h (T1_Loader): Renamed to... (T1_LoaderRec): This. (T1_Loader): Now pointer to T1_LoaderRec. * src/type1/t1load.c: Updated. * include/freetype/internal/t1types.h, src/type1/t1load.c, src/type1/t1objs.c: s/T1_ENCODING_TYPE_EXPORT/T1_ENCODING_TYPE_EXPERT/. --- ChangeLog | 20 +++++ builds/beos/beos.mk | 3 +- include/freetype/internal/t1types.h | 2 +- src/sfnt/ttload.c | 4 +- src/type1/t1driver.c | 4 +- src/type1/t1load.c | 121 ++++++++++++++-------------- src/type1/t1load.h | 2 +- src/type1/t1objs.c | 29 ++++--- 8 files changed, 105 insertions(+), 80 deletions(-) diff --git a/ChangeLog b/ChangeLog index 5232288ea..0537d5b98 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,23 @@ +2002-05-12 Owen Taylor + + * src/sfnt/ttload.c (TT_LookUp_Table): Protect against tables + with a zero length value. + +2002-05-12 Michael Pfeiffer + + * builds/beos/beos.mk: Include `link-std.mk'. + +2002-05-12 Werner Lemberg + + * src/type1/t1load.h (T1_Loader): Renamed to... + (T1_LoaderRec): This. + (T1_Loader): Now pointer to T1_LoaderRec. + * src/type1/t1load.c: Updated. + + * include/freetype/internal/t1types.h, src/type1/t1load.c, + src/type1/t1objs.c: + s/T1_ENCODING_TYPE_EXPORT/T1_ENCODING_TYPE_EXPERT/. + 2002-05-06 Werner Lemberg * README: Add a note regarding libttf vs. libfreetype. diff --git a/builds/beos/beos.mk b/builds/beos/beos.mk index 956b96aab..9c0ff5f07 100644 --- a/builds/beos/beos.mk +++ b/builds/beos/beos.mk @@ -2,7 +2,7 @@ # FreeType 2 configuration rules for a BeOS system # -# Copyright 1996-2000 by +# Copyright 1996-2000, 2002 by # David Turner, Robert Wilhelm, and Werner Lemberg. # # This file is part of the FreeType project, and may only be used, modified, @@ -13,6 +13,7 @@ include $(TOP)/builds/compiler/ansi-cc.mk include $(TOP)/builds/beos/beos-def.mk +include $(TOP)/builds/link_std.mk # EOF diff --git a/include/freetype/internal/t1types.h b/include/freetype/internal/t1types.h index fbb5bc639..6a14f3056 100644 --- a/include/freetype/internal/t1types.h +++ b/include/freetype/internal/t1types.h @@ -81,7 +81,7 @@ FT_BEGIN_HEADER T1_ENCODING_TYPE_ARRAY, T1_ENCODING_TYPE_STANDARD, T1_ENCODING_TYPE_ISOLATIN1, - T1_ENCODING_TYPE_EXPORT + T1_ENCODING_TYPE_EXPERT } T1_EncodingType; diff --git a/src/sfnt/ttload.c b/src/sfnt/ttload.c index 24ab8bb0a..15f27867b 100644 --- a/src/sfnt/ttload.c +++ b/src/sfnt/ttload.c @@ -73,7 +73,9 @@ for ( ; entry < limit; entry++ ) { - if ( entry->Tag == tag ) + /* For compatibility with Windows, we consider 0-length */ + /* tables the same as missing tables. */ + if ( entry->Tag == tag && entry->Length != 0 ) { FT_TRACE3(( "found table.\n" )); return entry; diff --git a/src/type1/t1driver.c b/src/type1/t1driver.c index db611e3d0..e7b1e6e8c 100644 --- a/src/type1/t1driver.c +++ b/src/type1/t1driver.c @@ -445,8 +445,8 @@ const char* gname = face->type1.glyph_names[n]; - if ( gname && gname[0] == glyph_name[0] && - ft_strcmp( gname, glyph_name ) == 0 ) + if ( gname && gname[0] == glyph_name[0] && + ft_strcmp( gname, glyph_name ) == 0 ) return charcode; } } diff --git a/src/type1/t1load.c b/src/type1/t1load.c index d0629758a..d2f810d94 100644 --- a/src/type1/t1load.c +++ b/src/type1/t1load.c @@ -378,8 +378,8 @@ static void - parse_blend_axis_types( T1_Face face, - T1_Loader* loader ) + parse_blend_axis_types( T1_Face face, + T1_Loader loader ) { T1_TokenRec axis_tokens[ T1_MAX_MM_AXIS ]; FT_Int n, num_axis; @@ -440,8 +440,8 @@ static void - parse_blend_design_positions( T1_Face face, - T1_Loader* loader ) + parse_blend_design_positions( T1_Face face, + T1_Loader loader ) { T1_TokenRec design_tokens[ T1_MAX_MM_DESIGNS ]; FT_Int num_designs; @@ -522,8 +522,8 @@ static void - parse_blend_design_map( T1_Face face, - T1_Loader* loader ) + parse_blend_design_map( T1_Face face, + T1_Loader loader ) { FT_Error error = 0; T1_Parser parser = &loader->parser; @@ -603,8 +603,8 @@ static void - parse_weight_vector( T1_Face face, - T1_Loader* loader ) + parse_weight_vector( T1_Face face, + T1_Loader loader ) { FT_Error error = 0; T1_Parser parser = &loader->parser; @@ -655,8 +655,8 @@ /* of spec!); we detect it and terminate the parsing */ /* */ static void - parse_shared_dict( T1_Face face, - T1_Loader* loader ) + parse_shared_dict( T1_Face face, + T1_Loader loader ) { T1_Parser parser = &loader->parser; @@ -688,15 +688,15 @@ static FT_Error - t1_load_keyword( T1_Face face, - T1_Loader* loader, - T1_Field field ) + t1_load_keyword( T1_Face face, + T1_Loader loader, + T1_Field field ) { - FT_Error error; - void* dummy_object; - void** objects; - FT_UInt max_objects; - PS_Blend blend = face->blend; + FT_Error error; + void* dummy_object; + void** objects; + FT_UInt max_objects; + PS_Blend blend = face->blend; /* if the keyword has a dedicated callback, call it */ @@ -767,7 +767,11 @@ /* Note: we must accept "+" as a valid character, as it is used in */ /* embedded type1 fonts in PDF documents. */ /* */ - return ( ft_isalnum( c ) || c == '.' || c == '_' || c == '-' || c == '+' ); + return ( ft_isalnum( c ) || + c == '.' || + c == '_' || + c == '-' || + c == '+' ); } @@ -814,8 +818,8 @@ /* dictionaries */ static void - parse_font_name( T1_Face face, - T1_Loader* loader ) + parse_font_name( T1_Face face, + T1_Loader loader ) { T1_Parser parser = &loader->parser; FT_Error error; @@ -860,8 +864,8 @@ static void - parse_font_bbox( T1_Face face, - T1_Loader* loader ) + parse_font_bbox( T1_Face face, + T1_Loader loader ) { T1_Parser parser = &loader->parser; FT_Fixed temp[4]; @@ -877,8 +881,8 @@ static void - parse_font_matrix( T1_Face face, - T1_Loader* loader ) + parse_font_matrix( T1_Face face, + T1_Loader loader ) { T1_Parser parser = &loader->parser; FT_Matrix* matrix = &face->type1.font_matrix; @@ -889,7 +893,7 @@ if ( matrix->xx || matrix->yx ) - /* with synthetic fonts, it's possible we get here twice */ + /* with synthetic fonts, it's possible we get here twice */ return; (void)T1_ToFixedArray( parser, 6, temp, 3 ); @@ -926,8 +930,8 @@ static void - parse_encoding( T1_Face face, - T1_Loader* loader ) + parse_encoding( T1_Face face, + T1_Loader loader ) { T1_Parser parser = &loader->parser; FT_Byte* cur = parser->root.cursor; @@ -973,13 +977,13 @@ if ( FT_NEW_ARRAY( encode->char_index, count ) || FT_NEW_ARRAY( encode->char_name, count ) || FT_SET_ERROR( psaux->ps_table_funcs->init( - char_table, count, memory ) ) ) + char_table, count, memory ) ) ) { parser->root.error = error; return; } - /* We need to `zero' out encoding_table.elements */ + /* We need to `zero' out encoding_table.elements */ for ( n = 0; n < count; n++ ) { char* notdef = (char *)".notdef"; @@ -1015,10 +1019,10 @@ /* we stop when we encounter a `def' */ if ( c == 'd' && cur + 3 < limit ) { - if ( cur[1] == 'e' && - cur[2] == 'f' && - is_space(cur[-1]) && - is_space(cur[3]) ) + if ( cur[1] == 'e' && + cur[2] == 'f' && + is_space( cur[-1] ) && + is_space( cur[3] ) ) { FT_TRACE6(( "encoding end\n" )); break; @@ -1033,7 +1037,7 @@ parser->root.cursor = cur; charcode = T1_ToInt( parser ); - cur = parser->root.cursor; + cur = parser->root.cursor; /* skip whitespace */ while ( cur < limit && is_space( *cur ) ) @@ -1068,19 +1072,19 @@ face->type1.encoding_type = T1_ENCODING_TYPE_ARRAY; parser->root.cursor = cur; } - /* Otherwise, we should have either `StandardEncoding' or */ - /* `ExpertEncoding' */ + /* Otherwise, we should have either `StandardEncoding', */ + /* `ExpertEncoding', or `ISOLatin1Encoding' */ else { - if ( cur + 17 < limit && + if ( cur + 17 < limit && ft_strncmp( (const char*)cur, "StandardEncoding", 16 ) == 0 ) face->type1.encoding_type = T1_ENCODING_TYPE_STANDARD; - else if ( cur + 15 < limit && + else if ( cur + 15 < limit && ft_strncmp( (const char*)cur, "ExpertEncoding", 14 ) == 0 ) - face->type1.encoding_type = T1_ENCODING_TYPE_EXPORT; + face->type1.encoding_type = T1_ENCODING_TYPE_EXPERT; - else if ( cur + 18 < limit && + else if ( cur + 18 < limit && ft_strncmp( (const char*)cur, "ISOLatin1Encoding", 17 ) == 0 ) face->type1.encoding_type = T1_ENCODING_TYPE_ISOLATIN1; @@ -1094,8 +1098,8 @@ static void - parse_subrs( T1_Face face, - T1_Loader* loader ) + parse_subrs( T1_Face face, + T1_Loader loader ) { T1_Parser parser = &loader->parser; PS_Table table = &loader->subrs; @@ -1191,8 +1195,8 @@ static void - parse_charstrings( T1_Face face, - T1_Loader* loader ) + parse_charstrings( T1_Face face, + T1_Loader loader ) { T1_Parser parser = &loader->parser; PS_Table code_table = &loader->charstrings; @@ -1241,8 +1245,8 @@ if ( error ) goto Fail; - n = 0; + for (;;) { FT_Int size; @@ -1479,10 +1483,10 @@ static FT_Error - parse_dict( T1_Face face, - T1_Loader* loader, - FT_Byte* base, - FT_Long size ) + parse_dict( T1_Face face, + T1_Loader loader, + FT_Byte* base, + FT_Long size ) { T1_Parser parser = &loader->parser; @@ -1499,7 +1503,7 @@ for ( ; cur < limit; cur++ ) { /* look for `FontDirectory', which causes problems on some fonts */ - if ( *cur == 'F' && cur + 25 < limit && + if ( *cur == 'F' && cur + 25 < limit && ft_strncmp( (char*)cur, "FontDirectory", 13 ) == 0 ) { FT_Byte* cur2; @@ -1596,8 +1600,8 @@ static void - t1_init_loader( T1_Loader* loader, - T1_Face face ) + t1_init_loader( T1_Loader loader, + T1_Face face ) { FT_UNUSED( face ); @@ -1616,7 +1620,7 @@ static void - t1_done_loader( T1_Loader* loader ) + t1_done_loader( T1_Loader loader ) { T1_Parser parser = &loader->parser; @@ -1636,7 +1640,7 @@ FT_LOCAL_DEF( FT_Error ) T1_Open_Face( T1_Face face ) { - T1_Loader loader; + T1_LoaderRec loader; T1_Parser parser; T1_Font type1 = &face->type1; FT_Error error; @@ -1701,8 +1705,7 @@ loader.glyph_names.block = 0; loader.glyph_names.elements = 0; - /* we must now build type1.encoding when we have a custom */ - /* array.. */ + /* we must now build type1.encoding when we have a custom array */ if ( type1->encoding_type == T1_ENCODING_TYPE_ARRAY ) { FT_Int charcode, idx, min_char, max_char; @@ -1740,8 +1743,8 @@ if ( ft_strcmp( (const char*)".notdef", (const char*)glyph_name ) != 0 ) { - if (charcode < min_char) min_char = charcode; - if (charcode > max_char) max_char = charcode; + if ( charcode < min_char ) min_char = charcode; + if ( charcode > max_char ) max_char = charcode; } break; } diff --git a/src/type1/t1load.h b/src/type1/t1load.h index 865d62ce7..804a01045 100644 --- a/src/type1/t1load.h +++ b/src/type1/t1load.h @@ -48,7 +48,7 @@ FT_BEGIN_HEADER PS_TableRec subrs; FT_Bool fontdata; - } T1_Loader; + } T1_LoaderRec, *T1_Loader; FT_LOCAL( FT_Error ) diff --git a/src/type1/t1objs.c b/src/type1/t1objs.c index 18d0b1e3f..2755f254a 100644 --- a/src/type1/t1objs.c +++ b/src/type1/t1objs.c @@ -327,10 +327,9 @@ root->num_glyphs = face->type1.num_glyphs; root->face_index = face_index; + root->face_flags = FT_FACE_FLAG_SCALABLE; - root->face_flags |= FT_FACE_FLAG_HORIZONTAL; - root->face_flags |= FT_FACE_FLAG_GLYPH_NAMES; if ( face->type1.font_info.is_fixed_pitch ) @@ -432,28 +431,28 @@ { FT_Face root = &face->root; - + if ( psnames && psaux ) { FT_CharMapRec charmap; T1_CMap_Classes cmap_classes = psaux->t1_cmap_classes; FT_CMap_Class clazz; - + charmap.face = root; - + /* first of all, try to synthetize a Unicode charmap */ charmap.platform_id = 3; charmap.encoding_id = 1; charmap.encoding = ft_encoding_unicode; - + FT_CMap_New( cmap_classes->unicode, NULL, &charmap, NULL ); - + /* now, generate an Adobe Standard encoding when appropriate */ charmap.platform_id = 7; clazz = NULL; - + switch ( face->type1.encoding_type ) { case T1_ENCODING_TYPE_STANDARD: @@ -461,29 +460,29 @@ charmap.encoding_id = 0; clazz = cmap_classes->standard; break; - - case T1_ENCODING_TYPE_EXPORT: + + case T1_ENCODING_TYPE_EXPERT: charmap.encoding = ft_encoding_adobe_expert; charmap.encoding_id = 1; clazz = cmap_classes->expert; break; - + case T1_ENCODING_TYPE_ARRAY: charmap.encoding = ft_encoding_adobe_custom; charmap.encoding_id = 2; clazz = cmap_classes->custom; break; - + case T1_ENCODING_TYPE_ISOLATIN1: charmap.encoding = ft_encoding_latin_1; charmap.encoding_id = 3; clazz = cmap_classes->unicode; break; - + default: ; } - + if ( clazz ) FT_CMap_New( clazz, NULL, &charmap, NULL ); } @@ -535,7 +534,7 @@ charmap->encoding_id = 0; break; - case T1_ENCODING_TYPE_EXPORT: + case T1_ENCODING_TYPE_EXPERT: charmap->encoding = ft_encoding_adobe_expert; charmap->encoding_id = 1; break;