diff options
| author | Gennadiy Civil <gennadiycivil@users.noreply.github.com> | 2017-08-22 22:38:22 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-08-22 22:38:22 -0400 | 
| commit | f4abce46093d3eeb6409786e8d23bbfa61601851 (patch) | |
| tree | e709d792d1a1ec5588ed5799ba359000a5a09617 /googlemock/include | |
| parent | 88269cd365fa5da9d2d6bd04a283ded660c1a0c3 (diff) | |
| parent | 863e02644b57cebe2bb3ee87bffee17127fc02d7 (diff) | |
| download | googletest-f4abce46093d3eeb6409786e8d23bbfa61601851.tar.gz googletest-f4abce46093d3eeb6409786e8d23bbfa61601851.tar.bz2 googletest-f4abce46093d3eeb6409786e8d23bbfa61601851.zip | |
Merge branch 'master' into vs-projects-fix
Diffstat (limited to 'googlemock/include')
| -rw-r--r-- | googlemock/include/gmock/gmock-matchers.h | 35 | 
1 files changed, 27 insertions, 8 deletions
| diff --git a/googlemock/include/gmock/gmock-matchers.h b/googlemock/include/gmock/gmock-matchers.h index 3a97c438..c446bf7d 100644 --- a/googlemock/include/gmock/gmock-matchers.h +++ b/googlemock/include/gmock/gmock-matchers.h @@ -2232,7 +2232,10 @@ class FieldMatcher {  // Implements the Property() matcher for matching a property  // (i.e. return value of a getter method) of an object. -template <typename Class, typename PropertyType> +// +// Property is a const-qualified member function of Class returning +// PropertyType. +template <typename Class, typename PropertyType, typename Property>  class PropertyMatcher {   public:    // The property may have a reference type, so 'const PropertyType&' @@ -2241,8 +2244,7 @@ class PropertyMatcher {    // PropertyType being a reference or not.    typedef GTEST_REFERENCE_TO_CONST_(PropertyType) RefToConstProperty; -  PropertyMatcher(PropertyType (Class::*property)() const, -                  const Matcher<RefToConstProperty>& matcher) +  PropertyMatcher(Property property, const Matcher<RefToConstProperty>& matcher)        : property_(property), matcher_(matcher) {}    void DescribeTo(::std::ostream* os) const { @@ -2295,7 +2297,7 @@ class PropertyMatcher {      return MatchAndExplainImpl(false_type(), *p, listener);    } -  PropertyType (Class::*property_)() const; +  Property property_;    const Matcher<RefToConstProperty> matcher_;    GTEST_DISALLOW_ASSIGN_(PropertyMatcher); @@ -3908,11 +3910,13 @@ inline PolymorphicMatcher<  //   Property(&Foo::str, StartsWith("hi"))  // matches a Foo object x iff x.str() starts with "hi".  template <typename Class, typename PropertyType, typename PropertyMatcher> -inline PolymorphicMatcher< -  internal::PropertyMatcher<Class, PropertyType> > Property( -    PropertyType (Class::*property)() const, const PropertyMatcher& matcher) { +inline PolymorphicMatcher<internal::PropertyMatcher< +    Class, PropertyType, PropertyType (Class::*)() const> > +Property(PropertyType (Class::*property)() const, +         const PropertyMatcher& matcher) {    return MakePolymorphicMatcher( -      internal::PropertyMatcher<Class, PropertyType>( +      internal::PropertyMatcher<Class, PropertyType, +                                PropertyType (Class::*)() const>(            property,            MatcherCast<GTEST_REFERENCE_TO_CONST_(PropertyType)>(matcher)));    // The call to MatcherCast() is required for supporting inner @@ -3921,6 +3925,21 @@ inline PolymorphicMatcher<    // to compile where bar() returns an int32 and m is a matcher for int64.  } +#if GTEST_LANG_CXX11 +// The same as above but for reference-qualified member functions. +template <typename Class, typename PropertyType, typename PropertyMatcher> +inline PolymorphicMatcher<internal::PropertyMatcher< +    Class, PropertyType, PropertyType (Class::*)() const &> > +Property(PropertyType (Class::*property)() const &, +         const PropertyMatcher& matcher) { +  return MakePolymorphicMatcher( +      internal::PropertyMatcher<Class, PropertyType, +                                PropertyType (Class::*)() const &>( +          property, +          MatcherCast<GTEST_REFERENCE_TO_CONST_(PropertyType)>(matcher))); +} +#endif +  // Creates a matcher that matches an object iff the result of applying  // a callable to x matches 'matcher'.  // For example, | 
