kadircet created this revision. kadircet added reviewers: usaxena95, nridge. Herald added a subscriber: arphaman. kadircet requested review of this revision. Herald added subscribers: cfe-commits, MaskRay, ilya-biryukov. Herald added a project: clang-tools-extra.
If the main file is a header, mark the marcos defined in its preamble section as code-completion ready. Fixes https://github.com/clangd/clangd/issues/921. Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D113555 Files: clang-tools-extra/clangd/index/SymbolCollector.cpp clang-tools-extra/clangd/unittests/FileIndexTests.cpp Index: clang-tools-extra/clangd/unittests/FileIndexTests.cpp =================================================================== --- clang-tools-extra/clangd/unittests/FileIndexTests.cpp +++ clang-tools-extra/clangd/unittests/FileIndexTests.cpp @@ -727,6 +727,19 @@ EXPECT_THAT(MT.child("f3").children(), ElementsAre(Pair("relations", _))); EXPECT_THAT(MT.child("f3").total(), Gt(0U)); } + +TEST(FileIndexTest, MacrosFromMainFile) { + FileIndex Idx; + TestTU TU; + TU.Code = "#pragma once\n#define FOO"; + TU.Filename = "foo.h"; + auto AST = TU.build(); + Idx.updateMain(testPath(TU.Filename), AST); + + auto &FooSymbol = findSymbol(runFuzzyFind(Idx, ""), "FOO"); + EXPECT_TRUE(FooSymbol.Flags & Symbol::IndexedForCodeCompletion); +} + } // namespace } // namespace clangd } // namespace clang Index: clang-tools-extra/clangd/index/SymbolCollector.cpp =================================================================== --- clang-tools-extra/clangd/index/SymbolCollector.cpp +++ clang-tools-extra/clangd/index/SymbolCollector.cpp @@ -564,6 +564,10 @@ S.SymInfo.Lang = index::SymbolLanguage::C; S.Origin = Opts.Origin; S.CanonicalDeclaration = R.Location; + if (!HeaderFileURIs->getIncludeHeader(SM.getMainFileID()).empty()) { + S.Flags |= Symbol::IndexedForCodeCompletion; + S.Flags |= Symbol::VisibleOutsideFile; + } Symbols.insert(S); } }
Index: clang-tools-extra/clangd/unittests/FileIndexTests.cpp =================================================================== --- clang-tools-extra/clangd/unittests/FileIndexTests.cpp +++ clang-tools-extra/clangd/unittests/FileIndexTests.cpp @@ -727,6 +727,19 @@ EXPECT_THAT(MT.child("f3").children(), ElementsAre(Pair("relations", _))); EXPECT_THAT(MT.child("f3").total(), Gt(0U)); } + +TEST(FileIndexTest, MacrosFromMainFile) { + FileIndex Idx; + TestTU TU; + TU.Code = "#pragma once\n#define FOO"; + TU.Filename = "foo.h"; + auto AST = TU.build(); + Idx.updateMain(testPath(TU.Filename), AST); + + auto &FooSymbol = findSymbol(runFuzzyFind(Idx, ""), "FOO"); + EXPECT_TRUE(FooSymbol.Flags & Symbol::IndexedForCodeCompletion); +} + } // namespace } // namespace clangd } // namespace clang Index: clang-tools-extra/clangd/index/SymbolCollector.cpp =================================================================== --- clang-tools-extra/clangd/index/SymbolCollector.cpp +++ clang-tools-extra/clangd/index/SymbolCollector.cpp @@ -564,6 +564,10 @@ S.SymInfo.Lang = index::SymbolLanguage::C; S.Origin = Opts.Origin; S.CanonicalDeclaration = R.Location; + if (!HeaderFileURIs->getIncludeHeader(SM.getMainFileID()).empty()) { + S.Flags |= Symbol::IndexedForCodeCompletion; + S.Flags |= Symbol::VisibleOutsideFile; + } Symbols.insert(S); } }
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits