dwrite/shaping: Make sure initial glyph buffer can fit at least one glyph per WCHAR.

Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Nikolay Sivov 2021-02-10 14:31:13 +03:00 committed by Alexandre Julliard
parent beb9c6578a
commit 23638b44ed
1 changed files with 6 additions and 8 deletions

View File

@ -1154,6 +1154,7 @@ static HRESULT WINAPI dwritetextanalyzer_GetGlyphs(IDWriteTextAnalyzer2 *iface,
struct scriptshaping_context context = { 0 }; struct scriptshaping_context context = { 0 };
struct dwrite_fontface *font_obj; struct dwrite_fontface *font_obj;
WCHAR digits[NATIVE_DIGITS_LEN]; WCHAR digits[NATIVE_DIGITS_LEN];
unsigned int glyph_count;
HRESULT hr; HRESULT hr;
TRACE("%s:%u, %p, %d, %d, %s, %s, %p, %p, %p, %u, %u, %p, %p, %p, %p, %p.\n", debugstr_wn(text, length), TRACE("%s:%u, %p, %d, %d, %s, %s, %p, %p, %p, %u, %u, %p, %p, %p, %p, %p.\n", debugstr_wn(text, length),
@ -1163,12 +1164,9 @@ static HRESULT WINAPI dwritetextanalyzer_GetGlyphs(IDWriteTextAnalyzer2 *iface,
analyzer_dump_user_features(features, feature_range_lengths, feature_ranges); analyzer_dump_user_features(features, feature_range_lengths, feature_ranges);
if (max_glyph_count < length)
return E_NOT_SUFFICIENT_BUFFER;
get_number_substitutes(substitution, is_rtl, digits); get_number_substitutes(substitution, is_rtl, digits);
font_obj = unsafe_impl_from_IDWriteFontFace(fontface); font_obj = unsafe_impl_from_IDWriteFontFace(fontface);
glyph_count = max(max_glyph_count, length);
context.cache = fontface_get_shaping_cache(font_obj); context.cache = fontface_get_shaping_cache(font_obj);
context.script = analysis->script > Script_LastId ? Script_Unknown : analysis->script; context.script = analysis->script > Script_LastId ? Script_Unknown : analysis->script;
@ -1176,18 +1174,18 @@ static HRESULT WINAPI dwritetextanalyzer_GetGlyphs(IDWriteTextAnalyzer2 *iface,
context.length = length; context.length = length;
context.is_rtl = is_rtl; context.is_rtl = is_rtl;
context.is_sideways = is_sideways; context.is_sideways = is_sideways;
context.u.subst.glyphs = heap_calloc(max_glyph_count, sizeof(*glyphs)); context.u.subst.glyphs = heap_calloc(glyph_count, sizeof(*glyphs));
context.u.subst.glyph_props = heap_calloc(max_glyph_count, sizeof(*glyph_props)); context.u.subst.glyph_props = heap_calloc(glyph_count, sizeof(*glyph_props));
context.u.subst.text_props = text_props; context.u.subst.text_props = text_props;
context.u.subst.clustermap = clustermap; context.u.subst.clustermap = clustermap;
context.u.subst.max_glyph_count = max_glyph_count; context.u.subst.max_glyph_count = max_glyph_count;
context.u.subst.capacity = max_glyph_count; context.u.subst.capacity = glyph_count;
context.u.subst.digits = digits; context.u.subst.digits = digits;
context.language_tag = get_opentype_language(locale); context.language_tag = get_opentype_language(locale);
context.user_features.features = features; context.user_features.features = features;
context.user_features.range_lengths = feature_range_lengths; context.user_features.range_lengths = feature_range_lengths;
context.user_features.range_count = feature_ranges; context.user_features.range_count = feature_ranges;
context.glyph_infos = heap_alloc_zero(sizeof(*context.glyph_infos) * max_glyph_count); context.glyph_infos = heap_calloc(glyph_count, sizeof(*context.glyph_infos));
context.table = &context.cache->gsub; context.table = &context.cache->gsub;
scriptprops = &dwritescripts_properties[context.script]; scriptprops = &dwritescripts_properties[context.script];