blob: 660e70549e30f93c94ce4c5fc1056c6cf794185d [file] [log] [blame]
// RUN: %clang_cc1 -triple x86_64-linux-gnu -fsyntax-only -verify -std=c++11 %s
// Make sure we handle contexts correctly with sizeof
template<typename T> void f(T n) {
int buffer[n];
[] { int x = sizeof(sizeof(buffer)); }();
}
int main() {
f<int>(1);
}
// Make sure we handle references to non-static data members in unevaluated
// contexts in class template methods correctly. Previously we assumed these
// would be valid MemberRefExprs, but they have no 'this' so we need to form a
// DeclRefExpr to the FieldDecl instead.
// PR26893
template <class T>
struct M {
M() {}; // expected-note {{in instantiation of default member initializer 'M<S>::m' requested here}}
int m = *T::x; // expected-error {{invalid use of non-static data member 'x'}}
void f() {
// These are valid.
static_assert(sizeof(T::x) == 8, "ptr");
static_assert(sizeof(*T::x) == 4, "int");
}
};
struct S { int *x; };
template struct M<S>; // expected-note {{in instantiation of member function 'M<S>::M' requested here}}
// Similar test case for PR26893.
template <typename T=void>
struct bar {
struct foo { int array[10]; };
int baz() { return sizeof(foo::array); }
};
template struct bar<>;