[Workflow] Try to fix code-formatter failing to find changes in some cases.
[llvm-project.git] / clang-tools-extra / clang-tidy / NoLintDirectiveHandler.h
blobe862195abaabbe8bfc26a55351d1502fe69aa00f
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 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_NOLINTDIRECTIVEHANDLER_H
10 #define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_NOLINTDIRECTIVEHANDLER_H
12 #include "clang/Basic/Diagnostic.h"
13 #include "llvm/ADT/StringRef.h"
14 #include <memory>
16 namespace clang::tooling {
17 struct Diagnostic;
18 } // namespace clang::tooling
20 namespace llvm {
21 template <typename T> class SmallVectorImpl;
22 } // namespace llvm
24 namespace clang::tidy {
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();
35 bool shouldSuppress(DiagnosticsEngine::Level DiagLevel,
36 const Diagnostic &Diag, llvm::StringRef DiagName,
37 llvm::SmallVectorImpl<tooling::Diagnostic> &NoLintErrors,
38 bool AllowIO, bool EnableNoLintBlocks);
40 private:
41 class Impl;
42 std::unique_ptr<Impl> PImpl;
45 } // namespace clang::tidy
47 #endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_NOLINTDIRECTIVEHANDLER_H