|  | //===--- IncludeCleaner.h - Unused/Missing Headers Analysis -----*- C++ -*-===// | 
|  | // | 
|  | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. | 
|  | // See https://llvm.org/LICENSE.txt for license information. | 
|  | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | /// | 
|  | /// \file | 
|  | /// Include Cleaner is clangd functionality for providing diagnostics for misuse | 
|  | /// of transitive headers and unused includes. It is inspired by | 
|  | /// Include-What-You-Use tool (https://include-what-you-use.org/). Our goal is | 
|  | /// to provide useful warnings in most popular scenarios but not 1:1 exact | 
|  | /// feature compatibility. | 
|  | /// | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_INCLUDECLEANER_H | 
|  | #define LLVM_CLANG_TOOLS_EXTRA_CLANGD_INCLUDECLEANER_H | 
|  |  | 
|  | #include "Diagnostics.h" | 
|  | #include "Headers.h" | 
|  | #include "ParsedAST.h" | 
|  | #include "Protocol.h" | 
|  | #include "clang-include-cleaner/Types.h" | 
|  | #include "clang/Basic/SourceManager.h" | 
|  | #include "clang/Tooling/Syntax/Tokens.h" | 
|  | #include "llvm/ADT/ArrayRef.h" | 
|  | #include "llvm/ADT/StringRef.h" | 
|  | #include <functional> | 
|  | #include <optional> | 
|  | #include <string> | 
|  | #include <tuple> | 
|  | #include <vector> | 
|  |  | 
|  | namespace clang { | 
|  | namespace clangd { | 
|  |  | 
|  | // Data needed for missing include diagnostics. | 
|  | struct MissingIncludeDiagInfo { | 
|  | include_cleaner::Symbol Symbol; | 
|  | syntax::FileRange SymRefRange; | 
|  | std::vector<include_cleaner::Header> Providers; | 
|  |  | 
|  | bool operator==(const MissingIncludeDiagInfo &Other) const { | 
|  | return std::tie(SymRefRange, Providers, Symbol) == | 
|  | std::tie(Other.SymRefRange, Other.Providers, Other.Symbol); | 
|  | } | 
|  | }; | 
|  |  | 
|  | struct IncludeCleanerFindings { | 
|  | std::vector<const Inclusion *> UnusedIncludes; | 
|  | std::vector<MissingIncludeDiagInfo> MissingIncludes; | 
|  | }; | 
|  |  | 
|  | IncludeCleanerFindings | 
|  | computeIncludeCleanerFindings(ParsedAST &AST, | 
|  | bool AnalyzeAngledIncludes = false); | 
|  |  | 
|  | std::vector<Diag> issueIncludeCleanerDiagnostics( | 
|  | ParsedAST &AST, llvm::StringRef Code, | 
|  | const IncludeCleanerFindings &Findings, const ThreadsafeFS &TFS, | 
|  | HeaderFilter IgnoreHeader = {}, HeaderFilter AngledHeaders = {}, | 
|  | HeaderFilter QuotedHeaders = {}); | 
|  |  | 
|  | /// Converts the clangd include representation to include-cleaner | 
|  | /// include representation. | 
|  | include_cleaner::Includes convertIncludes(const ParsedAST &); | 
|  |  | 
|  | std::vector<include_cleaner::SymbolReference> | 
|  | collectMacroReferences(ParsedAST &AST); | 
|  |  | 
|  | /// Whether this #include is considered to provide a particular symbol. | 
|  | /// | 
|  | /// This means it satisfies the reference, and no other #include does better. | 
|  | /// `Providers` is the symbol's candidate headers according to walkUsed(). | 
|  | bool isPreferredProvider(const Inclusion &, const include_cleaner::Includes &, | 
|  | llvm::ArrayRef<include_cleaner::Header> Providers); | 
|  |  | 
|  | } // namespace clangd | 
|  | } // namespace clang | 
|  |  | 
|  | #endif // LLVM_CLANG_TOOLS_EXTRA_CLANGD_INCLUDECLEANER_H |