From b6903bd6c4b0c792c821e37a8e223088ae40e5fa Mon Sep 17 00:00:00 2001 From: Michiharu Ariza Date: Fri, 16 Nov 2018 13:46:58 -0800 Subject: [PATCH] ensure fdmap initialized as identity for single-FD (non-CID) fonts --- src/hb-subset-cff1.cc | 13 ++++++++++--- src/hb-subset-cff2.cc | 2 ++ 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/src/hb-subset-cff1.cc b/src/hb-subset-cff1.cc index c889e1067..459da5c46 100644 --- a/src/hb-subset-cff1.cc +++ b/src/hb-subset-cff1.cc @@ -647,8 +647,9 @@ struct cff_subset_plan { } /* Determine re-mapping of font index as fdmap among other info */ - if (acc.fdSelect != &Null(CFF1FDSelect) - && unlikely (!hb_plan_subset_cff_fdselect (plan->glyphs, + if (acc.fdSelect != &Null(CFF1FDSelect)) + { + if (unlikely (!hb_plan_subset_cff_fdselect (plan->glyphs, orig_fdcount, *acc.fdSelect, subset_fdcount, @@ -657,6 +658,9 @@ struct cff_subset_plan { subset_fdselect_ranges, fdmap))) return false; + } + else + fdmap.identity (1); /* remove unused SIDs & reassign SIDs */ { @@ -790,7 +794,10 @@ struct cff_subset_plan { unsigned int priv_size = PrivateDict::calculate_serialized_size (acc.privateDicts[i], privSzr, has_localsubrs); TableInfo privInfo = { final_size, priv_size, 0 }; FontDictValuesMod fontdict_mod; - fontdict_mod.init ( &acc.fontDicts[i], sidmap[acc.fontDicts[i].fontName], privInfo ); + if (!acc.is_CID ()) + fontdict_mod.init ( &Null(CFF1FontDictValues), CFF_UNDEF_SID, privInfo ); + else + fontdict_mod.init ( &acc.fontDicts[i], sidmap[acc.fontDicts[i].fontName], privInfo ); fontdicts_mod.push (fontdict_mod); final_size += privInfo.size; diff --git a/src/hb-subset-cff2.cc b/src/hb-subset-cff2.cc index a30bc27f7..49de99544 100644 --- a/src/hb-subset-cff2.cc +++ b/src/hb-subset-cff2.cc @@ -356,6 +356,8 @@ struct cff2_subset_plan { final_size += offsets.FDSelectInfo.size; } + else + fdmap.identity (1); /* FDArray (FDIndex) */ {