Commit 086dffbb authored by Thierry Reding's avatar Thierry Reding Committed by Jean-Baptiste Kempf

freetype: Fix a possible buffer corruption

Memory associated with a FcPattern is freed when the pattern is
destroyed, so copying the font filename needs to be done before
the call to FcPatternDestroy.
Signed-off-by: default avatarThierry Reding <thierry.reding@avionic-design.de>
Modified-by: Rafaël Carré <funman@videolan.org> (simplify return)
Signed-off-by: default avatarRafaël Carré <funman@videolan.org>
(cherry picked from commit ae3fd827)
Signed-off-by: default avatarJean-Baptiste Kempf <jb@videolan.org>
parent 6325b1c3
...@@ -505,6 +505,7 @@ static char* FontConfig_Select( FcConfig* config, const char* family, ...@@ -505,6 +505,7 @@ static char* FontConfig_Select( FcConfig* config, const char* family,
FcPattern *pat, *p_pat; FcPattern *pat, *p_pat;
FcChar8* val_s; FcChar8* val_s;
FcBool val_b; FcBool val_b;
char *ret = NULL;
/* Create a pattern and fills it */ /* Create a pattern and fills it */
pat = FcPatternCreate(); pat = FcPatternCreate();
...@@ -561,14 +562,11 @@ static char* FontConfig_Select( FcConfig* config, const char* family, ...@@ -561,14 +562,11 @@ static char* FontConfig_Select( FcConfig* config, const char* family,
"the requested one: '%s' != '%s'\n", "the requested one: '%s' != '%s'\n",
(const char*)val_s, family ); */ (const char*)val_s, family ); */
if( FcResultMatch != FcPatternGetString( p_pat, FC_FILE, 0, &val_s ) ) if( FcResultMatch == FcPatternGetString( p_pat, FC_FILE, 0, &val_s ) )
{ ret = strdup( (const char*)val_s );
FcPatternDestroy( p_pat );
return NULL;
}
FcPatternDestroy( p_pat ); FcPatternDestroy( p_pat );
return strdup( (const char*)val_s ); return ret;
} }
#endif #endif
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment