blob: 298e1f280dcaf021e4ee83510f8e204fb5447614 [file] [log] [blame]
Piotr Padlewski552d4492016-06-21 15:23:27 +00001//===--- UseEmplaceCheck.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
10#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_USE_EMPLACE_H
11#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_USE_EMPLACE_H
12
13#include "../ClangTidy.h"
14
15namespace clang {
16namespace tidy {
17namespace modernize {
18
19/// This check looks for cases when inserting new element into std::vector but
20/// the element is constructed temporarily.
21/// It replaces those calls for emplace_back of arguments passed to
22/// constructor of temporary object.
23///`
24/// For the user-facing documentation see:
25/// http://clang.llvm.org/extra/clang-tidy/checks/modernize-use-emplace.html
26class UseEmplaceCheck : public ClangTidyCheck {
27public:
28 UseEmplaceCheck(StringRef Name, ClangTidyContext *Context)
29 : ClangTidyCheck(Name, Context) {}
30 void registerMatchers(ast_matchers::MatchFinder *Finder) override;
31 void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
32};
33
34} // namespace modernize
35} // namespace tidy
36} // namespace clang
37
38#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_USE_EMPLACE_H