56 lines
1.9 KiB
C++
56 lines
1.9 KiB
C++
|
// 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>;
|
||
|
}
|