xref: /llvm-project/clang-tools-extra/clang-tidy/NoLintDirectiveHandler.h (revision f59b600c21add076d6a876f29f94990b24b8e321)
1 //===-- clang-tools-extra/clang-tidy/NoLintDirectiveHandler.h ----*- C++ *-===//
2 //
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
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_NOLINTDIRECTIVEHANDLER_H
10 #define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_NOLINTDIRECTIVEHANDLER_H
11 
12 #include "clang/Basic/Diagnostic.h"
13 #include "llvm/ADT/StringRef.h"
14 #include <memory>
15 
16 namespace clang::tooling {
17 struct Diagnostic;
18 } // namespace clang::tooling
19 
20 namespace llvm {
21 template <typename T> class SmallVectorImpl;
22 } // namespace llvm
23 
24 namespace clang::tidy {
25 
26 /// This class is used to locate NOLINT comments in the file being analyzed, to
27 /// decide whether a diagnostic should be suppressed.
28 /// This class keeps a cache of every NOLINT comment found so that files do not
29 /// have to be repeatedly parsed each time a new diagnostic is raised.
30 class NoLintDirectiveHandler {
31 public:
32   NoLintDirectiveHandler();
33   ~NoLintDirectiveHandler();
34   NoLintDirectiveHandler(const NoLintDirectiveHandler &) = delete;
35   NoLintDirectiveHandler &operator=(const NoLintDirectiveHandler &) = delete;
36 
37   bool shouldSuppress(DiagnosticsEngine::Level DiagLevel,
38                       const Diagnostic &Diag, llvm::StringRef DiagName,
39                       llvm::SmallVectorImpl<tooling::Diagnostic> &NoLintErrors,
40                       bool AllowIO, bool EnableNoLintBlocks);
41 
42 private:
43   class Impl;
44   std::unique_ptr<Impl> PImpl;
45 };
46 
47 } // namespace clang::tidy
48 
49 #endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_NOLINTDIRECTIVEHANDLER_H
50