diff options
| author | Richard Smith <richard-llvm@metafoo.co.uk> | 2017-01-04 23:45:01 +0000 |
|---|---|---|
| committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2017-01-04 23:45:01 +0000 |
| commit | ece4758bf28b5be96ef0123ad79456a13e8518a1 (patch) | |
| tree | 7e0b2b55ba718ac6bc98546707624ba8bdfb40db | |
| parent | dd9c27b3bf77b947ba0bb08ed1ba1ae673b9f067 (diff) | |
| download | bcm5719-llvm-ece4758bf28b5be96ef0123ad79456a13e8518a1.tar.gz bcm5719-llvm-ece4758bf28b5be96ef0123ad79456a13e8518a1.zip | |
Only instantiate members of nested classes in local classes once, rather than once per enclosing class.
llvm-svn: 291034
| -rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateDecl.cpp | 7 | ||||
| -rw-r--r-- | clang/test/SemaTemplate/instantiate-local-class.cpp | 11 |
2 files changed, 16 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp index 7328dcb8760..3cc938106d8 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp @@ -1470,8 +1470,11 @@ Decl *TemplateDeclInstantiator::VisitCXXRecordDecl(CXXRecordDecl *D) { TSK_ImplicitInstantiation, /*Complain=*/true); - SemaRef.InstantiateClassMembers(D->getLocation(), Record, TemplateArgs, - TSK_ImplicitInstantiation); + // For nested local classes, we will instantiate the members when we + // reach the end of the outermost (non-nested) local class. + if (!D->isCXXClassMember()) + SemaRef.InstantiateClassMembers(D->getLocation(), Record, TemplateArgs, + TSK_ImplicitInstantiation); // This class may have local implicit instantiations that need to be // performed within this scope. diff --git a/clang/test/SemaTemplate/instantiate-local-class.cpp b/clang/test/SemaTemplate/instantiate-local-class.cpp index a61af7a5af3..eaff4c4bbc8 100644 --- a/clang/test/SemaTemplate/instantiate-local-class.cpp +++ b/clang/test/SemaTemplate/instantiate-local-class.cpp @@ -475,3 +475,14 @@ namespace rdar23721638 { } template void bar<A>(); // expected-note {{in instantiation}} } + +namespace anon_union_default_member_init { + template<typename T> void f() { + struct S { + union { + int i = 0; + }; + }; + } + void g() { f<int>(); } +} |

