From c755b3884f40595340fe3de615faf8c17842c667 Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Thu, 1 Dec 2022 20:02:38 -0700 Subject: [PATCH] [subset-cff] Pre-alloc enough for check-less copy --- src/hb-subset-cff-common.hh | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/src/hb-subset-cff-common.hh b/src/hb-subset-cff-common.hh index d0446e07d..e194ab629 100644 --- a/src/hb-subset-cff-common.hh +++ b/src/hb-subset-cff-common.hh @@ -111,14 +111,9 @@ struct str_encoder_t void copy_str (const unsigned char *str, unsigned length) { - unsigned int offset = buff.length; - /* Manually resize buffer since faster. */ - if (likely ((signed) (buff.length + length) <= buff.allocated)) - buff.length += length; - else if (unlikely (!buff.resize (offset + length))) - return; - - hb_memcpy (buff.arrayZ + offset, str, length); + assert ((signed) (buff.length + length) <= buff.allocated); + hb_memcpy (buff.arrayZ + buff.length, str, length); + buff.length += length; } bool in_error () const { return buff.in_error (); } @@ -986,8 +981,13 @@ struct subr_subsetter_t unsigned size = 0; for (unsigned int i = 0; i < count; i++) + { size += arr[i].length; - buff.alloc (size); + if (arr[i].op == OpCode_callsubr || arr[i].op == OpCode_callgsubr) + size += 3; + } + if (!buff.alloc (size)) + return false; for (unsigned int i = 0; i < count; i++) {