From 91dff73cf48d96a17c66b6476c48326aa379c409 Mon Sep 17 00:00:00 2001 From: Klaus Schmidinger Date: Fri, 29 Feb 2008 13:41:11 +0100 Subject: Fixed a crash in cFreetypeFont::DrawText() if an unknown symbol is encountered; unknown symbols are replaced with a '?' --- font.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'font.c') 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(); -- cgit v1.2.3