blob: 480db5d1e40c4580d9e4a8d2e15bc502a1b35fb7 [file] [log] [blame]
Gabor Horvatha49a91b2018-05-14 10:10:02 +00001//===--- TerminatingContinueCheck.h - clang-tidy-----------------*- C++ -*-===//
2//
Chandler Carruth2946cd72019-01-19 08:50:56 +00003// 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
Gabor Horvatha49a91b2018-05-14 10:10:02 +00006//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_BUGPRONE_TERMINATINGCONTINUECHECK_H
10#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_BUGPRONE_TERMINATINGCONTINUECHECK_H
11
Alexander Kornienko478fc5c2019-03-25 12:38:26 +000012#include "../ClangTidyCheck.h"
Gabor Horvatha49a91b2018-05-14 10:10:02 +000013
14namespace clang {
15namespace tidy {
16namespace bugprone {
17
18/// Checks if a 'continue' statement terminates the loop (i.e. the loop has
19/// a condition which always evaluates to false).
20///
21/// For the user-facing documentation see:
22/// http://clang.llvm.org/extra/clang-tidy/checks/bugprone-terminating-continue.html
23class TerminatingContinueCheck : public ClangTidyCheck {
24public:
25 TerminatingContinueCheck(StringRef Name, ClangTidyContext *Context)
26 : ClangTidyCheck(Name, Context) {}
27 void registerMatchers(ast_matchers::MatchFinder *Finder) override;
28 void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
29};
30
31} // namespace bugprone
32} // namespace tidy
33} // namespace clang
34
35#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_BUGPRONE_TERMINATINGCONTINUECHECK_H