From: Alex Lorenz Date: Tue, 23 May 2017 16:47:01 +0000 (+0000) Subject: [index] The references to enum constants from member enums that are X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=ac61568545c1f9af625962e4d5720a050ddf1ca4;p=clang [index] The references to enum constants from member enums that are from template instantiations should refer to the enum constant in the pattern enum in the base template rdar://32325459 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@303651 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Index/IndexingContext.cpp b/lib/Index/IndexingContext.cpp index 2f54667e85..754bc84ff4 100644 --- a/lib/Index/IndexingContext.cpp +++ b/lib/Index/IndexingContext.cpp @@ -130,7 +130,8 @@ bool IndexingContext::isTemplateImplicitInstantiation(const Decl *D) { } else if (const auto *ED = dyn_cast(D)) { if (ED->getInstantiatedFromMemberEnum()) TKind = ED->getTemplateSpecializationKind(); - } else if (isa(D) || isa(D)) { + } else if (isa(D) || isa(D) || + isa(D)) { if (const auto *Parent = dyn_cast(D->getDeclContext())) return isTemplateImplicitInstantiation(Parent); } @@ -193,6 +194,13 @@ static const Decl *adjustTemplateImplicitInstantiation(const Decl *D) { return BaseND; } } + } else if (const auto *ECD = dyn_cast(D)) { + if (const auto *ED = dyn_cast(ECD->getDeclContext())) { + if (const EnumDecl *Pattern = ED->getInstantiatedFromMemberEnum()) { + for (const NamedDecl *BaseECD : Pattern->lookup(ECD->getDeclName())) + return BaseECD; + } + } } return nullptr; } diff --git a/test/Index/Core/index-instantiated-source.cpp b/test/Index/Core/index-instantiated-source.cpp index 5cfdbac719..7a810fbdf3 100644 --- a/test/Index/Core/index-instantiated-source.cpp +++ b/test/Index/Core/index-instantiated-source.cpp @@ -46,6 +46,7 @@ public: enum Enum { // CHECK: [[@LINE-1]]:10 | enum/C | Enum | c:@ST>2#T#T@TemplateClass@S@NestedType@E@Enum | EnumCase +// CHECK: [[@LINE-1]]:7 | enumerator/C | EnumCase | c:@ST>2#T#T@TemplateClass@S@NestedType@E@Enum@EnumCase | }; }; }; @@ -82,4 +83,6 @@ void canonicalizeInstaniationReferences(TemplateClass &object) { TT::NestedType::Enum nestedEnum; // CHECK: [[@LINE-1]]:19 | enum/C | Enum | c:@ST>2#T#T@TemplateClass@S@NestedType@E@Enum | + (void)TT::NestedType::Enum::EnumCase; +// CHECK: [[@LINE-1]]:31 | enumerator/C | EnumCase | c:@ST>2#T#T@TemplateClass@S@NestedType@E@Enum@EnumCase | }