[PATCH] D150124: [index][clangd] Consider labels when indexing function bodies
Christian Kandeler via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Fri Jul 28 01:26:03 PDT 2023
ckandeler updated this revision to Diff 545054.
ckandeler added a comment.
Addressed review comment.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D150124/new/
https://reviews.llvm.org/D150124
Files:
clang-tools-extra/clangd/unittests/XRefsTests.cpp
clang/lib/Index/IndexBody.cpp
clang/unittests/Index/IndexTests.cpp
Index: clang/unittests/Index/IndexTests.cpp
===================================================================
--- clang/unittests/Index/IndexTests.cpp
+++ clang/unittests/Index/IndexTests.cpp
@@ -218,6 +218,28 @@
EXPECT_THAT(Index->Symbols, Not(Contains(QName("bar"))));
}
+TEST(IndexTest, IndexLabels) {
+ std::string Code = R"cpp(
+ int main() {
+ goto theLabel;
+ theLabel:
+ return 1;
+ }
+ )cpp";
+ auto Index = std::make_shared<Indexer>();
+ IndexingOptions Opts;
+ Opts.IndexFunctionLocals = true;
+ tooling::runToolOnCode(std::make_unique<IndexAction>(Index, Opts), Code);
+ EXPECT_THAT(Index->Symbols,
+ Contains(AllOf(QName("theLabel"), WrittenAt(Position(3, 16)),
+ DeclAt(Position(4, 11)))));
+
+ Opts.IndexFunctionLocals = false;
+ Index->Symbols.clear();
+ tooling::runToolOnCode(std::make_unique<IndexAction>(Index, Opts), Code);
+ EXPECT_THAT(Index->Symbols, Not(Contains(QName("theLabel"))));
+}
+
TEST(IndexTest, IndexExplicitTemplateInstantiation) {
std::string Code = R"cpp(
template <typename T>
Index: clang/lib/Index/IndexBody.cpp
===================================================================
--- clang/lib/Index/IndexBody.cpp
+++ clang/lib/Index/IndexBody.cpp
@@ -144,6 +144,18 @@
Parent, ParentDC, Roles, Relations, E);
}
+ bool VisitGotoStmt(GotoStmt *S) {
+ return IndexCtx.handleReference(S->getLabel(), S->getLabelLoc(), Parent,
+ ParentDC,
+ unsigned(SymbolRole::NameReference));
+ }
+
+ bool VisitLabelStmt(LabelStmt *S) {
+ if (IndexCtx.shouldIndexFunctionLocalSymbols())
+ return IndexCtx.handleDecl(S->getDecl());
+ return true;
+ }
+
bool VisitMemberExpr(MemberExpr *E) {
SourceLocation Loc = E->getMemberLoc();
if (Loc.isInvalid())
Index: clang-tools-extra/clangd/unittests/XRefsTests.cpp
===================================================================
--- clang-tools-extra/clangd/unittests/XRefsTests.cpp
+++ clang-tools-extra/clangd/unittests/XRefsTests.cpp
@@ -125,6 +125,13 @@
[Foo [[x]]:2 [[^y]]:4];
}
)cpp",
+ R"cpp( // Label
+ int main() {
+ goto [[^theLabel]];
+ [[theLabel]]:
+ return 1;
+ }
+ )cpp",
};
for (const char *Test : Tests) {
Annotations T(Test);
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D150124.545054.patch
Type: text/x-patch
Size: 2464 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20230728/81aff7a1/attachment.bin>
More information about the cfe-commits
mailing list