From 698f51464c4a8f2e7e49c2e99fb0c8b4bfce9493 Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Mon, 27 Jun 2022 15:30:19 -0600 Subject: [PATCH] [gvar] Share vector allocation across delta-sets --- src/hb-ot-var-gvar-table.hh | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/hb-ot-var-gvar-table.hh b/src/hb-ot-var-gvar-table.hh index 95b46fe47..31970458d 100644 --- a/src/hb-ot-var-gvar-table.hh +++ b/src/hb-ot-var-gvar-table.hh @@ -575,6 +575,10 @@ struct gvar auto coords = hb_array (font->coords, font->num_coords); unsigned num_coords = table->axisCount; hb_array_t shared_tuples = (table+table->sharedTuples).as_array (table->sharedTupleCount * table->axisCount); + + hb_vector_t private_indices; + hb_vector_t x_deltas; + hb_vector_t y_deltas; do { float scalar = iterator.current_tuple->calculate_scalar (coords, num_coords, shared_tuples); @@ -586,7 +590,6 @@ struct gvar const HBUINT8 *end = p + length; - hb_vector_t private_indices; bool has_private_points = iterator.current_tuple->has_private_points (); if (has_private_points && !GlyphVariationData::unpack_points (p, private_indices, end)) @@ -595,10 +598,8 @@ struct gvar bool apply_to_all = (indices.length == 0); unsigned int num_deltas = apply_to_all ? points.length : indices.length; - hb_vector_t x_deltas; if (unlikely (!x_deltas.resize (num_deltas))) return false; if (unlikely (!GlyphVariationData::unpack_deltas (p, x_deltas, end))) return false; - hb_vector_t y_deltas; if (unlikely (!y_deltas.resize (num_deltas))) return false; if (unlikely (!GlyphVariationData::unpack_deltas (p, y_deltas, end))) return false;