From 1d4b2e16a2bc20356e1c79e3115217a80c6104af Mon Sep 17 00:00:00 2001 From: Richard Smith Date: Mon, 1 Apr 2013 21:43:41 +0000 Subject: PR15633: Note that we are EnteringContext when parsing the nested name specifier for an enumeration. Also fix a crash-on-invalid if a non-dependent name specifier is used to declare an enum template. llvm-svn: 178502 --- clang/test/SemaCXX/enum-scoped.cpp | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'clang/test/SemaCXX/enum-scoped.cpp') diff --git a/clang/test/SemaCXX/enum-scoped.cpp b/clang/test/SemaCXX/enum-scoped.cpp index a1f911d79d3..d01000d22bb 100644 --- a/clang/test/SemaCXX/enum-scoped.cpp +++ b/clang/test/SemaCXX/enum-scoped.cpp @@ -252,3 +252,17 @@ namespace pr13128 { enum class E { C }; }; } + +namespace PR15633 { + template struct A { + struct B { + enum class E : T; + enum class E2 : T; + }; + }; + template enum class A::B::E { e }; + template class A; + + struct B { enum class E; }; + template enum class B::E { e }; // expected-error {{enumeration cannot be a template}} +} -- cgit v1.2.3