From dfad19ad5aefdacecca6af81917abc2670d4416f Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Fri, 30 Nov 2018 19:57:12 -0500 Subject: [PATCH] Make operator [] take signed int The built-in operator takes signed int. So, match it, such that the built-in is never a better or equally-good match to our operator. Fixes "ambiguous overload" errors from gcc 4.2 and VS 2008. See https://github.com/harfbuzz/harfbuzz/issues/1374 --- src/hb-dsalgs.hh | 3 ++- src/hb-open-type.hh | 42 ++++++++++++++++++++++++++++-------------- src/hb-vector.hh | 6 ++++-- 3 files changed, 34 insertions(+), 17 deletions(-) diff --git a/src/hb-dsalgs.hh b/src/hb-dsalgs.hh index 4a8144ba7..9c920fc89 100644 --- a/src/hb-dsalgs.hh +++ b/src/hb-dsalgs.hh @@ -571,8 +571,9 @@ struct hb_array_t inline hb_array_t (const hb_array_t &o) : arrayZ (o.arrayZ), len (o.len) {} inline hb_array_t (Type *array_, unsigned int len_) : arrayZ (array_), len (len_) {} - inline Type& operator [] (unsigned int i) const + inline Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; if (unlikely (i >= len)) return Null(Type); return arrayZ[i]; } diff --git a/src/hb-open-type.hh b/src/hb-open-type.hh index f4d0238ea..ee76d7ed8 100644 --- a/src/hb-open-type.hh +++ b/src/hb-open-type.hh @@ -351,14 +351,16 @@ struct UnsizedArrayOf HB_NO_CREATE_COPY_ASSIGN_TEMPLATE (UnsizedArrayOf, Type); - inline const Type& operator [] (unsigned int i) const + inline const Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; const Type *p = &arrayZ[i]; if (unlikely (p < arrayZ)) return Null (Type); /* Overflowed. */ return *p; } - inline Type& operator [] (unsigned int i) + inline Type& operator [] (int i_) { + unsigned int i = (unsigned int) i_; Type *p = &arrayZ[i]; if (unlikely (p < arrayZ)) return Crap (Type); /* Overflowed. */ return *p; @@ -441,14 +443,16 @@ struct UnsizedOffsetArrayOf : UnsizedArrayOf struct UnsizedOffsetListOf : UnsizedOffsetArrayOf { - inline const Type& operator [] (unsigned int i) const + inline const Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; const OffsetTo *p = &this->arrayZ[i]; if (unlikely (p < this->arrayZ)) return Null (Type); /* Overflowed. */ return this+*p; } - inline Type& operator [] (unsigned int i) + inline Type& operator [] (int i_) { + unsigned int i = (unsigned int) i_; const OffsetTo *p = &this->arrayZ[i]; if (unlikely (p < this->arrayZ)) return Crap (Type); /* Overflowed. */ return this+*p; @@ -501,13 +505,15 @@ struct ArrayOf HB_NO_CREATE_COPY_ASSIGN_TEMPLATE2 (ArrayOf, Type, LenType); - inline const Type& operator [] (unsigned int i) const + inline const Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; if (unlikely (i >= len)) return Null (Type); return arrayZ[i]; } - inline Type& operator [] (unsigned int i) + inline Type& operator [] (int i_) { + unsigned int i = (unsigned int) i_; if (unlikely (i >= len)) return Crap (Type); return arrayZ[i]; } @@ -625,13 +631,15 @@ struct LOffsetLArrayOf : ArrayOf, HBUINT32> {}; template struct OffsetListOf : OffsetArrayOf { - inline const Type& operator [] (unsigned int i) const + inline const Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; if (unlikely (i >= this->len)) return Null (Type); return this+this->arrayZ[i]; } - inline const Type& operator [] (unsigned int i) + inline const Type& operator [] (int i_) { + unsigned int i = (unsigned int) i_; if (unlikely (i >= this->len)) return Crap (Type); return this+this->arrayZ[i]; } @@ -668,13 +676,15 @@ struct HeadlessArrayOf HB_NO_CREATE_COPY_ASSIGN_TEMPLATE2 (HeadlessArrayOf, Type, LenType); - inline const Type& operator [] (unsigned int i) const + inline const Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; if (unlikely (i >= lenP1 || !i)) return Null (Type); return arrayZ[i-1]; } - inline Type& operator [] (unsigned int i) + inline Type& operator [] (int i_) { + unsigned int i = (unsigned int) i_; if (unlikely (i >= lenP1 || !i)) return Crap (Type); return arrayZ[i-1]; } @@ -734,13 +744,15 @@ struct ArrayOfM1 { HB_NO_CREATE_COPY_ASSIGN_TEMPLATE2 (ArrayOfM1, Type, LenType); - inline const Type& operator [] (unsigned int i) const + inline const Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; if (unlikely (i > lenM1)) return Null (Type); return arrayZ[i]; } - inline Type& operator [] (unsigned int i) + inline Type& operator [] (int i_) { + unsigned int i = (unsigned int) i_; if (unlikely (i > lenM1)) return Crap (Type); return arrayZ[i]; } @@ -890,13 +902,15 @@ struct VarSizedBinSearchArrayOf return true; } - inline const Type& operator [] (unsigned int i) const + inline const Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; if (unlikely (i >= get_length ())) return Null (Type); return StructAtOffset (&bytesZ, i * header.unitSize); } - inline Type& operator [] (unsigned int i) + inline Type& operator [] (int i_) { + unsigned int i = (unsigned int) i_; if (unlikely (i >= get_length ())) return Crap (Type); return StructAtOffset (&bytesZ, i * header.unitSize); } diff --git a/src/hb-vector.hh b/src/hb-vector.hh index 313c24c41..953a776e0 100644 --- a/src/hb-vector.hh +++ b/src/hb-vector.hh @@ -78,14 +78,16 @@ struct hb_vector_t inline const Type * arrayZ (void) const { return arrayZ_ ? arrayZ_ : static_array; } - inline Type& operator [] (unsigned int i) + inline Type& operator [] (int i_) { + unsigned int i = (unsigned int) i_; if (unlikely (i >= len)) return Crap (Type); return arrayZ()[i]; } - inline const Type& operator [] (unsigned int i) const + inline const Type& operator [] (int i_) const { + unsigned int i = (unsigned int) i_; if (unlikely (i >= len)) return Null(Type); return arrayZ()[i];