xref: /llvm-project/clang-tools-extra/clang-tidy/openmp/UseDefaultNoneCheck.h (revision 4718da506091a37ca4863d979bc541e359b79b10)
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