From: eugeni Date: Fri, 3 Nov 2006 23:11:00 +0000 (+0000) Subject: Prefer microsoft-specific charmaps to all other. X-Git-Tag: 0.9.7~400 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=eed98361befc05a44bae35f68a6348e49b9ecabc;p=libass Prefer microsoft-specific charmaps to all other. There are some fonts with both 'Unicode' and 'Microsoft/Unicode' charmaps, and the second always seems to be the right choice. git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@20653 b3059339-0415-0410-9bf9-f77b7e298cf2 --- diff --git a/libass/ass_cache.c b/libass/ass_cache.c index a2f5bf2..7ed4d7e 100644 --- a/libass/ass_cache.c +++ b/libass/ass_cache.c @@ -56,6 +56,24 @@ static int font_compare(face_desc_t* a, face_desc_t* b) { return 1; } +/** + * Select Microfost Unicode CharMap, if the font has one. + * Otherwise, let FreeType decide. + */ +static void charmap_magic(FT_Face face) +{ + int i; + for (i = 0; i < face->num_charmaps; ++i) { + FT_CharMap cmap = face->charmaps[i]; + unsigned pid = cmap->platform_id; + unsigned eid = cmap->encoding_id; + if (pid == 3 /*microsoft*/ && (eid == 1 /*unicode bmp*/ || eid == 10 /*full unicode*/)) { + FT_Set_Charmap(face, cmap); + break; + } + } +} + /** * \brief Get a face object, either from cache or created through FreeType+FontConfig. * \param library FreeType library object @@ -91,6 +109,8 @@ int ass_new_face(FT_Library library, void* fontconfig_priv, face_desc_t* desc, / no_more_font_messages = 1; return 1; } + + charmap_magic(*face); item = face_cache + face_cache_size; item->path = strdup(path);