2013-08-29 21:42:13 +08:00
|
|
|
//===-- PassByValueActions.h ------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
///
|
|
|
|
/// \file
|
|
|
|
/// \brief This file contains the declaration of the ASTMatcher callback for the
|
|
|
|
/// PassByValue transform.
|
|
|
|
///
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2013-09-05 03:13:50 +08:00
|
|
|
#ifndef CLANG_MODERNIZE_PASS_BY_VALUE_ACTIONS_H
|
|
|
|
#define CLANG_MODERNIZE_PASS_BY_VALUE_ACTIONS_H
|
2013-08-29 21:42:13 +08:00
|
|
|
|
|
|
|
#include "clang/ASTMatchers/ASTMatchFinder.h"
|
|
|
|
#include "clang/Tooling/Refactoring.h"
|
|
|
|
|
|
|
|
class Transform;
|
|
|
|
class IncludeDirectives;
|
|
|
|
|
|
|
|
/// \brief Callback that replaces const-ref parameters in constructors to use
|
|
|
|
/// pass-by-value semantic where applicable.
|
|
|
|
///
|
|
|
|
/// Modifications done by the callback:
|
|
|
|
/// - \#include \<utility\> is added if necessary for the definition of
|
|
|
|
/// \c std::move() to be available.
|
|
|
|
/// - The parameter type is changed from const-ref to value-type.
|
|
|
|
/// - In the init-list the parameter is moved.
|
|
|
|
///
|
|
|
|
/// Example:
|
|
|
|
/// \code
|
|
|
|
/// + #include <utility>
|
|
|
|
///
|
|
|
|
/// class Foo(const std::string &S) {
|
|
|
|
/// public:
|
|
|
|
/// - Foo(const std::string &S) : S(S) {}
|
|
|
|
/// + Foo(std::string S) : S(std::move(S)) {}
|
|
|
|
///
|
|
|
|
/// private:
|
|
|
|
/// std::string S;
|
|
|
|
/// };
|
|
|
|
/// \endcode
|
|
|
|
///
|
|
|
|
/// \note Since an include may be added by this matcher it's necessary to call
|
|
|
|
/// \c setIncludeDirectives() with an up-to-date \c IncludeDirectives. This is
|
|
|
|
/// typically done by overloading \c Transform::handleBeginSource().
|
|
|
|
class ConstructorParamReplacer
|
|
|
|
: public clang::ast_matchers::MatchFinder::MatchCallback {
|
|
|
|
public:
|
2013-09-03 21:16:02 +08:00
|
|
|
ConstructorParamReplacer(unsigned &AcceptedChanges, unsigned &RejectedChanges,
|
|
|
|
Transform &Owner)
|
|
|
|
: AcceptedChanges(AcceptedChanges), RejectedChanges(RejectedChanges),
|
2014-06-09 10:03:06 +08:00
|
|
|
Owner(Owner), IncludeManager(nullptr) {}
|
2013-08-29 21:42:13 +08:00
|
|
|
|
|
|
|
void setIncludeDirectives(IncludeDirectives *Includes) {
|
|
|
|
IncludeManager = Includes;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
/// \brief Entry point to the callback called when matches are made.
|
|
|
|
virtual void run(const clang::ast_matchers::MatchFinder::MatchResult &Result)
|
2014-03-02 18:20:11 +08:00
|
|
|
override;
|
2013-08-29 21:42:13 +08:00
|
|
|
|
|
|
|
unsigned &AcceptedChanges;
|
|
|
|
unsigned &RejectedChanges;
|
2013-09-03 21:16:02 +08:00
|
|
|
Transform &Owner;
|
2013-08-29 21:42:13 +08:00
|
|
|
IncludeDirectives *IncludeManager;
|
|
|
|
};
|
|
|
|
|
2013-09-05 03:13:50 +08:00
|
|
|
#endif // CLANG_MODERNIZE_PASS_BY_VALUE_ACTIONS_H
|