From 309322ae4af2ed5f2614bae761e27ba9547930a1 Mon Sep 17 00:00:00 2001 From: Fabian Giesen Date: Thu, 1 Jul 2021 17:03:51 -0700 Subject: [PATCH] stb_truetype: Turn codepoint assert into error check Fixes the bug covered by PR #1066, but with a slightly different fix that's hopefully a bit clearer. --- stb_truetype.h | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/stb_truetype.h b/stb_truetype.h index 542a890..e06b867 100644 --- a/stb_truetype.h +++ b/stb_truetype.h @@ -1541,12 +1541,12 @@ STBTT_DEF int stbtt_FindGlyphIndex(const stbtt_fontinfo *info, int unicode_codep search += 2; { - stbtt_uint16 offset, start; + stbtt_uint16 offset, start, last; stbtt_uint16 item = (stbtt_uint16) ((search - endCount) >> 1); - STBTT_assert(unicode_codepoint <= ttUSHORT(data + endCount + 2*item)); start = ttUSHORT(data + index_map + 14 + segcount*2 + 2 + 2*item); - if (unicode_codepoint < start) + last = ttUSHORT(data + endCount + 2*item); + if (unicode_codepoint < start || unicode_codepoint > last) return 0; offset = ttUSHORT(data + index_map + 14 + segcount*6 + 2 + 2*item);