Viewing file: addressof1.C (2.16 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
// LWG2296 - addressof should be constexpr // { dg-do run { target c++11 } }
template <typename T> constexpr inline T * addressof (T &x) noexcept { return __builtin_addressof (x); }
int i; static_assert (__builtin_addressof (i) == &i, ""); static_assert (addressof (i) == &i, "");
constexpr int &j = i; static_assert (__builtin_addressof (j) == &i, ""); static_assert (addressof (j) == &i, "");
struct S { int s; } s; static_assert (__builtin_addressof (s) == &s, ""); static_assert (addressof (s) == &s, "");
struct T { static T tt; constexpr T () : p (addressof (tt)) {} constexpr T *operator & () const { return p; } T *p; }; constexpr T t; T T::tt; static_assert (&t == __builtin_addressof (T::tt), ""); static_assert (&t == addressof (T::tt), "");
struct S x, y;
constexpr S * foo (bool b) { return __builtin_addressof (b ? x : y); }
constexpr S * bar (bool b, S &c, S &d) { return __builtin_addressof (b ? c : d); }
static_assert (foo (false) == &y, ""); static_assert (foo (true) == &x, ""); static_assert (bar (false, y, x) == &x, ""); static_assert (bar (true, y, x) == &y, "");
constexpr S * foo2 (bool b) { return addressof (b ? x : y); }
constexpr S * bar2 (bool b, S &c, S &d) { return addressof (b ? c : d); }
static_assert (foo2 (false) == &y, ""); static_assert (foo2 (true) == &x, ""); static_assert (bar2 (false, y, x) == &x, ""); static_assert (bar2 (true, y, x) == &y, "");
constexpr int a = 1; static_assert (__builtin_addressof (a) == &a, ""); static_assert (addressof (a) == &a, ""); constexpr int c[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
void baz () { }
int main () { if (__builtin_addressof (T::tt) == __builtin_addressof (t) || addressof (T::tt) == addressof (t) || &T::tt != &t || __builtin_addressof (baz) != baz || addressof (baz) != baz) __builtin_abort ();
// reinterpret casts are not constexprs if (! (((int *) __builtin_addressof (s) == &s.s) && ((int *) addressof (s) == &s.s) && (__builtin_addressof (t) == (const T *) &t.p) && (addressof (t) == (const T *) &t.p) && ((const int *) __builtin_addressof (c) == &c[0]) && ((const int *) addressof (c) == &c[0]))) __builtin_abort ();
return 0; }
|