|  | // RUN: %clang_cc1 -Wno-uninitialized -fsyntax-only -verify -std=c++11 -Wno-error=static-float-init %s | 
|  |  | 
|  | int vs = 0; | 
|  |  | 
|  | class C { | 
|  | public: | 
|  | struct NestedC { | 
|  | NestedC(int); | 
|  | }; | 
|  |  | 
|  | int i = 0; | 
|  | static int si = 0; // expected-error {{non-const static data member must be initialized out of line}} | 
|  | static const NestedC ci = 0; // expected-error {{static data member of type 'const C::NestedC' must be initialized out of line}} | 
|  | static const int nci = vs; // expected-error {{in-class initializer for static data member is not a constant expression}} | 
|  | static const int vi = 0; | 
|  | static const volatile int cvi = 0; // expected-error {{static const volatile data member must be initialized out of line}} | 
|  | }; | 
|  |  | 
|  | namespace rdar8367341 { | 
|  | float foo(); // expected-note {{here}} | 
|  |  | 
|  | struct A { | 
|  | static const float x = 5.0f; // expected-warning {{requires 'constexpr'}} expected-note {{add 'constexpr'}} | 
|  | static const float y = foo(); // expected-warning {{requires 'constexpr'}} expected-note {{add 'constexpr'}} | 
|  | static constexpr float x2 = 5.0f; | 
|  | static constexpr float y2 = foo(); // expected-error {{must be initialized by a constant expression}} expected-note {{non-constexpr function 'foo'}} | 
|  | }; | 
|  | } | 
|  |  | 
|  |  | 
|  | namespace Foo { | 
|  | // Regression test -- forward declaration of Foo should not cause error about | 
|  | // nonstatic data member. | 
|  | class Foo; | 
|  | class Foo { | 
|  | int x; | 
|  | int y = x; | 
|  | }; | 
|  | } | 
|  |  | 
|  | // Instantiating another default member initializer while parsing one should | 
|  | // not cause us to mess up the 'this' override. | 
|  | template<typename> struct DefaultMemberTemplate { int n = 0; }; | 
|  | class DefaultMemberInitSelf { | 
|  | DefaultMemberTemplate<int> t = {}; | 
|  | int *p = &t.n; | 
|  | }; | 
|  |  | 
|  | namespace composed_templates { | 
|  | // Regression test -- obtaining the type from composed templates should not | 
|  | // require out-of-line definition. | 
|  | template <typename T> struct Zero { static const typename T::type value = 0; }; | 
|  | struct Integer { using type = int; }; | 
|  | template struct Zero<Integer>; | 
|  | } |