Skip to content

Commit

Permalink
[clang][Index] Add a knob to index function parameters in declarations
Browse files Browse the repository at this point in the history
Summary:
Parameters in declarations are useful for clangd, so that we can
provide symbol information for them as well. It also helps clangd to be
consistent whether a function's definition is accessible or not.

Reviewers: hokein, akyrtzi

Subscribers: ilya-biryukov, ioeric, arphaman, cfe-commits

Tags: #clang

Differential Revision: https://reviews.llvm.org/D57949

llvm-svn: 353695
  • Loading branch information
kadircet committed Feb 11, 2019
1 parent cf13bfe commit 0468fc0
Show file tree
Hide file tree
Showing 5 changed files with 27 additions and 4 deletions.
2 changes: 2 additions & 0 deletions clang/include/clang/Index/IndexingAction.h
Expand Up @@ -44,6 +44,8 @@ struct IndexingOptions {
// callback is not available (e.g. after parsing has finished). Note that
// macro references are not available in Proprocessor.
bool IndexMacrosInPreprocessor = false;
// Has no effect if IndexFunctionLocals are false.
bool IndexParametersInDeclarations = false;
};

/// Creates a frontend action that indexes all symbols (macros and AST decls).
Expand Down
8 changes: 4 additions & 4 deletions clang/lib/Index/IndexDecl.cpp
Expand Up @@ -88,12 +88,11 @@ class IndexingDeclVisitor : public ConstDeclVisitor<IndexingDeclVisitor, bool> {
/*isBase=*/false, isIBType);
IndexCtx.indexNestedNameSpecifierLoc(D->getQualifierLoc(), Parent);
if (IndexCtx.shouldIndexFunctionLocalSymbols()) {
// Only index parameters in definitions, parameters in declarations are
// not useful.
if (const ParmVarDecl *Parm = dyn_cast<ParmVarDecl>(D)) {
auto *DC = Parm->getDeclContext();
if (auto *FD = dyn_cast<FunctionDecl>(DC)) {
if (FD->isThisDeclarationADefinition())
if (IndexCtx.shouldIndexParametersInDeclarations() ||
FD->isThisDeclarationADefinition())
IndexCtx.handleDecl(Parm);
} else if (auto *MD = dyn_cast<ObjCMethodDecl>(DC)) {
if (MD->isThisDeclarationADefinition())
Expand All @@ -102,7 +101,8 @@ class IndexingDeclVisitor : public ConstDeclVisitor<IndexingDeclVisitor, bool> {
IndexCtx.handleDecl(Parm);
}
} else if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {
if (FD->isThisDeclarationADefinition()) {
if (IndexCtx.shouldIndexParametersInDeclarations() ||
FD->isThisDeclarationADefinition()) {
for (auto PI : FD->parameters()) {
IndexCtx.handleDecl(PI);
}
Expand Down
4 changes: 4 additions & 0 deletions clang/lib/Index/IndexingContext.cpp
Expand Up @@ -40,6 +40,10 @@ bool IndexingContext::shouldIndexImplicitInstantiation() const {
return IndexOpts.IndexImplicitInstantiation;
}

bool IndexingContext::shouldIndexParametersInDeclarations() const {
return IndexOpts.IndexParametersInDeclarations;
}

bool IndexingContext::handleDecl(const Decl *D,
SymbolRoleSet Roles,
ArrayRef<SymbolRelation> Relations) {
Expand Down
2 changes: 2 additions & 0 deletions clang/lib/Index/IndexingContext.h
Expand Up @@ -61,6 +61,8 @@ class IndexingContext {

bool shouldIndexImplicitInstantiation() const;

bool shouldIndexParametersInDeclarations() const;

static bool isTemplateImplicitInstantiation(const Decl *D);

bool handleDecl(const Decl *D, SymbolRoleSet Roles = SymbolRoleSet(),
Expand Down
15 changes: 15 additions & 0 deletions clang/unittests/Index/IndexTests.cpp
Expand Up @@ -119,6 +119,21 @@ TEST(IndexTest, IndexPreprocessorMacros) {
EXPECT_THAT(Index->Symbols, UnorderedElementsAre());
}

TEST(IndexTest, IndexParametersInDecls) {
std::string Code = "void foo(int bar);";
auto Index = std::make_shared<Indexer>();
IndexingOptions Opts;
Opts.IndexFunctionLocals = true;
Opts.IndexParametersInDeclarations = true;
tooling::runToolOnCode(new IndexAction(Index, Opts), Code);
EXPECT_THAT(Index->Symbols, Contains(QName("bar")));

Opts.IndexParametersInDeclarations = false;
Index->Symbols.clear();
tooling::runToolOnCode(new IndexAction(Index, Opts), Code);
EXPECT_THAT(Index->Symbols, Not(Contains(QName("bar"))));
}

} // namespace
} // namespace index
} // namespace clang

0 comments on commit 0468fc0

Please sign in to comment.