[meta] Use std::addressof() instead of hb_addressof()
This commit is contained in:
parent
b7b0a15f7e
commit
8a69e00639
|
@ -880,7 +880,7 @@ hb_bsearch_impl (unsigned *pos, /* Out */
|
||||||
#pragma GCC diagnostic ignored "-Wcast-align"
|
#pragma GCC diagnostic ignored "-Wcast-align"
|
||||||
V* p = (V*) (((const char *) base) + (mid * stride));
|
V* p = (V*) (((const char *) base) + (mid * stride));
|
||||||
#pragma GCC diagnostic pop
|
#pragma GCC diagnostic pop
|
||||||
int c = compar ((const void *) hb_addressof (key), (const void *) p, ds...);
|
int c = compar ((const void *) std::addressof (key), (const void *) p, ds...);
|
||||||
if (c < 0)
|
if (c < 0)
|
||||||
max = mid - 1;
|
max = mid - 1;
|
||||||
else if (c > 0)
|
else if (c > 0)
|
||||||
|
|
|
@ -91,7 +91,7 @@ struct hb_iter_t
|
||||||
* TODO Use a wrapper return type to fix for non-reference type. */
|
* TODO Use a wrapper return type to fix for non-reference type. */
|
||||||
template <typename T = item_t,
|
template <typename T = item_t,
|
||||||
hb_enable_if (std::is_reference<T>::value)>
|
hb_enable_if (std::is_reference<T>::value)>
|
||||||
hb_remove_reference<item_t>* operator -> () const { return hb_addressof (**thiz()); }
|
hb_remove_reference<item_t>* operator -> () const { return std::addressof (**thiz()); }
|
||||||
item_t operator * () const { return thiz()->__item__ (); }
|
item_t operator * () const { return thiz()->__item__ (); }
|
||||||
item_t operator * () { return thiz()->__item__ (); }
|
item_t operator * () { return thiz()->__item__ (); }
|
||||||
item_t operator [] (unsigned i) const { return thiz()->__item_at__ (i); }
|
item_t operator [] (unsigned i) const { return thiz()->__item_at__ (i); }
|
||||||
|
|
|
@ -69,9 +69,9 @@ struct hb_hashmap_t
|
||||||
|
|
||||||
void clear ()
|
void clear ()
|
||||||
{
|
{
|
||||||
new (hb_addressof (key)) K ();
|
new (std::addressof (key)) K ();
|
||||||
key = hb_coerce<K> (kINVALID);
|
key = hb_coerce<K> (kINVALID);
|
||||||
new (hb_addressof (value)) V ();
|
new (std::addressof (value)) V ();
|
||||||
value = hb_coerce<V> (vINVALID);
|
value = hb_coerce<V> (vINVALID);
|
||||||
hash = 0;
|
hash = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -85,22 +85,6 @@ template <> struct hb_priority<0> {};
|
||||||
template <typename T> struct hb_type_identity_t { typedef T type; };
|
template <typename T> struct hb_type_identity_t { typedef T type; };
|
||||||
template <typename T> using hb_type_identity = typename hb_type_identity_t<T>::type;
|
template <typename T> using hb_type_identity = typename hb_type_identity_t<T>::type;
|
||||||
|
|
||||||
struct
|
|
||||||
{
|
|
||||||
template <typename T> constexpr T*
|
|
||||||
operator () (T& arg) const
|
|
||||||
{
|
|
||||||
#pragma GCC diagnostic push
|
|
||||||
#pragma GCC diagnostic ignored "-Wcast-align"
|
|
||||||
/* https://en.cppreference.com/w/cpp/memory/addressof */
|
|
||||||
return reinterpret_cast<T*> (
|
|
||||||
&const_cast<char&> (
|
|
||||||
reinterpret_cast<const volatile char&> (arg)));
|
|
||||||
#pragma GCC diagnostic pop
|
|
||||||
}
|
|
||||||
}
|
|
||||||
HB_FUNCOBJ (hb_addressof);
|
|
||||||
|
|
||||||
template <typename T> static inline T hb_declval ();
|
template <typename T> static inline T hb_declval ();
|
||||||
#define hb_declval(T) (hb_declval<T> ())
|
#define hb_declval(T) (hb_declval<T> ())
|
||||||
|
|
||||||
|
@ -157,7 +141,7 @@ struct
|
||||||
operator () (T&& v) const HB_AUTO_RETURN (std::forward<T> (v))
|
operator () (T&& v) const HB_AUTO_RETURN (std::forward<T> (v))
|
||||||
|
|
||||||
template <typename T> constexpr auto
|
template <typename T> constexpr auto
|
||||||
operator () (T& v) const HB_AUTO_RETURN (hb_addressof (v))
|
operator () (T& v) const HB_AUTO_RETURN (std::addressof (v))
|
||||||
}
|
}
|
||||||
HB_FUNCOBJ (hb_ref);
|
HB_FUNCOBJ (hb_ref);
|
||||||
|
|
||||||
|
@ -174,7 +158,7 @@ struct hb_reference_wrapper
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct hb_reference_wrapper<T&>
|
struct hb_reference_wrapper<T&>
|
||||||
{
|
{
|
||||||
hb_reference_wrapper (T& v) : v (hb_addressof (v)) {}
|
hb_reference_wrapper (T& v) : v (std::addressof (v)) {}
|
||||||
bool operator == (const hb_reference_wrapper& o) const { return v == o.v; }
|
bool operator == (const hb_reference_wrapper& o) const { return v == o.v; }
|
||||||
bool operator != (const hb_reference_wrapper& o) const { return v != o.v; }
|
bool operator != (const hb_reference_wrapper& o) const { return v != o.v; }
|
||||||
operator T& () const { return *v; }
|
operator T& () const { return *v; }
|
||||||
|
|
|
@ -1607,7 +1607,7 @@ struct cmap
|
||||||
unsigned format = (this + _.subtable).u.format;
|
unsigned format = (this + _.subtable).u.format;
|
||||||
if (format == 12) has_format12 = true;
|
if (format == 12) has_format12 = true;
|
||||||
|
|
||||||
const EncodingRecord *table = hb_addressof (_);
|
const EncodingRecord *table = std::addressof (_);
|
||||||
if (_.platformID == 0 && _.encodingID == 3) unicode_bmp = table;
|
if (_.platformID == 0 && _.encodingID == 3) unicode_bmp = table;
|
||||||
else if (_.platformID == 0 && _.encodingID == 4) unicode_ucs4 = table;
|
else if (_.platformID == 0 && _.encodingID == 4) unicode_ucs4 = table;
|
||||||
else if (_.platformID == 3 && _.encodingID == 1) ms_bmp = table;
|
else if (_.platformID == 3 && _.encodingID == 1) ms_bmp = table;
|
||||||
|
|
|
@ -43,7 +43,7 @@ HB_INTERNAL void PaintColrLayers::closurev1 (hb_colrv1_closure_context_t* c) con
|
||||||
const LayerList &paint_offset_lists = c->get_colr_table ()->get_layerList ();
|
const LayerList &paint_offset_lists = c->get_colr_table ()->get_layerList ();
|
||||||
for (unsigned i = firstLayerIndex; i < firstLayerIndex + numLayers; i++)
|
for (unsigned i = firstLayerIndex; i < firstLayerIndex + numLayers; i++)
|
||||||
{
|
{
|
||||||
const Paint &paint = hb_addressof (paint_offset_lists) + paint_offset_lists[i];
|
const Paint &paint = std::addressof (paint_offset_lists) + paint_offset_lists[i];
|
||||||
paint.dispatch (c);
|
paint.dispatch (c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -256,7 +256,7 @@ struct name
|
||||||
})
|
})
|
||||||
;
|
;
|
||||||
|
|
||||||
name_prime->serialize (c->serializer, it, hb_addressof (this + stringOffset));
|
name_prime->serialize (c->serializer, it, std::addressof (this + stringOffset));
|
||||||
return_trace (name_prime->count);
|
return_trace (name_prime->count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -510,7 +510,7 @@ struct hb_serialize_context_t
|
||||||
{ return reinterpret_cast<Type *> (this->head); }
|
{ return reinterpret_cast<Type *> (this->head); }
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type *start_embed (const Type &obj) const
|
Type *start_embed (const Type &obj) const
|
||||||
{ return start_embed (hb_addressof (obj)); }
|
{ return start_embed (std::addressof (obj)); }
|
||||||
|
|
||||||
bool err (hb_serialize_error_t err_type)
|
bool err (hb_serialize_error_t err_type)
|
||||||
{
|
{
|
||||||
|
@ -548,7 +548,7 @@ struct hb_serialize_context_t
|
||||||
}
|
}
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type *embed (const Type &obj)
|
Type *embed (const Type &obj)
|
||||||
{ return embed (hb_addressof (obj)); }
|
{ return embed (std::addressof (obj)); }
|
||||||
|
|
||||||
template <typename Type, typename ...Ts> auto
|
template <typename Type, typename ...Ts> auto
|
||||||
_copy (const Type &src, hb_priority<1>, Ts&&... ds) HB_RETURN
|
_copy (const Type &src, hb_priority<1>, Ts&&... ds) HB_RETURN
|
||||||
|
@ -595,19 +595,19 @@ struct hb_serialize_context_t
|
||||||
}
|
}
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type *extend_size (Type &obj, size_t size)
|
Type *extend_size (Type &obj, size_t size)
|
||||||
{ return extend_size (hb_addressof (obj), size); }
|
{ return extend_size (std::addressof (obj), size); }
|
||||||
|
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type *extend_min (Type *obj) { return extend_size (obj, obj->min_size); }
|
Type *extend_min (Type *obj) { return extend_size (obj, obj->min_size); }
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type *extend_min (Type &obj) { return extend_min (hb_addressof (obj)); }
|
Type *extend_min (Type &obj) { return extend_min (std::addressof (obj)); }
|
||||||
|
|
||||||
template <typename Type, typename ...Ts>
|
template <typename Type, typename ...Ts>
|
||||||
Type *extend (Type *obj, Ts&&... ds)
|
Type *extend (Type *obj, Ts&&... ds)
|
||||||
{ return extend_size (obj, obj->get_size (std::forward<Ts> (ds)...)); }
|
{ return extend_size (obj, obj->get_size (std::forward<Ts> (ds)...)); }
|
||||||
template <typename Type, typename ...Ts>
|
template <typename Type, typename ...Ts>
|
||||||
Type *extend (Type &obj, Ts&&... ds)
|
Type *extend (Type &obj, Ts&&... ds)
|
||||||
{ return extend (hb_addressof (obj), std::forward<Ts> (ds)...); }
|
{ return extend (std::addressof (obj), std::forward<Ts> (ds)...); }
|
||||||
|
|
||||||
/* Output routines. */
|
/* Output routines. */
|
||||||
hb_bytes_t copy_bytes () const
|
hb_bytes_t copy_bytes () const
|
||||||
|
|
Loading…
Reference in New Issue