[cfe-commits] r83904 - /cfe/trunk/test/CXX/temp/temp.spec/temp.expl.spec/p15.cpp

Douglas Gregor dgregor at apple.com
Mon Oct 12 14:38:00 PDT 2009


Author: dgregor
Date: Mon Oct 12 16:37:59 2009
New Revision: 83904

URL: http://llvm.org/viewvc/llvm-project?rev=83904&view=rev
Log:
Test explicit specializations of static data members that are declarations, not definitions

Added:
    cfe/trunk/test/CXX/temp/temp.spec/temp.expl.spec/p15.cpp

Added: cfe/trunk/test/CXX/temp/temp.spec/temp.expl.spec/p15.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CXX/temp/temp.spec/temp.expl.spec/p15.cpp?rev=83904&view=auto

==============================================================================
--- cfe/trunk/test/CXX/temp/temp.spec/temp.expl.spec/p15.cpp (added)
+++ cfe/trunk/test/CXX/temp/temp.spec/temp.expl.spec/p15.cpp Mon Oct 12 16:37:59 2009
@@ -0,0 +1,22 @@
+// RUN: clang-cc -fsyntax-only -verify %s
+
+struct NonDefaultConstructible {
+  NonDefaultConstructible(const NonDefaultConstructible&);
+};
+
+template<typename T, typename U>
+struct X {
+  static T member;
+};
+
+template<typename T, typename U>
+T X<T, U>::member; // expected-error{{no matching constructor}}
+
+// Okay; this is a declaration, not a definition.
+template<>
+NonDefaultConstructible X<NonDefaultConstructible, long>::member;
+
+NonDefaultConstructible &test(bool b) {
+  return b? X<NonDefaultConstructible, int>::member // expected-note{{instantiation}}
+          : X<NonDefaultConstructible, long>::member;
+}





More information about the cfe-commits mailing list