diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2012-10-03 21:05:51 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2012-10-03 21:05:51 +0000 |
commit | 3da76bfbd24b2747ceb72d1918bbbe3123dac841 (patch) | |
tree | a33af700688b2d41830a9fea8b34aa4ec17d8834 /tools/libclang/Indexing.cpp | |
parent | 37f2f52fbc16b0d426d4d86c7e1662e5c6b9e3b8 (diff) |
[libclang] When indexing, invoke the importedASTFile for PCH files as well.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@165161 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/libclang/Indexing.cpp')
-rw-r--r-- | tools/libclang/Indexing.cpp | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/tools/libclang/Indexing.cpp b/tools/libclang/Indexing.cpp index 6cf3a637ac..0b12d82d30 100644 --- a/tools/libclang/Indexing.cpp +++ b/tools/libclang/Indexing.cpp @@ -197,13 +197,20 @@ public: virtual ASTConsumer *CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { + PreprocessorOptions &PPOpts = CI.getPreprocessorOpts(); + // We usually disable the preprocessing record for indexing even if the // original preprocessing options had it enabled. Now that the indexing // Preprocessor has been created (without a preprocessing record), re-enable // the option in case modules are enabled, so that the detailed record // option can be propagated when the module file is generated. if (CI.getLangOpts().Modules && EnablePPDetailedRecordForModules) - CI.getPreprocessorOpts().DetailedRecord = true; + PPOpts.DetailedRecord = true; + + if (!PPOpts.ImplicitPCHInclude.empty()) { + IndexCtx.importedPCH( + CI.getFileManager().getFile(PPOpts.ImplicitPCHInclude)); + } IndexCtx.setASTContext(CI.getASTContext()); Preprocessor &PP = CI.getPreprocessor(); @@ -536,6 +543,9 @@ static void clang_indexTranslationUnit_Impl(void *UserData) { ASTUnit::ConcurrencyCheck Check(*Unit); + if (const FileEntry *PCHFile = Unit->getPCHFile()) + IndexCtx->importedPCH(PCHFile); + FileManager &FileMgr = Unit->getFileManager(); if (Unit->getOriginalSourceFileName().empty()) |