From 9edb03ac7ac4b4d0814f3fd1f20cc8d2be99e971 Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Tue, 10 May 2022 14:25:08 -0600 Subject: [PATCH] [cff-common] Optimize INDEX::operator[] --- src/hb-ot-cff-common.hh | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/src/hb-ot-cff-common.hh b/src/hb-ot-cff-common.hh index 8688575e9..888683427 100644 --- a/src/hb-ot-cff-common.hh +++ b/src/hb-ot-cff-common.hh @@ -212,14 +212,6 @@ struct CFFIndex return offset; } - unsigned int length_at (unsigned int index) const - { - if (unlikely ((offset_at (index + 1) < offset_at (index)) || - (offset_at (index + 1) > offset_at (count)))) - return 0; - return offset_at (index + 1) - offset_at (index); - } - const unsigned char *data_base () const { return (const unsigned char *) this + min_size + offSize.static_size + offset_array_size (); } public: @@ -227,7 +219,15 @@ struct CFFIndex hb_ubytes_t operator [] (unsigned int index) const { if (unlikely (index >= count)) return hb_ubytes_t (); - return hb_ubytes_t (data_base () + offset_at (index) - 1, length_at (index)); + + unsigned offset1 = offset_at (index); + unsigned offset2 = offset_at (index + 1); + unsigned offsetn = offset_at (count); + + if (unlikely (offset2 < offset1 || offset2 > offsetn)) + return hb_ubytes_t (); + + return hb_ubytes_t (data_base () + offset1 - 1, offset2 - offset1); } unsigned int get_size () const