blob: 8ed4142731c99fcc7d45c09a733f00ae01dffd68 [file] [log] [blame]
Alexander Kornienkob959f4c2015-12-30 10:24:40 +00001//===--- UnnecessaryCopyInitialization.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_PERFORMANCE_UNNECESSARY_COPY_INITIALIZATION_H
11#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_PERFORMANCE_UNNECESSARY_COPY_INITIALIZATION_H
12
13#include "../ClangTidy.h"
14
15namespace clang {
16namespace tidy {
17namespace performance {
18
Felix Bergeradfdc142016-03-05 21:17:58 +000019// The check detects local variable declarations that are copy initialized with
20// the const reference of a function call or the const reference of a method
21// call whose object is guaranteed to outlive the variable's scope and suggests
22// to use a const reference.
Alexander Kornienkob959f4c2015-12-30 10:24:40 +000023//
24// The check currently only understands a subset of variables that are
25// guaranteed to outlive the const reference returned, namely: const variables,
26// const references, and const pointers to const.
27class UnnecessaryCopyInitialization : public ClangTidyCheck {
28public:
Alexander Kornienko15890712015-12-30 11:39:30 +000029 UnnecessaryCopyInitialization(StringRef Name, ClangTidyContext *Context)
30 : ClangTidyCheck(Name, Context) {}
Alexander Kornienkob959f4c2015-12-30 10:24:40 +000031 void registerMatchers(ast_matchers::MatchFinder *Finder) override;
32 void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
Haojian Wu6ccb1dd2016-03-23 09:33:07 +000033
34private:
35 void handleCopyFromMethodReturn(const VarDecl &Var, const Stmt &BlockStmt,
Felix Berger98e40192016-05-31 00:25:57 +000036 bool IssueFix, const VarDecl *ObjectArg,
37 ASTContext &Context);
Haojian Wu6ccb1dd2016-03-23 09:33:07 +000038 void handleCopyFromLocalVar(const VarDecl &NewVar, const VarDecl &OldVar,
Felix Berger6d3d7462016-05-13 02:47:56 +000039 const Stmt &BlockStmt, bool IssueFix,
40 ASTContext &Context);
Alexander Kornienkob959f4c2015-12-30 10:24:40 +000041};
42
43} // namespace performance
44} // namespace tidy
45} // namespace clang
46
47#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_PERFORMANCE_UNNECESSARY_COPY_INITIALIZATION_H