1 //===--- RestrictSystemIncludesCheck.h - clang-tidy --------------*- C++-*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_PORTABILITY_RESTRICTINCLUDESSCHECK_H
10 #define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_PORTABILITY_RESTRICTINCLUDESSCHECK_H
12 #include "../ClangTidyCheck.h"
13 #include "../GlobList.h"
14 #include "clang/Lex/PPCallbacks.h"
16 namespace clang::tidy::portability
{
18 /// Checks for allowed includes and suggests removal of any others. If no
19 /// includes are specified, the check will exit without issuing any warnings.
21 /// For the user-facing documentation see:
22 /// http://clang.llvm.org/extra/clang-tidy/checks/portability/restrict-system-includes.html
23 class RestrictSystemIncludesCheck
: public ClangTidyCheck
{
25 RestrictSystemIncludesCheck(StringRef Name
, ClangTidyContext
*Context
,
26 std::string DefaultAllowedIncludes
= "*")
27 : ClangTidyCheck(Name
, Context
),
28 AllowedIncludes(Options
.get("Includes", DefaultAllowedIncludes
)),
29 AllowedIncludesGlobList(AllowedIncludes
) {}
31 void registerPPCallbacks(const SourceManager
&SM
, Preprocessor
*PP
,
32 Preprocessor
*ModuleExpanderPP
) override
;
33 void storeOptions(ClangTidyOptions::OptionMap
&Opts
) override
;
34 bool contains(StringRef FileName
) {
35 return AllowedIncludesGlobList
.contains(FileName
);
39 std::string AllowedIncludes
;
40 GlobList AllowedIncludesGlobList
;
43 class RestrictedIncludesPPCallbacks
: public PPCallbacks
{
45 explicit RestrictedIncludesPPCallbacks(RestrictSystemIncludesCheck
&Check
,
46 const SourceManager
&SM
)
47 : Check(Check
), SM(SM
) {}
49 void InclusionDirective(SourceLocation HashLoc
, const Token
&IncludeTok
,
50 StringRef FileName
, bool IsAngled
,
51 CharSourceRange FilenameRange
,
52 OptionalFileEntryRef File
, StringRef SearchPath
,
53 StringRef RelativePath
, const Module
*SuggestedModule
,
55 SrcMgr::CharacteristicKind FileType
) override
;
56 void EndOfMainFile() override
;
59 struct IncludeDirective
{
60 IncludeDirective() = default;
61 IncludeDirective(SourceLocation Loc
, CharSourceRange Range
,
62 StringRef Filename
, StringRef FullPath
, bool IsInMainFile
)
63 : Loc(Loc
), Range(Range
), IncludeFile(Filename
), IncludePath(FullPath
),
64 IsInMainFile(IsInMainFile
) {}
66 SourceLocation Loc
; // '#' location in the include directive
67 CharSourceRange Range
; // SourceRange for the file name
68 std::string IncludeFile
; // Filename as a string
69 std::string IncludePath
; // Full file path as a string
70 bool IsInMainFile
; // Whether or not the include is in the main file
73 using FileIncludes
= llvm::SmallVector
<IncludeDirective
, 8>;
74 llvm::SmallDenseMap
<FileID
, FileIncludes
> IncludeDirectives
;
76 RestrictSystemIncludesCheck
&Check
;
77 const SourceManager
&SM
;
80 } // namespace clang::tidy::portability
82 #endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_PORTABILITY_RESTRICTINCLUDESSCHECK_H