|  | // 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) { // expected-note {{declared here}} | 
|  | int buffer[n]; // expected-warning {{variable length arrays in C++ are a Clang extension}} \ | 
|  | expected-note {{function parameter 'n' with unknown value cannot be used in a constant expression}} \ | 
|  | expected-note@#instantiate {{in instantiation of function template specialization 'f<int>' requested here}} | 
|  | [] { int x = sizeof(sizeof(buffer)); }(); | 
|  | } | 
|  | int main() { | 
|  | f<int>(1); // #instantiate | 
|  | } | 
|  |  | 
|  | // 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<>; |