//===---------- IncludeInserter.h - clang-tidy ----------------------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_INCLUDEINSERTER_H #define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_INCLUDEINSERTER_H #include "IncludeSorter.h" #include "clang/Basic/Diagnostic.h" #include "clang/Basic/LangOptions.h" #include "clang/Basic/SourceManager.h" #include "clang/Lex/PPCallbacks.h" #include #include namespace clang { namespace tidy { namespace utils { /// \brief Produces fixes to insert specified includes to source files, if not /// yet present. /// /// ``IncludeInserter`` can be used in clang-tidy checks in the following way: /// \code /// #include "../utils/IncludeInserter.h" /// #include "clang/Frontend/CompilerInstance.h" /// /// class MyCheck : public ClangTidyCheck { /// public: /// void registerPPCallbacks(CompilerInstance& Compiler) override { /// Inserter = llvm::make_unique(&Compiler.getSourceManager(), /// &Compiler.getLangOpts()); /// Compiler.getPreprocessor().addPPCallbacks( /// Inserter->CreatePPCallbacks()); /// } /// /// void registerMatchers(ast_matchers::MatchFinder* Finder) override { ... } /// /// void check( /// const ast_matchers::MatchFinder::MatchResult& Result) override { /// ... /// Inserter->CreateIncludeInsertion( /// Result.SourceManager->getMainFileID(), "path/to/Header.h", /// /*IsAngled=*/false); /// ... /// } /// /// private: /// std::unique_ptr Inserter; /// }; /// \endcode class IncludeInserter { public: IncludeInserter(const SourceManager &SourceMgr, const LangOptions &LangOpts, IncludeSorter::IncludeStyle Style); ~IncludeInserter(); /// Create ``PPCallbacks`` for registration with the compiler's preprocessor. std::unique_ptr CreatePPCallbacks(); /// Creates a \p Header inclusion directive fixit. Returns ``llvm::None`` on /// error or if inclusion directive already exists. llvm::Optional CreateIncludeInsertion(FileID FileID, llvm::StringRef Header, bool IsAngled); private: void AddInclude(StringRef FileName, bool IsAngled, SourceLocation HashLocation, SourceLocation EndLocation); llvm::DenseMap> IncludeSorterByFile; llvm::DenseMap> InsertedHeaders; const SourceManager &SourceMgr; const LangOptions &LangOpts; const IncludeSorter::IncludeStyle Style; friend class IncludeInserterCallback; }; } // namespace utils } // namespace tidy } // namespace clang #endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_INCLUDEINSERTER_H