| //===--- UseEqualsDeleteCheck.h - clang-tidy---------------------------*- C++ -*-===// | 
 | // | 
 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. | 
 | // See https://llvm.org/LICENSE.txt for license information. | 
 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | 
 | // | 
 | //===----------------------------------------------------------------------===// | 
 |  | 
 | #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_USE_EQUALS_DELETE_H | 
 | #define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_USE_EQUALS_DELETE_H | 
 |  | 
 | #include "../ClangTidyCheck.h" | 
 |  | 
 | namespace clang::tidy::modernize { | 
 |  | 
 | /// Identifies unimplemented private special member functions, and recommends | 
 | /// using ``= delete`` for them. Additionally, it recommends relocating any | 
 | /// deleted member function from the ``private`` to the ``public`` section. | 
 | /// | 
 | /// For the user-facing documentation see: | 
 | /// http://clang.llvm.org/extra/clang-tidy/checks/modernize/use-equals-delete.html | 
 | class UseEqualsDeleteCheck : public ClangTidyCheck { | 
 | public: | 
 |   UseEqualsDeleteCheck(StringRef Name, ClangTidyContext *Context); | 
 |   bool isLanguageVersionSupported(const LangOptions &LangOpts) const override { | 
 |     return LangOpts.CPlusPlus; | 
 |   } | 
 |   void storeOptions(ClangTidyOptions::OptionMap &Opts) override; | 
 |   void registerMatchers(ast_matchers::MatchFinder *Finder) override; | 
 |   void check(const ast_matchers::MatchFinder::MatchResult &Result) override; | 
 |   std::optional<TraversalKind> getCheckTraversalKind() const override { | 
 |     return TK_IgnoreUnlessSpelledInSource; | 
 |   } | 
 |  | 
 | private: | 
 |   const bool IgnoreMacros; | 
 | }; | 
 |  | 
 | } // namespace clang::tidy::modernize | 
 |  | 
 | #endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_USE_EQUALS_DELETE_H |