mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0026611: Visualization, TKService - fix NULL-dereference in Font_FontMgr on broken font
Check FT_Face::family_name for NULL during detection. Skip fonts without mandatory UNICODE charset in Font_FontMgr. Test case for issue CR26611 Drop the test case for issue CR26611
This commit is contained in:
parent
09749bc31c
commit
508643cf1b
@ -203,9 +203,14 @@ static Handle(Font_SystemFont) checkFont (const Handle(Font_FTLibrary)& theFTLib
|
|||||||
anAspect = Font_FA_Bold;
|
anAspect = Font_FA_Bold;
|
||||||
}
|
}
|
||||||
|
|
||||||
Handle(TCollection_HAsciiString) aFontName = new TCollection_HAsciiString (aFontFace->family_name);
|
Handle(Font_SystemFont) aResult;
|
||||||
Handle(TCollection_HAsciiString) aFontPath = new TCollection_HAsciiString (theFontPath);
|
if (aFontFace->family_name != NULL // skip broken fonts (error in FreeType?)
|
||||||
Handle(Font_SystemFont) aResult = new Font_SystemFont (aFontName, anAspect, aFontPath);
|
&& FT_Select_Charmap (aFontFace, ft_encoding_unicode) == 0) // Font_FTFont supports only UNICODE fonts
|
||||||
|
{
|
||||||
|
Handle(TCollection_HAsciiString) aFontName = new TCollection_HAsciiString (aFontFace->family_name);
|
||||||
|
Handle(TCollection_HAsciiString) aFontPath = new TCollection_HAsciiString (theFontPath);
|
||||||
|
aResult = new Font_SystemFont (aFontName, anAspect, aFontPath);
|
||||||
|
}
|
||||||
|
|
||||||
FT_Done_Face (aFontFace);
|
FT_Done_Face (aFontFace);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user