1cbbf9282SRoman Lebedev //===--- UseDefaultNoneCheck.h - clang-tidy ---------------------*- C++ -*-===// 2cbbf9282SRoman Lebedev // 3cbbf9282SRoman Lebedev // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4cbbf9282SRoman Lebedev // See https://llvm.org/LICENSE.txt for license information. 5cbbf9282SRoman Lebedev // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6cbbf9282SRoman Lebedev // 7cbbf9282SRoman Lebedev //===----------------------------------------------------------------------===// 8cbbf9282SRoman Lebedev 9cbbf9282SRoman Lebedev #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_OPENMP_USEDEFAULTNONECHECK_H 10cbbf9282SRoman Lebedev #define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_OPENMP_USEDEFAULTNONECHECK_H 11cbbf9282SRoman Lebedev 12860aefd0SNathan James #include "../ClangTidyCheck.h" 13cbbf9282SRoman Lebedev 14*4718da50SCarlos Galvez namespace clang::tidy::openmp { 15cbbf9282SRoman Lebedev 16cbbf9282SRoman Lebedev /// Finds OpenMP directives that are allowed to contain a ``default`` clause, 17cbbf9282SRoman Lebedev /// but either don't specify it or the clause is specified but with the kind 18cbbf9282SRoman Lebedev /// other than ``none``, and suggests to use the ``default(none)`` clause. 19cbbf9282SRoman Lebedev /// 20cbbf9282SRoman Lebedev /// For the user-facing documentation see: 216e566bc5SRichard /// http://clang.llvm.org/extra/clang-tidy/checks/openmp/use-default-none.html 22cbbf9282SRoman Lebedev class UseDefaultNoneCheck : public ClangTidyCheck { 23cbbf9282SRoman Lebedev public: UseDefaultNoneCheck(StringRef Name,ClangTidyContext * Context)24cbbf9282SRoman Lebedev UseDefaultNoneCheck(StringRef Name, ClangTidyContext *Context) 25cbbf9282SRoman Lebedev : ClangTidyCheck(Name, Context) {} isLanguageVersionSupported(const LangOptions & LangOpts)26e40a742aSNathan James bool isLanguageVersionSupported(const LangOptions &LangOpts) const override { 27e40a742aSNathan James return LangOpts.OpenMP; 28e40a742aSNathan James } 29cbbf9282SRoman Lebedev void registerMatchers(ast_matchers::MatchFinder *Finder) override; 30cbbf9282SRoman Lebedev void check(const ast_matchers::MatchFinder::MatchResult &Result) override; 31cbbf9282SRoman Lebedev }; 32cbbf9282SRoman Lebedev 33*4718da50SCarlos Galvez } // namespace clang::tidy::openmp 34cbbf9282SRoman Lebedev 35cbbf9282SRoman Lebedev #endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_OPENMP_USEDEFAULTNONECHECK_H 36