diff options
| author | Gennadiy Civil <gennadiycivil@users.noreply.github.com> | 2018-08-16 11:13:12 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-08-16 11:13:12 -0400 | 
| commit | 21e518557ad7634bc4b1fd57effa7e49a1405bb5 (patch) | |
| tree | 8484ccd28cc1bb4aa27c3b47b9a56cf9ee2ce66c /googlemock/include/gmock/gmock-actions.h | |
| parent | 3e2cb75446e0f56f226f0fb259e032bb4d014002 (diff) | |
| parent | 490554aa0f3618e1e5dd217f11fe0c3f188ed615 (diff) | |
| download | googletest-21e518557ad7634bc4b1fd57effa7e49a1405bb5.tar.gz googletest-21e518557ad7634bc4b1fd57effa7e49a1405bb5.tar.bz2 googletest-21e518557ad7634bc4b1fd57effa7e49a1405bb5.zip | |
Merge branch 'master' into josh/fix_scoped_class2
Diffstat (limited to 'googlemock/include/gmock/gmock-actions.h')
| -rw-r--r-- | googlemock/include/gmock/gmock-actions.h | 106 | 
1 files changed, 82 insertions, 24 deletions
| diff --git a/googlemock/include/gmock/gmock-actions.h b/googlemock/include/gmock/gmock-actions.h index 845c8232..b82313d5 100644 --- a/googlemock/include/gmock/gmock-actions.h +++ b/googlemock/include/gmock/gmock-actions.h @@ -26,13 +26,14 @@  // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT  // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE  // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -// -// Author: wan@google.com (Zhanyong Wan) +  // Google Mock - a framework for writing C++ mock classes.  //  // This file implements some commonly used actions. +// GOOGLETEST_CM0002 DO NOT DELETE +  #ifndef GMOCK_INCLUDE_GMOCK_GMOCK_ACTIONS_H_  #define GMOCK_INCLUDE_GMOCK_GMOCK_ACTIONS_H_ @@ -46,9 +47,10 @@  #include "gmock/internal/gmock-internal-utils.h"  #include "gmock/internal/gmock-port.h" -#if GTEST_HAS_STD_TYPE_TRAITS_  // Defined by gtest-port.h via gmock-port.h. +#if GTEST_LANG_CXX11  // Defined by gtest-port.h via gmock-port.h. +#include <functional>  #include <type_traits> -#endif +#endif  // GTEST_LANG_CXX11  namespace testing { @@ -96,7 +98,7 @@ struct BuiltInDefaultValueGetter<T, false> {  template <typename T>  class BuiltInDefaultValue {   public: -#if GTEST_HAS_STD_TYPE_TRAITS_ +#if GTEST_LANG_CXX11    // This function returns true iff type T has a built-in default value.    static bool Exists() {      return ::std::is_default_constructible<T>::value; @@ -107,7 +109,7 @@ class BuiltInDefaultValue {          T, ::std::is_default_constructible<T>::value>::Get();    } -#else  // GTEST_HAS_STD_TYPE_TRAITS_ +#else  // GTEST_LANG_CXX11    // This function returns true iff type T has a built-in default value.    static bool Exists() {      return false; @@ -117,7 +119,7 @@ class BuiltInDefaultValue {      return BuiltInDefaultValueGetter<T, false>::Get();    } -#endif  // GTEST_HAS_STD_TYPE_TRAITS_ +#endif  // GTEST_LANG_CXX11  };  // This partial specialization says that we use the same built-in @@ -359,14 +361,20 @@ class Action {    // Constructs a null Action.  Needed for storing Action objects in    // STL containers. -  Action() : impl_(NULL) {} +  Action() {} -  // Constructs an Action from its implementation.  A NULL impl is -  // used to represent the "do-default" action. -  explicit Action(ActionInterface<F>* impl) : impl_(impl) {} +#if GTEST_LANG_CXX11 +  // Construct an Action from a specified callable. +  // This cannot take std::function directly, because then Action would not be +  // directly constructible from lambda (it would require two conversions). +  template <typename G, +            typename = typename ::std::enable_if< +                ::std::is_constructible<::std::function<F>, G>::value>::type> +  Action(G&& fun) : fun_(::std::forward<G>(fun)) {}  // NOLINT +#endif -  // Copy constructor. -  Action(const Action& action) : impl_(action.impl_) {} +  // Constructs an Action from its implementation. +  explicit Action(ActionInterface<F>* impl) : impl_(impl) {}    // This constructor allows us to turn an Action<Func> object into an    // Action<F>, as long as F's arguments can be implicitly converted @@ -376,7 +384,13 @@ class Action {    explicit Action(const Action<Func>& action);    // Returns true iff this is the DoDefault() action. -  bool IsDoDefault() const { return impl_.get() == NULL; } +  bool IsDoDefault() const { +#if GTEST_LANG_CXX11 +    return impl_ == nullptr && fun_ == nullptr; +#else +    return impl_ == NULL; +#endif +  }    // Performs the action.  Note that this method is const even though    // the corresponding method in ActionInterface is not.  The reason @@ -384,14 +398,15 @@ class Action {    // another concrete action, not that the concrete action it binds to    // cannot change state.  (Think of the difference between a const    // pointer and a pointer to const.) -  Result Perform(const ArgumentTuple& args) const { -    internal::Assert( -        !IsDoDefault(), __FILE__, __LINE__, -        "You are using DoDefault() inside a composite action like " -        "DoAll() or WithArgs().  This is not supported for technical " -        "reasons.  Please instead spell out the default action, or " -        "assign the default action to an Action variable and use " -        "the variable in various places."); +  Result Perform(ArgumentTuple args) const { +    if (IsDoDefault()) { +      internal::IllegalDoDefault(__FILE__, __LINE__); +    } +#if GTEST_LANG_CXX11 +    if (fun_ != nullptr) { +      return internal::Apply(fun_, ::std::move(args)); +    } +#endif      return impl_->Perform(args);    } @@ -399,6 +414,18 @@ class Action {    template <typename F1, typename F2>    friend class internal::ActionAdaptor; +  template <typename G> +  friend class Action; + +  // In C++11, Action can be implemented either as a generic functor (through +  // std::function), or legacy ActionInterface. In C++98, only ActionInterface +  // is available. The invariants are as follows: +  // * in C++98, impl_ is null iff this is the default action +  // * in C++11, at most one of fun_ & impl_ may be nonnull; both are null iff +  //   this is the default action +#if GTEST_LANG_CXX11 +  ::std::function<F> fun_; +#endif    internal::linked_ptr<ActionInterface<F> > impl_;  }; @@ -530,6 +557,9 @@ struct ByMoveWrapper {  // statement, and conversion of the result of Return to Action<T(U)> is a  // good place for that.  // +// The real life example of the above scenario happens when an invocation +// of gtl::Container() is passed into Return. +//  template <typename R>  class ReturnAction {   public: @@ -749,7 +779,7 @@ class DoDefaultAction {    // This template type conversion operator allows DoDefault() to be    // used in any function.    template <typename F> -  operator Action<F>() const { return Action<F>(NULL); } +  operator Action<F>() const { return Action<F>(); }  // NOLINT  };  // Implements the Assign action to set a given pointer referent to a @@ -885,6 +915,28 @@ class InvokeMethodWithoutArgsAction {    GTEST_DISALLOW_ASSIGN_(InvokeMethodWithoutArgsAction);  }; +// Implements the InvokeWithoutArgs(callback) action. +template <typename CallbackType> +class InvokeCallbackWithoutArgsAction { + public: +  // The c'tor takes ownership of the callback. +  explicit InvokeCallbackWithoutArgsAction(CallbackType* callback) +      : callback_(callback) { +    callback->CheckIsRepeatable();  // Makes sure the callback is permanent. +  } + +  // This type conversion operator template allows Invoke(callback) to +  // be used wherever the callback's return type can be implicitly +  // converted to that of the mock function. +  template <typename Result, typename ArgumentTuple> +  Result Perform(const ArgumentTuple&) const { return callback_->Run(); } + + private: +  const internal::linked_ptr<CallbackType> callback_; + +  GTEST_DISALLOW_ASSIGN_(InvokeCallbackWithoutArgsAction); +}; +  // Implements the IgnoreResult(action) action.  template <typename A>  class IgnoreResultAction { @@ -1052,7 +1104,13 @@ typedef internal::IgnoredValue Unused;  template <typename To>  template <typename From>  Action<To>::Action(const Action<From>& from) -    : impl_(new internal::ActionAdaptor<To, From>(from)) {} +    : +#if GTEST_LANG_CXX11 +      fun_(from.fun_), +#endif +      impl_(from.impl_ == NULL ? NULL +                               : new internal::ActionAdaptor<To, From>(from)) { +}  // Creates an action that returns 'value'.  'value' is passed by value  // instead of const reference - otherwise Return("string literal") | 
