clang-tools 22.0.0git
OverrideWithDifferentVisibilityCheck.h
Go to the documentation of this file.
1//===--- OverrideWithDifferentVisibilityCheck.h - clang-tidy --*- 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_MISC_OVERRIDEWITHDIFFERENTVISIBILITYCHECK_H
10#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_OVERRIDEWITHDIFFERENTVISIBILITYCHECK_H
11
12#include "../ClangTidyCheck.h"
13
14namespace clang::tidy::misc {
15
16/// Finds virtual function overrides with different visibility than the function
17/// in the base class.
18///
19/// For the user-facing documentation see:
20/// http://clang.llvm.org/extra/clang-tidy/checks/misc/override-with-different-visibility.html
22public:
23 enum class ChangeKind { Any, Widening, Narrowing };
24
26 ClangTidyContext *Context);
27 void storeOptions(ClangTidyOptions::OptionMap &Opts) override;
28 void registerMatchers(ast_matchers::MatchFinder *Finder) override;
29 void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
30 bool isLanguageVersionSupported(const LangOptions &LangOpts) const override {
31 return LangOpts.CPlusPlus;
32 }
33
34private:
35 ChangeKind DetectVisibilityChange;
36 bool CheckDestructors;
37 bool CheckOperators;
38 std::vector<llvm::StringRef> IgnoredFunctions;
39};
40
41} // namespace clang::tidy::misc
42
43#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_OVERRIDEWITHDIFFERENTVISIBILITYCHECK_H
Every ClangTidyCheck reports errors through a DiagnosticsEngine provided by this context.
bool isLanguageVersionSupported(const LangOptions &LangOpts) const override
void check(const ast_matchers::MatchFinder::MatchResult &Result) override
llvm::StringMap< ClangTidyValue > OptionMap