// 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<>;