From b246a5efd698f289065ae93393586c7febb5ee65 Mon Sep 17 00:00:00 2001 From: David Turner Date: Mon, 8 Oct 2001 21:18:11 +0000 Subject: [PATCH] * src/psnames/pstables.h, src/psnames/psmodule.c, src/tools/glnames.py: fixed a bug in 'glnames.py' that prevented it from generating correct glyph names table. This resulted in the unavailability of certain glyphs like "Cacute", "cacute" and "lslash" in Unicode charmaps, even if these were present in the font (causing problems for Polish users). --- ChangeLog | 9 + src/psnames/psmodule.c | 10 +- src/psnames/pstables.h | 417 ++++++++++++++++++++++------------------- src/tools/glnames.py | 69 ++++--- 4 files changed, 276 insertions(+), 229 deletions(-) diff --git a/ChangeLog b/ChangeLog index 9399dd011..e43a9ba6c 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +2001-10-08 David Turner + + * src/psnames/pstables.h, src/psnames/psmodule.c, src/tools/glnames.py: + fixed a bug in 'glnames.py' that prevented it from generating correct + glyph names table. This resulted in the unavailability of certain glyphs + like "Cacute", "cacute" and "lslash" in Unicode charmaps, even if these + were present in the font (causing problems for Polish users). + + 2001-10-07 Richard Barber * src/cache/ftlru.c (FT_Lru_Lookup_Node): fixed a bug that prevented diff --git a/src/psnames/psmodule.c b/src/psnames/psmodule.c index 7760588b1..8ed27689d 100644 --- a/src/psnames/psmodule.c +++ b/src/psnames/psmodule.c @@ -115,11 +115,11 @@ /* now, look up the glyph in the Adobe Glyph List */ for ( n = 0; n < NUM_ADOBE_GLYPHS; n++ ) { - const char* name = t1_standard_glyphs[n]; + const char* name = sid_standard_names[n]; if ( first == name[0] && strcmp( glyph_name, name ) == 0 ) - return names_to_unicode[n]; + return ps_names_to_unicode[n]; } /* not found, there is probably no Unicode value for this glyph name */ @@ -173,7 +173,7 @@ { uni_char = PS_Unicode_Value( gname ); - if ( uni_char && uni_char != 0xFFFF ) + if ( uni_char != 0 && uni_char != 0xFFFF ) { map->unicode = uni_char; map->glyph_index = n; @@ -247,14 +247,14 @@ if ( name_index >= 258 ) name_index = 0; - return standard_glyph_names[mac_standard_names[name_index]]; + return ps_glyph_names[mac_standard_names[name_index]]; } static const char* PS_Standard_Strings( FT_UInt sid ) { - return ( sid < NUM_STD_GLYPHS ? t1_standard_glyphs[sid] : 0 ); + return ( sid < NUM_SID_GLYPHS ? sid_standard_names[sid] : 0 ); } diff --git a/src/psnames/pstables.h b/src/psnames/pstables.h index 37b30d077..3db8fe7c3 100644 --- a/src/psnames/pstables.h +++ b/src/psnames/pstables.h @@ -1,6 +1,6 @@ /***************************************************************************/ /* */ -/* pstables.h */ +/* c:\david\source\freetype\freetype2\src\psnames\pstables.h */ /* */ /* PostScript glyph names (specification only). */ /* */ @@ -19,39 +19,13 @@ /* this file has been generated automatically -- do not edit! */ - static const char* const standard_glyph_names[] = + static const char* const ps_glyph_names[] = { + ".notdef", ".null", - "CR", - "notequal", - "infinity", - "lessequal", - "greaterequal", - "partialdiff", - "summation", - "product", - "pi", - "integral", - "Omega", - "radical", - "approxequal", - "Delta", - "nbspace", - "lozenge", - "periodcentered", + "nonmarkingreturn", + "nonbreakingspace", "apple", - "lslash", - "franc", - "Gbreve", - "gbreve", - "Idot", - "Scedilla", - "scedilla", - "Cacute", - "cacute", - "Ccaron", - "ccaron", - "dmacron", ".notdef", "space", "exclam", @@ -166,7 +140,7 @@ "endash", "dagger", "daggerdbl", - "periodcenter", + "periodcentered", "paragraph", "bullet", "quotesinglbase", @@ -198,7 +172,7 @@ "ordmasculine", "ae", "dotlessi", - "Islash", + "lslash", "oslash", "oe", "germandbls", @@ -425,7 +399,7 @@ "OEsmall", "Oslashsmall", "Ugravesmall", - "Uacautesmall", + "Uacutesmall", "Ucircumflexsmall", "Udieresissmall", "Yacutesmall", @@ -455,12 +429,16 @@ "Aogonek", "Aringacute", "Beta", + "Cacute", "Caron", + "Ccaron", "Ccircumflex", "Cdotaccent", "Chi", "Dcaron", "Dcroat", + "Delta", + "Delta", "Dieresis", "DieresisAcute", "DieresisGrave", @@ -476,6 +454,7 @@ "Etatonos", "Euro", "Gamma", + "Gbreve", "Gcaron", "Gcircumflex", "Gcommaaccent", @@ -517,6 +496,8 @@ "Ohorn", "Ohungarumlaut", "Omacron", + "Omega", + "Omega", "Omegatonos", "Omicron", "Omicrontonos", @@ -570,6 +551,8 @@ "SF530000", "SF540000", "Sacute", + "Scedilla", + "Scedilla", "Scircumflex", "Scommaaccent", "Sigma", @@ -579,7 +562,6 @@ "Tcommaaccent", "Tcommaaccent", "Theta", - "Uacutesmall", "Ubreve", "Uhorn", "Uhungarumlaut", @@ -858,6 +840,7 @@ "angleright", "anoteleia", "aogonek", + "approxequal", "aringacute", "arrowboth", "arrowdblboth", @@ -889,7 +872,9 @@ "bracketrightbt", "bracketrightex", "bracketrighttp", + "cacute", "carriagereturn", + "ccaron", "ccircumflex", "cdotaccent", "chi", @@ -939,13 +924,16 @@ "female", "filledbox", "filledrect", + "franc", "gamma", + "gbreve", "gcaron", "gcircumflex", "gcommaaccent", "gdotaccent", "gradient", "gravecomb", + "greaterequal", "hbar", "hcircumflex", "heart", @@ -954,6 +942,8 @@ "ibreve", "ij", "imacron", + "infinity", + "integral", "integralbt", "integralex", "integraltp", @@ -976,12 +966,14 @@ "lcaron", "lcommaaccent", "ldot", + "lessequal", "lfblock", "lira", "ll", "logicaland", "logicalor", "longs", + "lozenge", "ltshade", "male", "minute", @@ -992,6 +984,7 @@ "ncaron", "ncommaaccent", "notelement", + "notequal", "notsubset", "nu", "obreve", @@ -1012,17 +1005,21 @@ "parenrightbt", "parenrightex", "parenrighttp", + "partialdiff", "perpendicular", "peseta", "phi", "phi1", + "pi", "prescription", + "product", "propersubset", "propersuperset", "proportional", "psi", "quotereversed", "racute", + "radical", "radicalex", "rcaron", "rcommaaccent", @@ -1034,6 +1031,8 @@ "rho", "rtblock", "sacute", + "scedilla", + "scedilla", "scircumflex", "scommaaccent", "second", @@ -1044,6 +1043,7 @@ "smileface", "spade", "suchthat", + "summation", "sun", "tau", "tbar", @@ -1090,18 +1090,17 @@ #endif /* FT_CONFIG_OPTION_ADOBE_GLYPH_LIST */ - 0 + NULL }; - static const char* const * const t1_standard_glyphs = - standard_glyph_names + 31; + static const char* const * const sid_standard_names = ps_glyph_names + 5; -#define NUM_STD_GLYPHS 391 +#define NUM_SID_GLYPHS 391 #ifdef FT_CONFIG_OPTION_ADOBE_GLYPH_LIST -#define NUM_ADOBE_GLYPHS 1032 +#define NUM_ADOBE_GLYPHS 1058 #else #define NUM_ADOBE_GLYPHS 391 #endif @@ -1109,9 +1108,35 @@ static const unsigned short mac_standard_names[259] = { - 31, + 5, 0, 1, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 109, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, 32, 33, 34, @@ -1119,7 +1144,7 @@ 36, 37, 38, - 135, + 39, 40, 41, 42, @@ -1150,7 +1175,7 @@ 67, 68, 69, - 70, + 129, 71, 72, 73, @@ -1176,186 +1201,162 @@ 93, 94, 95, - 155, + 96, 97, 98, 99, 100, - 101, - 102, - 103, - 104, - 105, - 106, - 107, - 108, - 109, - 110, - 111, - 112, - 113, - 114, - 115, - 116, - 117, - 118, - 119, - 120, - 121, - 122, - 123, - 124, - 125, - 126, - 204, - 206, + 178, + 180, + 182, + 183, + 191, + 194, + 200, + 205, 208, + 206, + 207, + 210, 209, + 211, + 212, + 215, + 213, + 214, + 216, + 219, 217, + 218, 220, - 226, - 231, - 234, - 232, - 233, - 236, - 235, - 237, - 238, - 241, - 239, - 240, - 242, - 245, - 243, - 244, - 246, - 247, - 250, - 248, - 249, - 251, - 253, - 256, - 254, - 255, + 221, + 224, + 222, + 223, + 225, + 227, + 230, + 228, + 229, + 117, + 166, + 102, + 103, + 107, + 121, + 120, + 154, + 170, + 175, + 158, + 130, + 136, + 2, 143, - 192, - 128, - 129, - 133, - 147, 146, - 180, - 196, - 201, - 184, - 156, - 162, - 2, - 169, - 172, 3, - 187, + 161, 4, 5, - 131, - 183, + 105, + 157, 6, 7, 8, 9, 10, - 170, - 174, + 144, + 148, 11, - 175, - 178, - 154, - 127, - 182, + 149, + 152, + 128, + 101, + 156, 12, - 132, + 106, 13, 14, - 137, - 151, - 152, + 111, + 125, + 126, 15, - 205, - 207, - 222, - 173, 179, + 181, + 196, + 147, + 153, + 116, 142, - 168, - 136, - 150, - 96, - 39, - 190, + 110, + 124, + 70, + 13, + 164, 16, - 258, - 229, - 130, + 232, + 203, + 104, + 108, + 112, + 113, + 114, + 115, + 118, + 119, + 122, + 123, + 127, + 177, + 184, + 176, + 185, + 186, + 187, + 188, + 189, + 190, + 192, + 193, + 17, + 195, + 198, + 199, + 201, + 150, + 131, + 132, + 133, 134, + 135, + 137, 138, 139, 140, 141, - 144, - 17, - 148, - 149, - 153, - 203, - 210, - 202, - 211, - 212, - 213, - 214, - 215, - 216, - 218, - 219, - 18, - 221, - 224, - 225, - 227, - 176, - 157, - 158, - 159, - 160, - 161, - 163, - 164, + 145, + 151, + 197, + 226, + 204, + 233, 165, - 166, + 159, + 172, + 202, + 231, + 162, 167, 171, + 173, + 155, + 169, + 174, + 160, + 163, + 168, + 18, 19, - 223, - 252, - 230, - 259, - 191, - 185, - 198, - 228, - 257, - 188, - 193, - 197, - 199, - 181, - 195, - 200, - 186, - 189, - 194, 20, 21, 22, @@ -1365,14 +1366,12 @@ 26, 27, 28, - 29, - 30, 0 }; - static const unsigned short names_to_unicode[1033] = + static const unsigned short ps_names_to_unicode[1059] = { 0, 0x0020, @@ -1488,7 +1487,7 @@ 0x2013, 0x2020, 0x2021, - 0, + 0x00B7, 0x00B6, 0x2022, 0x201A, @@ -1520,7 +1519,7 @@ 0x00BA, 0x00E6, 0x0131, - 0, + 0x0142, 0x00F8, 0x0153, 0x00DF, @@ -1747,7 +1746,7 @@ 0xF6FA, 0xF7F8, 0xF7F9, - 0, + 0xF7FA, 0xF7FB, 0xF7FC, 0xF7FD, @@ -1777,12 +1776,16 @@ 0x0104, 0x01FA, 0x0392, + 0x0106, 0xF6CA, + 0x010C, 0x0108, 0x010A, 0x03A7, 0x010E, 0x0110, + 0x2206, + 0x2206, 0xF6CB, 0xF6CC, 0xF6CD, @@ -1798,6 +1801,7 @@ 0x0389, 0x20AC, 0x0393, + 0x011E, 0x01E6, 0x011C, 0x0122, @@ -1839,6 +1843,8 @@ 0x01A0, 0x0150, 0x014C, + 0x2126, + 0x2126, 0x038F, 0x039F, 0x038C, @@ -1892,6 +1898,8 @@ 0x256B, 0x256A, 0x015A, + 0x015E, + 0x015E, 0x015C, 0x0218, 0x03A3, @@ -1901,7 +1909,6 @@ 0x0162, 0x0162, 0x0398, - 0xF7FA, 0x016C, 0x01AF, 0x0170, @@ -2180,6 +2187,7 @@ 0x232A, 0x0387, 0x0105, + 0x2248, 0x01FB, 0x2194, 0x21D4, @@ -2211,7 +2219,9 @@ 0xF8FB, 0xF8FA, 0xF8F9, + 0x0107, 0x21B5, + 0x010D, 0x0109, 0x010B, 0x03C7, @@ -2261,13 +2271,16 @@ 0x2640, 0x25A0, 0x25AC, + 0x20A3, 0x03B3, + 0x011F, 0x01E7, 0x011D, 0x0123, 0x0121, 0x2207, 0x0300, + 0x2265, 0x0127, 0x0125, 0x2665, @@ -2276,6 +2289,8 @@ 0x012D, 0x0133, 0x012B, + 0x221E, + 0x222B, 0x2321, 0xF8F5, 0x2320, @@ -2298,12 +2313,14 @@ 0x013E, 0x013C, 0x0140, + 0x2264, 0x258C, 0x20A4, 0xF6C0, 0x2227, 0x2228, 0x017F, + 0x25CA, 0x2591, 0x2642, 0x2032, @@ -2314,6 +2331,7 @@ 0x0148, 0x0146, 0x2209, + 0x2260, 0x2284, 0x03BD, 0x014F, @@ -2334,17 +2352,21 @@ 0xF8F8, 0xF8F7, 0xF8F6, + 0x2202, 0x22A5, 0x20A7, 0x03C6, 0x03D5, + 0x03C0, 0x211E, + 0x220F, 0x2282, 0x2283, 0x221D, 0x03C8, 0x201B, 0x0155, + 0x221A, 0xF8E5, 0x0159, 0x0157, @@ -2356,6 +2378,8 @@ 0x03C1, 0x2590, 0x015B, + 0x015F, + 0x015F, 0x015D, 0x0219, 0x2033, @@ -2366,6 +2390,7 @@ 0x263A, 0x2660, 0x220B, + 0x2211, 0x263C, 0x03C4, 0x0167, @@ -2855,7 +2880,7 @@ 312, 0, 0, - 312, + 313, 0, 0, 314, diff --git a/src/tools/glnames.py b/src/tools/glnames.py index 6179f0071..808e365e2 100644 --- a/src/tools/glnames.py +++ b/src/tools/glnames.py @@ -33,10 +33,13 @@ import sys, string # This table is used to name the glyph according to the Macintosh # specification. It is used by the TrueType Postscript names table # +# see http://fonts.apple.com/TTRefMan/RM06/Chap6post.html +# for the official list +# mac_standard_names = \ [ # 0 - ".notdef", ".null", "CR", "space", "exclam", + ".notdef", ".null", "nonmarkingreturn", "space", "exclam", "quotedbl", "numbersign", "dollar", "percent", "ampersand", # 10 @@ -104,7 +107,7 @@ mac_standard_names = \ "radical", "florin", "approxequal", "Delta", "guillemotleft", # 170 - "guillemotright", "ellipsis", "nbspace", "Agrave", "Atilde", + "guillemotright", "ellipsis", "nonbreakingspace", "Agrave", "Atilde", "Otilde", "OE", "oe", "endash", "emdash", # 180 @@ -137,12 +140,16 @@ mac_standard_names = \ "onequarter", "threequarters", "franc", "Gbreve", "gbreve", # 250 - "Idot", "Scedilla", "scedilla", "Cacute", "cacute", - "Ccaron", "ccaron", "dmacron" + "Idotaccent", "Scedilla", "scedilla", "Cacute", "cacute", + "Ccaron", "ccaron", "dcroat" ] -t1_standard_strings = \ +# the list of standard "SID" glyph names. For the official list, +# see Annex A of document at +# http://partners.adobe.com/asn/developer/pdfs/tn/5176.CFF.pdf +# +sid_standard_names = \ [ # 0 ".notdef", "space", "exclam", "quotedbl", "numbersign", @@ -189,7 +196,7 @@ t1_standard_strings = \ "quotedblleft", "guillemotleft", "guilsinglleft", "guilsinglright", "fi", # 110 - "fl", "endash", "dagger", "daggerdbl", "periodcenter", + "fl", "endash", "dagger", "daggerdbl", "periodcentered", "paragraph", "bullet", "quotesinglbase", "quotedblbase", "quotedblright", # 120 @@ -202,7 +209,7 @@ t1_standard_strings = \ # 140 "Lslash", "Oslash", "OE", "ordmasculine", "ae", - "dotlessi", "Islash", "oslash", "oe", "germandbls", + "dotlessi", "lslash", "oslash", "oe", "germandbls", # 150 "onesuperior", "logicalnot", "mu", "trademark", "Eth", @@ -309,7 +316,7 @@ t1_standard_strings = \ "Odieresissmall", # 370 - "OEsmall", "Oslashsmall", "Ugravesmall", "Uacautesmall", + "OEsmall", "Oslashsmall", "Ugravesmall", "Uacutesmall", "Ucircumflexsmall", "Udieresissmall", "Yacutesmall", "Thornsmall", "Ydieresissmall", "001.000", @@ -323,6 +330,9 @@ t1_standard_strings = \ ] +# this table maps character code of the Adobe Standard Type 1 +# encoding to glyph indexes in the sid_standard_names table +# t1_standard_encoding = \ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, @@ -359,6 +369,9 @@ t1_standard_encoding = \ ] +# this table maps character code of the Adobe Expert Type 1 +# encoding to glyph indexes in the sid_standard_names table +# t1_expert_encoding = \ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, @@ -381,7 +394,7 @@ t1_expert_encoding = \ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 304, 305, 306, 0, 0, 307, 308, 309, 310, - 311, 0, 312, 0, 0, 312, 0, 0, 314, 315, + 311, 0, 312, 0, 0, 313, 0, 0, 314, 315, 0, 0, 316, 317, 318, 0, 0, 0, 158, 155, 163, 319, 320, 321, 322, 323, 324, 325, 0, 0, @@ -1459,8 +1472,8 @@ t1_bias = 0 glyph_list = [] -def the_adobe_glyph_list(): - """return the list of glyph names in the adobe list""" +def adobe_glyph_names(): + """return the list of glyph names from the adobe list""" lines = string.split( adobe_glyph_list, '\n' ) glyphs = [] @@ -1474,8 +1487,8 @@ def the_adobe_glyph_list(): return glyphs -def the_adobe_glyphs(): - """return the list of unicode values""" +def adobe_glyph_values(): + """return the list of glyph names and their unicode values""" lines = string.split( adobe_glyph_list, '\n' ) glyphs = [] @@ -1516,7 +1529,7 @@ def dump_mac_indices( file, t1_bias ): count = 0 for name in mac_standard_names: try: - t1_index = t1_standard_strings.index( name ) + t1_index = sid_standard_names.index( name ) write( " " + repr( t1_bias + t1_index ) + ",\n" ) except: write( " " + repr( count ) + ",\n" ) @@ -1533,7 +1546,7 @@ def dump_glyph_list( file, glyph_list, adobe_extra ): name_list = [] - write( " static const char* const standard_glyph_names[] =\n" ) + write( " static const char* const ps_glyph_names[] =\n" ) write( " {\n" ) for name in glyph_list: @@ -1551,7 +1564,7 @@ def dump_glyph_list( file, glyph_list, adobe_extra ): write( "\n" ) write( "#endif /* FT_CONFIG_OPTION_ADOBE_GLYPH_LIST */\n" ) write( "\n" ) - write( " 0\n" ) + write( " NULL\n" ) write( " };\n" ) write( "\n" ) write( "\n" ) @@ -1564,16 +1577,16 @@ def dump_unicode_values( file, base_list, adobe_list ): write = file.write - adobe_glyphs, uni_values = the_adobe_glyphs() + glyph_names, uni_values = adobe_glyph_values() write( "\n" ) - write( " static const unsigned short names_to_unicode[" + \ + write( " static const unsigned short ps_names_to_unicode[" + \ repr( len( base_list ) + len( adobe_list ) + 1 ) + "] =\n" ) write( " {\n" ) for name in base_list: try: - index = adobe_glyphs.index( name ) + index = glyph_names.index( name ) write( " 0x" + uni_values[index] + ",\n" ) except: write( " 0,\n" ) @@ -1584,7 +1597,7 @@ def dump_unicode_values( file, base_list, adobe_list ): for name in adobe_list: try: - index = adobe_glyphs.index( name ) + index = glyph_names.index( name ) write( " 0x" + uni_values[index] + ",\n" ) except: write( " 0,\n" ) @@ -1625,16 +1638,16 @@ def main(): file = open( sys.argv[1], "w\n" ) write = file.write - count_sid = len( t1_standard_strings ) + count_sid = len( sid_standard_names ) # build mac index table & supplemental glyph names - mac_list = count_extra_glyphs( mac_standard_names, t1_standard_strings ) + mac_list = count_extra_glyphs( mac_standard_names, adobe_glyph_names() ) count_mac = len( mac_list ) t1_bias = count_mac - base_list = mac_list + t1_standard_strings + base_list = mac_list + sid_standard_names # build adobe unicode index table & supplemental glyph names - adobe_list = the_adobe_glyph_list() + adobe_list = adobe_glyph_names() adobe_list = count_extra_glyphs( adobe_list, base_list ) count_adobe = len( adobe_list ) @@ -1646,7 +1659,7 @@ def main(): write( "/* */\n" ) write( "/* PostScript glyph names (specification only). */\n" ) write( "/* */\n" ) - write( "/* Copyright 2000 by */\n" ) + write( "/* Copyright 2000-2001 by */\n" ) write( "/* David Turner, Robert Wilhelm, and Werner Lemberg. */\n" ) write( "/* */\n" ) write( "/* This file is part of the FreeType project, and may only be used, */\n" ) @@ -1666,12 +1679,12 @@ def main(): name_list = dump_glyph_list( file, base_list, adobe_list ) # dump t1_standard_list - write( " static const char* const * const t1_standard_glyphs = " \ - + "standard_glyph_names + " + repr( t1_bias ) + ";\n" ) + write( " static const char* const * const sid_standard_names = " \ + + "ps_glyph_names + " + repr( t1_bias ) + ";\n" ) write( "\n" ) write( "\n" ) - write( "#define NUM_STD_GLYPHS " + repr( len( t1_standard_strings ) ) + "\n" ) + write( "#define NUM_SID_GLYPHS " + repr( len( sid_standard_names ) ) + "\n" ) write( "\n" ) write( "#ifdef FT_CONFIG_OPTION_ADOBE_GLYPH_LIST\n" ) write( "#define NUM_ADOBE_GLYPHS " + \