blob: 6935b455ed618f2f0fc98010a9a7e360015f300e [file] [log] [blame]
Gabor Horvath3880bee2015-02-07 19:54:19 +00001//===--- InefficientAlgorithmCheck.h - clang-tidy----------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Alexander Kornienko66580552015-03-09 16:52:33 +000010#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_INEFFICIENTALGORITHMCHECK_H
11#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_INEFFICIENTALGORITHMCHECK_H
Gabor Horvath3880bee2015-02-07 19:54:19 +000012
13#include "../ClangTidy.h"
14
15namespace clang {
16namespace tidy {
Alexander Kornienko2b3124202015-03-02 12:25:03 +000017namespace misc {
Gabor Horvath3880bee2015-02-07 19:54:19 +000018
Alexander Kornienkof8ed0a82015-08-27 18:01:58 +000019/// Warns on inefficient use of STL algorithms on associative containers.
Gabor Horvath3880bee2015-02-07 19:54:19 +000020///
21/// Associative containers implements some of the algorithms as methods which
22/// should be preferred to the algorithms in the algorithm header. The methods
23/// can take advanatage of the order of the elements.
24class InefficientAlgorithmCheck : public ClangTidyCheck {
25public:
26 InefficientAlgorithmCheck(StringRef Name, ClangTidyContext *Context)
27 : ClangTidyCheck(Name, Context) {}
28 void registerMatchers(ast_matchers::MatchFinder *Finder) override;
29 void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
30};
31
Alexander Kornienko2b3124202015-03-02 12:25:03 +000032} // namespace misc
Gabor Horvath3880bee2015-02-07 19:54:19 +000033} // namespace tidy
34} // namespace clang
35
Alexander Kornienko66580552015-03-09 16:52:33 +000036#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MISC_INEFFICIENTALGORITHMCHECK_H