diff --git a/clang-tools-extra/clangd/XRefs.cpp b/clang-tools-extra/clangd/XRefs.cpp --- a/clang-tools-extra/clangd/XRefs.cpp +++ b/clang-tools-extra/clangd/XRefs.cpp @@ -1140,11 +1140,18 @@ } else { // Handle references to Decls. - // We also show references to the targets of using-decls, so we include - // DeclRelation::Underlying. - DeclRelationSet Relations = DeclRelation::TemplatePattern | - DeclRelation::Alias | DeclRelation::Underlying; + DeclRelationSet Relations = + DeclRelation::TemplatePattern | DeclRelation::Alias; auto Decls = getDeclAtPosition(AST, *CurLoc, Relations); + // If the results include a *non-renaming* alias, get its + // underlying decls as well. (See similar logic in locateASTReferent()). + for (const NamedDecl *D : Decls) { + if (llvm::isa(D) || llvm::isa(D)) { + Decls = getDeclAtPosition(AST, *CurLoc, + Relations | DeclRelation::Underlying); + break; + } + } // We traverse the AST to find references in the main file. auto MainFileRefs = findRefs(Decls, AST); diff --git a/clang-tools-extra/clangd/unittests/XRefsTests.cpp b/clang-tools-extra/clangd/unittests/XRefsTests.cpp --- a/clang-tools-extra/clangd/unittests/XRefsTests.cpp +++ b/clang-tools-extra/clangd/unittests/XRefsTests.cpp @@ -1582,6 +1582,13 @@ f.[[^~]]Foo(); } )cpp", + R"cpp(// Renaming alias + template class Vector {}; + using [[^X]] = Vector; + [[X]] x1; + Vector x2; + Vector y; + )cpp", }; for (const char *Test : Tests) { Annotations T(Test);