]> granicus.if.org Git - clang/commitdiff
Further testing for instantiation of out-of-line constexpr static data member
authorRichard Smith <richard-llvm@metafoo.co.uk>
Thu, 19 Jan 2012 22:50:02 +0000 (22:50 +0000)
committerRichard Smith <richard-llvm@metafoo.co.uk>
Thu, 19 Jan 2012 22:50:02 +0000 (22:50 +0000)
template definitions.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@148506 91177308-0d34-0410-b5e6-96231b3b80d8

test/CXX/class/class.static/class.static.data/p3.cpp

index 4d5ac470a0c051c2b2653d7952cd6406b0c72036..fed715e2190918ca2adff5b68d31affdaf52a86e 100644 (file)
@@ -32,9 +32,14 @@ struct U {
   // FIXME: It'd be nice to error on this at template definition time.
   static constexpr NonLit h = NonLit(); // expected-error 2{{must be initialized by a constant expression}} expected-note 2{{non-literal type}}
   static constexpr T c = T(); // expected-error {{must be initialized by a constant expression}} expected-note {{non-literal type}}
+  static const T d;
 };
 
+template<typename T> constexpr T U<T>::d = T(); // expected-error {{must be initialized by a constant expression}} expected-note {{non-literal type 'const NonLit'}}
+
 U<int> u1; // expected-note {{here}}
 U<NonLit> u2; // expected-note {{here}}
 
 static_assert(U<int>::a == 0, "");
+
+constexpr int outofline = (U<NonLit>::d, 0); // expected-note {{here}} expected-warning {{unused}}