From 5a5030366e40baa8d96ca67b47a52ad5af143157 Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Mon, 2 May 2011 19:54:29 -0400 Subject: [PATCH] Fix bug in array growth implementation With this, test/object is now passing. Yay! --- src/hb-private.hh | 24 +++++++++++------------- 1 file changed, 11 insertions(+), 13 deletions(-) diff --git a/src/hb-private.hh b/src/hb-private.hh index dc4700091..02fc0996a 100644 --- a/src/hb-private.hh +++ b/src/hb-private.hh @@ -294,30 +294,28 @@ struct hb_static_array_t { } if (likely (len < allocated)) return &array[len++]; + /* Need to reallocate */ unsigned int new_allocated = allocated + (allocated >> 1) + 8; - Type *new_array; + Type *new_array = NULL; + if (array == static_array) { new_array = (Type *) calloc (new_allocated, sizeof (Type)); - if (new_array) { + if (new_array) memcpy (new_array, array, len * sizeof (Type)); - array = new_array; - } } else { bool overflows = (new_allocated < allocated) || _hb_unsigned_int_mul_overflows (new_allocated, sizeof (Type)); - if (unlikely (overflows)) - new_array = NULL; - else + if (likely (!overflows)) { new_array = (Type *) realloc (array, new_allocated * sizeof (Type)); - if (new_array) { - free (array); - array = new_array; } } - if ((len < allocated)) - return &array[len++]; - else + + if (unlikely (!new_array)) return NULL; + + array = new_array; + allocated = new_allocated; + return &array[len++]; } inline void pop (void)