clang-tools 22.0.0git
MisleadingBidirectionalCheck.h
Go to the documentation of this file.
1//===----------------------------------------------------------------------===//
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_MISC_MISLEADINGBIDIRECTIONALCHECK_H
10#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_MISLEADINGBIDIRECTIONALCHECK_H
11
12#include "../ClangTidyCheck.h"
13
14namespace clang::tidy::misc {
15
16/// Warns about unterminated bidirectional unicode sequence.
17///
18/// For the user-facing documentation see:
19/// https://clang.llvm.org/extra/clang-tidy/checks/misc/misleading-bidirectional.html
21public:
22 MisleadingBidirectionalCheck(StringRef Name, ClangTidyContext *Context);
24
25 void registerPPCallbacks(const SourceManager &SM, Preprocessor *PP,
26 Preprocessor *ModuleExpanderPP) override;
27
28 void registerMatchers(ast_matchers::MatchFinder *Finder) override;
29 void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
30
31private:
33 std::unique_ptr<MisleadingBidirectionalHandler> Handler;
34};
35
36} // namespace clang::tidy::misc
37
38#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_MISLEADINGBIDIRECTIONALCHECK_H
Every ClangTidyCheck reports errors through a DiagnosticsEngine provided by this context.
MisleadingBidirectionalCheck(StringRef Name, ClangTidyContext *Context)
void registerPPCallbacks(const SourceManager &SM, Preprocessor *PP, Preprocessor *ModuleExpanderPP) override
void check(const ast_matchers::MatchFinder::MatchResult &Result) override
void registerMatchers(ast_matchers::MatchFinder *Finder) override