[PATCH] D66530: [clangd] Don't collect locations that implicitly refer to the target decl.
Haojian Wu via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Wed Aug 21 06:46:42 PDT 2019
hokein created this revision.
hokein added a reviewer: ilya-biryukov.
Herald added subscribers: kadircet, arphaman, jkorous, MaskRay.
Herald added a project: clang.
A followup of rL369514 <https://reviews.llvm.org/rL369514>, the previous patch was fix the
DeclarationAndMacrosFinder (we will not get decl from implicit
node under the cursor).
This patch is to fix ReferenceFinder (we will not collect implicit references).
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D66530
Files:
clang-tools-extra/clangd/XRefs.cpp
clang-tools-extra/clangd/unittests/XRefsTests.cpp
Index: clang-tools-extra/clangd/unittests/XRefsTests.cpp
===================================================================
--- clang-tools-extra/clangd/unittests/XRefsTests.cpp
+++ clang-tools-extra/clangd/unittests/XRefsTests.cpp
@@ -2080,7 +2080,18 @@
[[a]].operator bool();
if ([[a^]]) {} // ignore implicit conversion-operator AST node
}
- )cpp",
+ )cpp",
+ R"cpp(
+ struct X {
+ [[operator]] bool();
+ };
+
+ int test() {
+ X a;
+ a.[[oper^ator]] bool();
+ if (a) {}
+ }
+ )cpp",
};
for (const char *Test : Tests) {
Annotations T(Test);
Index: clang-tools-extra/clangd/XRefs.cpp
===================================================================
--- clang-tools-extra/clangd/XRefs.cpp
+++ clang-tools-extra/clangd/XRefs.cpp
@@ -129,6 +129,23 @@
return Merged.CanonicalDeclaration;
}
+// Returns true if the given expression is an implicit AST node.
+bool IsImplicitExpr(const Expr *E) {
+ if (!E)
+ return false;
+ // We assume that a constructor expression is implict (was inserted by
+ // clang) if it has an invalid paren/brace location, since such
+ // experssion is impossible to write down.
+ if (const auto *CtorExpr = dyn_cast<CXXConstructExpr>(E))
+ return CtorExpr->getParenOrBraceRange().isInvalid();
+ // Ignore implicit conversion-operator AST node.
+ if (const auto *ME = dyn_cast<MemberExpr>(E)) {
+ if (isa<CXXConversionDecl>(ME->getMemberDecl()))
+ return ME->getMemberLoc().isInvalid();
+ }
+ return isa<ImplicitCastExpr>(E);
+}
+
/// Finds declarations locations that a given source location refers to.
class DeclarationAndMacrosFinder : public index::IndexDataConsumer {
std::vector<DefinedMacro> MacroInfos;
@@ -179,22 +196,6 @@
return true;
if (Loc == SearchedLocation) {
- auto IsImplicitExpr = [](const Expr *E) {
- if (!E)
- return false;
- // We assume that a constructor expression is implict (was inserted by
- // clang) if it has an invalid paren/brace location, since such
- // experssion is impossible to write down.
- if (const auto *CtorExpr = dyn_cast<CXXConstructExpr>(E))
- return CtorExpr->getParenOrBraceRange().isInvalid();
- // Ignore implicit conversion-operator AST node.
- if (const auto *ME = dyn_cast<MemberExpr>(E)) {
- if (isa<CXXConversionDecl>(ME->getMemberDecl()))
- return ME->getMemberLoc().isInvalid();
- }
- return isa<ImplicitCastExpr>(E);
- };
-
if (IsImplicitExpr(ASTNode.OrigE))
return true;
// Find and add definition declarations (for GoToDefinition).
@@ -408,7 +409,8 @@
assert(D->isCanonicalDecl() && "expect D to be a canonical declaration");
const SourceManager &SM = AST.getSourceManager();
Loc = SM.getFileLoc(Loc);
- if (isInsideMainFile(Loc, SM) && CanonicalTargets.count(D))
+ if (isInsideMainFile(Loc, SM) && CanonicalTargets.count(D) &&
+ !IsImplicitExpr(ASTNode.OrigE))
References.push_back({Loc, Roles});
return true;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D66530.216387.patch
Type: text/x-patch
Size: 3128 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20190821/43df3fe0/attachment.bin>
More information about the cfe-commits
mailing list