ref: a87bb7923592dda5aafd8d35b3a678db90f671e0
parent: b9b2cac6343caca35e3f8f5818b4f1018e8f44c5
author: David Turner <[email protected]>
date: Wed Jul 10 12:58:10 EDT 2002
* src/cff/cffobjs.c: small fix to allow OpenType fonts to support Adobe charmaps when needed.
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
2002-07-10 David Turner <[email protected]>
+ * src/cff/cffobjs.c: small fix to allow OpenType fonts to support Adobe
+ charmaps when needed.
+
* src/cff/cffcmap.c, src/cff/cffcmap.h, Jamfile, rules.mk: new files added
to support charmaps for CFF fonts
--- a/src/cff/cffobjs.c
+++ b/src/cff/cffobjs.c
@@ -446,73 +446,74 @@
flags |= FT_STYLE_FLAG_BOLD;
root->style_flags = flags;
+ }
- /*******************************************************************/
- /* */
- /* Compute char maps. */
- /* */
+ /*******************************************************************/
+ /* */
+ /* Compute char maps. */
+ /* */
+
+ /* try to synthetize a Unicode charmap if there is none available */
+ /* already. If an OpenType font contains a Unicode "cmap", we */
+ /* will use it, wathever be in the CFF part of the file.. */
+ {
+ FT_CharMapRec cmaprec;
+ FT_CharMap cmap;
+ FT_UInt nn;
+ CFF_Encoding encoding = &cff->encoding;
- /* try to synthetize a Unicode charmap if there is none available */
- /* already. If an OpenType font contains a Unicode "cmap", we */
- /* will use it, wathever be in the CFF part of the file.. */
+ for ( nn = 0; nn < (FT_UInt) root->num_charmaps; nn++ )
{
- FT_CharMapRec cmaprec;
- FT_CharMap cmap;
- FT_UInt nn;
- CFF_Encoding encoding = &cff->encoding;
+ cmap = root->charmaps[nn];
- for ( nn = 0; nn < (FT_UInt) root->num_charmaps; nn++ )
- {
- cmap = root->charmaps[nn];
+ /* Windows Unicode (3,1) ? */
+ if ( cmap->platform_id == 3 && cmap->encoding_id == 1 )
+ goto Skip_Unicode;
- /* Windows Unicode (3,1) ? */
- if ( cmap->platform_id == 3 && cmap->platform_id == 1 )
- goto Skip_Unicode;
-
- /* Deprecated Unicode platform id ?? */
- if ( cmap->platform_id == 0 )
- break; /* Standard Unicode (deprecated) */
- }
-
- /* we didn't find a Unicode charmap, synthetize one */
+ /* Deprecated Unicode platform id ?? */
+ if ( cmap->platform_id == 0 )
+ goto Skip_Unicode; /* Standard Unicode (deprecated) */
+ }
+
+ /* we didn't find a Unicode charmap, synthetize one */
#ifdef FT_CONFIG_OPTION_USE_CMAPS
- cmaprec.face = root;
- cmaprec.platform_id = 3;
- cmaprec.encoding_id = 1;
- cmaprec.encoding = ft_encoding_unicode;
+ cmaprec.face = root;
+ cmaprec.platform_id = 3;
+ cmaprec.encoding_id = 1;
+ cmaprec.encoding = ft_encoding_unicode;
- FT_CMap_New( &cff_cmap_unicode_class_rec, NULL, &cmaprec, NULL );
+ FT_CMap_New( &cff_cmap_unicode_class_rec, NULL, &cmaprec, NULL );
- Skip_Unicode:
- if ( encoding->count > 0 )
+ Skip_Unicode:
+ if ( encoding->count > 0 )
+ {
+ FT_CMap_Class clazz;
+
+ cmaprec.face = root;
+ cmaprec.platform_id = 7; /* Adobe platform id */
+
+ switch( encoding->offset )
{
- FT_CMap_Class clazz;
+ case 0:
+ cmaprec.encoding_id = 0;
+ cmaprec.encoding = ft_encoding_adobe_standard;
+ clazz = &cff_cmap_encoding_class_rec;
+ break;
- cmaprec.face = root;
- cmaprec.platform_id = 7; /* Adobe platform id */
-
- switch( encoding->offset )
- {
- case 0:
- cmaprec.encoding_id = 0;
- cmaprec.encoding = ft_encoding_adobe_standard;
- clazz = &cff_cmap_encoding_class_rec;
- break;
-
- case 1:
- cmaprec.encoding_id = 1;
- cmaprec.encoding = ft_encoding_adobe_expert;
- clazz = &cff_cmap_encoding_class_rec;
- break;
-
- default:
- cmaprec.encoding_id = 3;
- cmaprec.encoding = ft_encoding_adobe_custom;
- clazz = &cff_cmap_encoding_class_rec;
- }
+ case 1:
+ cmaprec.encoding_id = 1;
+ cmaprec.encoding = ft_encoding_adobe_expert;
+ clazz = &cff_cmap_encoding_class_rec;
+ break;
- FT_CMap_New( clazz, NULL, &cmaprec, NULL );
+ default:
+ cmaprec.encoding_id = 3;
+ cmaprec.encoding = ft_encoding_adobe_custom;
+ clazz = &cff_cmap_encoding_class_rec;
+ }
+
+ FT_CMap_New( clazz, NULL, &cmaprec, NULL );
#else /* !FT_CONFIG_OPTION_USE_CMAPS */
@@ -519,8 +520,6 @@
/* unimplemented !! */
#endif /* !FT_CONFIG_OPTION_USE_CMAPS */
-
- }
}
}