From 91dff73cf48d96a17c66b6476c48326aa379c409 Mon Sep 17 00:00:00 2001 From: Klaus Schmidinger Date: Fri, 29 Feb 2008 13:41:11 +0100 Subject: [PATCH] Fixed a crash in cFreetypeFont::DrawText() if an unknown symbol is encountered; unknown symbols are replaced with a '?' --- CONTRIBUTORS | 1 + HISTORY | 2 ++ font.c | 7 ++++++- 3 files changed, 9 insertions(+), 1 deletion(-) diff --git a/CONTRIBUTORS b/CONTRIBUTORS index ee547adb..7b719184 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -2100,6 +2100,7 @@ Tobias Grimm for fixing a memory leak in closing the video file during replay for fixing deleting the 'skinDescriptions' in cMenuSetupOSD::~cMenuSetupOSD() for reporting that GCC 4.3 issues a silly warning for expressions like 'a || b && c' + for fixing a crash in cFreetypeFont::DrawText() if an unknown symbol is encountered Helge Lenz for reporting a bug in setting the 'Delta' parameter when calling the shutdown diff --git a/HISTORY b/HISTORY index c1a7cf39..4c6987f4 100644 --- a/HISTORY +++ b/HISTORY @@ -5682,3 +5682,5 @@ Video Disk Recorder Revision History - Updated French language texts (thanks to Jean-Claude Repetto). - Fixed handling 3 and 4 byte UTF-8 symbols in Utf8CharGet() (thanks to Andreas Mair). +- Fixed a crash in cFreetypeFont::DrawText() if an unknown symbol is encountered + (thanks to Tobias Grimm). Unknown symbols are replaced with a '?'. diff --git a/font.c b/font.c index 2f14d14f..7e52a5f5 100644 --- a/font.c +++ b/font.c @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: font.c 1.23 2008/02/09 11:52:25 kls Exp $ + * $Id: font.c 1.24 2008/02/29 13:35:15 kls Exp $ */ #include "font.h" @@ -214,6 +214,9 @@ cGlyph* cFreetypeFont::Glyph(uint CharCode, bool AntiAliased) const return Glyph; } } +#define UNKNOWN_GLYPH_INDICATOR '?' + if (CharCode != UNKNOWN_GLYPH_INDICATOR) + return Glyph(UNKNOWN_GLYPH_INDICATOR); return NULL; } @@ -258,6 +261,8 @@ void cFreetypeFont::DrawText(cBitmap *Bitmap, int x, int y, const char *s, tColo uint sym = Utf8CharGet(s, sl); s += sl; cGlyph *g = Glyph(sym, AntiAliased); + if (!g) + continue; int kerning = Kerning(g, prevSym); prevSym = sym; uchar *buffer = g->Bitmap();