blob: 7c3ce66b4c913726cbb38b83de4134a8053f2fc8 [file] [log] [blame]
// PR c++/66477
// { dg-do compile { target c++11 } }
struct a { constexpr bool g() const { return true; } };
constexpr bool g(a&) { return true;}
constexpr bool h(a) { return true;}
a a1;
a& ar = a1;
void f(a ap, a& arp)
{
a a2;
a& ar2 = a2;
// Most of these are OK because no data is actually loaded.
static_assert (a1.g(),"");
static_assert (g(a1),"");
static_assert (h(a1),"");
static_assert (a2.g(),"");
static_assert (g(a2),"");
static_assert (h(a2),"");
static_assert (ap.g(),"");
static_assert (g(ap),"");
static_assert (h(ap),"");
static_assert (ar.g(),"");
static_assert (g(ar),"");
static_assert (h(ar),"");
// But these are specifically prohibited in [expr.const]/4.12:
// * an id-expression that refers to a variable or data member of reference
// type unless the reference has a preceding initialization and either
// ** it is usable in constant expressions or
// ** its lifetime began within the evaluation of e;
static_assert (ar2.g(),""); // { dg-error "constant" }
static_assert (g(ar2),""); // { dg-error "constant" }
static_assert (h(ar2),""); // { dg-error "constant" }
static_assert (arp.g(),""); // { dg-error "constant" }
static_assert (g(arp),""); // { dg-error "constant" }
static_assert (h(arp),""); // { dg-error "constant" }
}