Moves the universal printer from gmock to gtest (by Vlad Losev).
This commit is contained in:
		| @@ -38,7 +38,6 @@ pkginclude_HEADERS = include/gmock/gmock.h \ | ||||
|                      include/gmock/gmock-generated-nice-strict.h \ | ||||
|                      include/gmock/gmock-matchers.h \ | ||||
|                      include/gmock/gmock-more-actions.h \ | ||||
|                      include/gmock/gmock-printers.h \ | ||||
|                      include/gmock/gmock-spec-builders.h | ||||
|  | ||||
| pkginclude_internaldir = $(pkgincludedir)/internal | ||||
| @@ -92,7 +91,6 @@ GMOCK_SOURCE_INGLUDES = \ | ||||
|   src/gmock-cardinalities.cc \ | ||||
|   src/gmock-internal-utils.cc \ | ||||
|   src/gmock-matchers.cc \ | ||||
|   src/gmock-printers.cc \ | ||||
|   src/gmock-spec-builders.cc | ||||
|  | ||||
| EXTRA_DIST += $(GMOCK_SOURCE_INGLUDES) | ||||
| @@ -110,8 +108,7 @@ EXTRA_DIST += \ | ||||
|   test/gmock-matchers_test.cc \ | ||||
|   test/gmock-more-actions_test.cc \ | ||||
|   test/gmock-nice-strict_test.cc \ | ||||
|   test/gmock-port_test.cc \ | ||||
|   test/gmock-printers_test.cc | ||||
|   test/gmock-port_test.cc | ||||
|  | ||||
| # Python tests, which we don't run using autotools. | ||||
| EXTRA_DIST += \ | ||||
|   | ||||
| @@ -43,7 +43,6 @@ | ||||
| #include <errno.h> | ||||
| #endif | ||||
|  | ||||
| #include <gmock/gmock-printers.h> | ||||
| #include <gmock/internal/gmock-internal-utils.h> | ||||
| #include <gmock/internal/gmock-port.h> | ||||
|  | ||||
| @@ -477,7 +476,7 @@ class ReturnAction { | ||||
|     // and put the typedef both here (for use in assert statement) and | ||||
|     // in the Impl class. But both definitions must be the same. | ||||
|     typedef typename Function<F>::Result Result; | ||||
|     GMOCK_COMPILE_ASSERT_( | ||||
|     GTEST_COMPILE_ASSERT_( | ||||
|         !internal::is_reference<Result>::value, | ||||
|         use_ReturnRef_instead_of_Return_to_return_a_reference); | ||||
|     return Action<F>(new Impl<F>(value_)); | ||||
| @@ -504,7 +503,7 @@ class ReturnAction { | ||||
|     virtual Result Perform(const ArgumentTuple&) { return value_; } | ||||
|  | ||||
|    private: | ||||
|     GMOCK_COMPILE_ASSERT_(!internal::is_reference<Result>::value, | ||||
|     GTEST_COMPILE_ASSERT_(!internal::is_reference<Result>::value, | ||||
|                           Result_cannot_be_a_reference_type); | ||||
|     Result value_; | ||||
|  | ||||
| @@ -522,7 +521,7 @@ class ReturnNullAction { | ||||
|   // Allows ReturnNull() to be used in any pointer-returning function. | ||||
|   template <typename Result, typename ArgumentTuple> | ||||
|   static Result Perform(const ArgumentTuple&) { | ||||
|     GMOCK_COMPILE_ASSERT_(internal::is_pointer<Result>::value, | ||||
|     GTEST_COMPILE_ASSERT_(internal::is_pointer<Result>::value, | ||||
|                           ReturnNull_can_be_used_to_return_a_pointer_only); | ||||
|     return NULL; | ||||
|   } | ||||
| @@ -555,7 +554,7 @@ class ReturnRefAction { | ||||
|     // Asserts that the function return type is a reference.  This | ||||
|     // catches the user error of using ReturnRef(x) when Return(x) | ||||
|     // should be used, and generates some helpful error message. | ||||
|     GMOCK_COMPILE_ASSERT_(internal::is_reference<Result>::value, | ||||
|     GTEST_COMPILE_ASSERT_(internal::is_reference<Result>::value, | ||||
|                           use_Return_instead_of_ReturnRef_to_return_a_value); | ||||
|     return Action<F>(new Impl<F>(ref_)); | ||||
|   } | ||||
|   | ||||
| @@ -344,7 +344,7 @@ using internal::FunctionMocker; | ||||
| // INTERNAL IMPLEMENTATION - DON'T USE IN USER CODE!!! | ||||
| #define GMOCK_METHOD0_(tn, constness, ct, Method, F) \ | ||||
|   GMOCK_RESULT_(tn, F) ct Method() constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 0, \ | ||||
|         this_method_does_not_take_0_arguments); \ | ||||
|     GMOCK_MOCKER_(0, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -359,7 +359,7 @@ using internal::FunctionMocker; | ||||
| // INTERNAL IMPLEMENTATION - DON'T USE IN USER CODE!!! | ||||
| #define GMOCK_METHOD1_(tn, constness, ct, Method, F) \ | ||||
|   GMOCK_RESULT_(tn, F) ct Method(GMOCK_ARG_(tn, F, 1) gmock_a1) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 1, \ | ||||
|         this_method_does_not_take_1_argument); \ | ||||
|     GMOCK_MOCKER_(1, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -376,7 +376,7 @@ using internal::FunctionMocker; | ||||
| #define GMOCK_METHOD2_(tn, constness, ct, Method, F) \ | ||||
|   GMOCK_RESULT_(tn, F) ct Method(GMOCK_ARG_(tn, F, 1) gmock_a1, \ | ||||
|                                  GMOCK_ARG_(tn, F, 2) gmock_a2) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 2, \ | ||||
|         this_method_does_not_take_2_arguments); \ | ||||
|     GMOCK_MOCKER_(2, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -395,7 +395,7 @@ using internal::FunctionMocker; | ||||
|   GMOCK_RESULT_(tn, F) ct Method(GMOCK_ARG_(tn, F, 1) gmock_a1, \ | ||||
|                                  GMOCK_ARG_(tn, F, 2) gmock_a2, \ | ||||
|                                  GMOCK_ARG_(tn, F, 3) gmock_a3) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 3, \ | ||||
|         this_method_does_not_take_3_arguments); \ | ||||
|     GMOCK_MOCKER_(3, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -417,7 +417,7 @@ using internal::FunctionMocker; | ||||
|                                  GMOCK_ARG_(tn, F, 2) gmock_a2, \ | ||||
|                                  GMOCK_ARG_(tn, F, 3) gmock_a3, \ | ||||
|                                  GMOCK_ARG_(tn, F, 4) gmock_a4) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 4, \ | ||||
|         this_method_does_not_take_4_arguments); \ | ||||
|     GMOCK_MOCKER_(4, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -442,7 +442,7 @@ using internal::FunctionMocker; | ||||
|                                  GMOCK_ARG_(tn, F, 3) gmock_a3, \ | ||||
|                                  GMOCK_ARG_(tn, F, 4) gmock_a4, \ | ||||
|                                  GMOCK_ARG_(tn, F, 5) gmock_a5) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 5, \ | ||||
|         this_method_does_not_take_5_arguments); \ | ||||
|     GMOCK_MOCKER_(5, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -469,7 +469,7 @@ using internal::FunctionMocker; | ||||
|                                  GMOCK_ARG_(tn, F, 4) gmock_a4, \ | ||||
|                                  GMOCK_ARG_(tn, F, 5) gmock_a5, \ | ||||
|                                  GMOCK_ARG_(tn, F, 6) gmock_a6) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 6, \ | ||||
|         this_method_does_not_take_6_arguments); \ | ||||
|     GMOCK_MOCKER_(6, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -498,7 +498,7 @@ using internal::FunctionMocker; | ||||
|                                  GMOCK_ARG_(tn, F, 5) gmock_a5, \ | ||||
|                                  GMOCK_ARG_(tn, F, 6) gmock_a6, \ | ||||
|                                  GMOCK_ARG_(tn, F, 7) gmock_a7) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 7, \ | ||||
|         this_method_does_not_take_7_arguments); \ | ||||
|     GMOCK_MOCKER_(7, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -529,7 +529,7 @@ using internal::FunctionMocker; | ||||
|                                  GMOCK_ARG_(tn, F, 6) gmock_a6, \ | ||||
|                                  GMOCK_ARG_(tn, F, 7) gmock_a7, \ | ||||
|                                  GMOCK_ARG_(tn, F, 8) gmock_a8) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 8, \ | ||||
|         this_method_does_not_take_8_arguments); \ | ||||
|     GMOCK_MOCKER_(8, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -562,7 +562,7 @@ using internal::FunctionMocker; | ||||
|                                  GMOCK_ARG_(tn, F, 7) gmock_a7, \ | ||||
|                                  GMOCK_ARG_(tn, F, 8) gmock_a8, \ | ||||
|                                  GMOCK_ARG_(tn, F, 9) gmock_a9) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 9, \ | ||||
|         this_method_does_not_take_9_arguments); \ | ||||
|     GMOCK_MOCKER_(9, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
| @@ -598,7 +598,7 @@ using internal::FunctionMocker; | ||||
|                                  GMOCK_ARG_(tn, F, 8) gmock_a8, \ | ||||
|                                  GMOCK_ARG_(tn, F, 9) gmock_a9, \ | ||||
|                                  GMOCK_ARG_(tn, F, 10) gmock_a10) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == 10, \ | ||||
|         this_method_does_not_take_10_arguments); \ | ||||
|     GMOCK_MOCKER_(10, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
|   | ||||
| @@ -132,7 +132,7 @@ $var matcher_as = [[$for j, \ | ||||
| // INTERNAL IMPLEMENTATION - DON'T USE IN USER CODE!!! | ||||
| #define GMOCK_METHOD$i[[]]_(tn, constness, ct, Method, F) \ | ||||
|   GMOCK_RESULT_(tn, F) ct Method($arg_as) constness { \ | ||||
|     GMOCK_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|     GTEST_COMPILE_ASSERT_(::std::tr1::tuple_size< \ | ||||
|         tn ::testing::internal::Function<F>::ArgumentTuple>::value == $i, \ | ||||
|         this_method_does_not_take_$i[[]]_argument[[$if i != 1 [[s]]]]); \ | ||||
|     GMOCK_MOCKER_($i, constness, Method).SetOwnerAndName(this, #Method); \ | ||||
|   | ||||
| @@ -42,7 +42,6 @@ | ||||
| #include <string> | ||||
| #include <vector> | ||||
| #include <gmock/gmock-matchers.h> | ||||
| #include <gmock/gmock-printers.h> | ||||
|  | ||||
| namespace testing { | ||||
| namespace internal { | ||||
| @@ -222,7 +221,7 @@ template <class ArgsTuple, int k0 = -1, int k1 = -1, int k2 = -1, int k3 = -1, | ||||
| class ArgsMatcherImpl : public MatcherInterface<ArgsTuple> { | ||||
|  public: | ||||
|   // ArgsTuple may have top-level const or reference modifiers. | ||||
|   typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(ArgsTuple)) RawArgsTuple; | ||||
|   typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(ArgsTuple)) RawArgsTuple; | ||||
|   typedef typename internal::TupleFields<RawArgsTuple, k0, k1, k2, k3, k4, k5, | ||||
|       k6, k7, k8, k9>::type SelectedArgs; | ||||
|   typedef Matcher<const SelectedArgs&> MonomorphicInnerMatcher; | ||||
| @@ -315,7 +314,7 @@ class ElementsAreMatcher1 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -344,7 +343,7 @@ class ElementsAreMatcher2 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -372,7 +371,7 @@ class ElementsAreMatcher3 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -402,7 +401,7 @@ class ElementsAreMatcher4 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -434,7 +433,7 @@ class ElementsAreMatcher5 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -470,7 +469,7 @@ class ElementsAreMatcher6 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -508,7 +507,7 @@ class ElementsAreMatcher7 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -548,7 +547,7 @@ class ElementsAreMatcher8 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -591,7 +590,7 @@ class ElementsAreMatcher9 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -636,7 +635,7 @@ class ElementsAreMatcher10 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
|   | ||||
| @@ -44,7 +44,6 @@ $$ }} This line fixes auto-indentation of the following code in Emacs. | ||||
| #include <string> | ||||
| #include <vector> | ||||
| #include <gmock/gmock-matchers.h> | ||||
| #include <gmock/gmock-printers.h> | ||||
|  | ||||
| namespace testing { | ||||
| namespace internal { | ||||
| @@ -108,7 +107,7 @@ template <class ArgsTuple$for i [[, int k$i = -1]]> | ||||
| class ArgsMatcherImpl : public MatcherInterface<ArgsTuple> { | ||||
|  public: | ||||
|   // ArgsTuple may have top-level const or reference modifiers. | ||||
|   typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(ArgsTuple)) RawArgsTuple; | ||||
|   typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(ArgsTuple)) RawArgsTuple; | ||||
|   typedef typename internal::TupleFields<RawArgsTuple, $ks>::type SelectedArgs; | ||||
|   typedef Matcher<const SelectedArgs&> MonomorphicInnerMatcher; | ||||
|  | ||||
| @@ -201,7 +200,7 @@ class ElementsAreMatcher$i { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
|   | ||||
| @@ -45,7 +45,6 @@ | ||||
| #include <string> | ||||
| #include <vector> | ||||
|  | ||||
| #include <gmock/gmock-printers.h> | ||||
| #include <gmock/internal/gmock-internal-utils.h> | ||||
| #include <gmock/internal/gmock-port.h> | ||||
| #include <gtest/gtest.h> | ||||
| @@ -419,20 +418,20 @@ class SafeMatcherCastImpl { | ||||
|   template <typename U> | ||||
|   static inline Matcher<T> Cast(const Matcher<U>& matcher) { | ||||
|     // Enforce that T can be implicitly converted to U. | ||||
|     GMOCK_COMPILE_ASSERT_((internal::ImplicitlyConvertible<T, U>::value), | ||||
|     GTEST_COMPILE_ASSERT_((internal::ImplicitlyConvertible<T, U>::value), | ||||
|                           T_must_be_implicitly_convertible_to_U); | ||||
|     // Enforce that we are not converting a non-reference type T to a reference | ||||
|     // type U. | ||||
|     GMOCK_COMPILE_ASSERT_( | ||||
|     GTEST_COMPILE_ASSERT_( | ||||
|         internal::is_reference<T>::value || !internal::is_reference<U>::value, | ||||
|         cannot_convert_non_referentce_arg_to_reference); | ||||
|     // In case both T and U are arithmetic types, enforce that the | ||||
|     // conversion is not lossy. | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(T)) RawT; | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(U)) RawU; | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(T)) RawT; | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(U)) RawU; | ||||
|     const bool kTIsOther = GMOCK_KIND_OF_(RawT) == internal::kOther; | ||||
|     const bool kUIsOther = GMOCK_KIND_OF_(RawU) == internal::kOther; | ||||
|     GMOCK_COMPILE_ASSERT_( | ||||
|     GTEST_COMPILE_ASSERT_( | ||||
|         kTIsOther || kUIsOther || | ||||
|         (internal::LosslessArithmeticConvertible<RawT, RawU>::value), | ||||
|         conversion_of_arithmetic_types_must_be_lossless); | ||||
| @@ -566,7 +565,7 @@ bool TupleMatches(const MatcherTuple& matcher_tuple, | ||||
|   using ::std::tr1::tuple_size; | ||||
|   // Makes sure that matcher_tuple and value_tuple have the same | ||||
|   // number of fields. | ||||
|   GMOCK_COMPILE_ASSERT_(tuple_size<MatcherTuple>::value == | ||||
|   GTEST_COMPILE_ASSERT_(tuple_size<MatcherTuple>::value == | ||||
|                         tuple_size<ValueTuple>::value, | ||||
|                         matcher_and_value_have_different_numbers_of_fields); | ||||
|   return TuplePrefix<tuple_size<ValueTuple>::value>:: | ||||
| @@ -1604,8 +1603,8 @@ class PointeeMatcher { | ||||
|   template <typename Pointer> | ||||
|   class Impl : public MatcherInterface<Pointer> { | ||||
|    public: | ||||
|     typedef typename PointeeOf<GMOCK_REMOVE_CONST_(  // NOLINT | ||||
|         GMOCK_REMOVE_REFERENCE_(Pointer))>::type Pointee; | ||||
|     typedef typename PointeeOf<GTEST_REMOVE_CONST_(  // NOLINT | ||||
|         GTEST_REMOVE_REFERENCE_(Pointer))>::type Pointee; | ||||
|  | ||||
|     explicit Impl(const InnerMatcher& matcher) | ||||
|         : matcher_(MatcherCast<const Pointee&>(matcher)) {} | ||||
| @@ -1663,7 +1662,7 @@ class FieldMatcher { | ||||
|   bool MatchAndExplain(const T& value, MatchResultListener* listener) const { | ||||
|     return MatchAndExplainImpl( | ||||
|         typename ::testing::internal:: | ||||
|             is_pointer<GMOCK_REMOVE_CONST_(T)>::type(), | ||||
|             is_pointer<GTEST_REMOVE_CONST_(T)>::type(), | ||||
|         value, listener); | ||||
|   } | ||||
|  | ||||
| @@ -1702,9 +1701,9 @@ class PropertyMatcher { | ||||
|  public: | ||||
|   // The property may have a reference type, so 'const PropertyType&' | ||||
|   // may cause double references and fail to compile.  That's why we | ||||
|   // need GMOCK_REFERENCE_TO_CONST, which works regardless of | ||||
|   // need GTEST_REFERENCE_TO_CONST, which works regardless of | ||||
|   // PropertyType being a reference or not. | ||||
|   typedef GMOCK_REFERENCE_TO_CONST_(PropertyType) RefToConstProperty; | ||||
|   typedef GTEST_REFERENCE_TO_CONST_(PropertyType) RefToConstProperty; | ||||
|  | ||||
|   PropertyMatcher(PropertyType (Class::*property)() const, | ||||
|                   const Matcher<RefToConstProperty>& matcher) | ||||
| @@ -1724,7 +1723,7 @@ class PropertyMatcher { | ||||
|   bool MatchAndExplain(const T&value, MatchResultListener* listener) const { | ||||
|     return MatchAndExplainImpl( | ||||
|         typename ::testing::internal:: | ||||
|             is_pointer<GMOCK_REMOVE_CONST_(T)>::type(), | ||||
|             is_pointer<GTEST_REMOVE_CONST_(T)>::type(), | ||||
|         value, listener); | ||||
|   } | ||||
|  | ||||
| @@ -1875,7 +1874,7 @@ class ContainerEqMatcher { | ||||
|     // Makes sure the user doesn't instantiate this class template | ||||
|     // with a const or reference type. | ||||
|     testing::StaticAssertTypeEq<Container, | ||||
|         GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container))>(); | ||||
|         GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container))>(); | ||||
|   } | ||||
|  | ||||
|   void DescribeTo(::std::ostream* os) const { | ||||
| @@ -1890,9 +1889,9 @@ class ContainerEqMatcher { | ||||
|   template <typename LhsContainer> | ||||
|   bool MatchAndExplain(const LhsContainer& lhs, | ||||
|                        MatchResultListener* listener) const { | ||||
|     // GMOCK_REMOVE_CONST_() is needed to work around an MSVC 8.0 bug | ||||
|     // GTEST_REMOVE_CONST_() is needed to work around an MSVC 8.0 bug | ||||
|     // that causes LhsContainer to be a const type sometimes. | ||||
|     typedef internal::StlContainerView<GMOCK_REMOVE_CONST_(LhsContainer)> | ||||
|     typedef internal::StlContainerView<GTEST_REMOVE_CONST_(LhsContainer)> | ||||
|         LhsView; | ||||
|     typedef typename LhsView::type LhsStlContainer; | ||||
|     StlContainerReference lhs_stl_container = LhsView::ConstReference(lhs); | ||||
| @@ -1951,7 +1950,7 @@ class ContainerEqMatcher { | ||||
| template <typename Container> | ||||
| class QuantifierMatcherImpl : public MatcherInterface<Container> { | ||||
|  public: | ||||
|   typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) RawContainer; | ||||
|   typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) RawContainer; | ||||
|   typedef StlContainerView<RawContainer> View; | ||||
|   typedef typename View::type StlContainer; | ||||
|   typedef typename View::const_reference StlContainerReference; | ||||
| @@ -2090,7 +2089,7 @@ class EachMatcher { | ||||
| template <typename PairType> | ||||
| class KeyMatcherImpl : public MatcherInterface<PairType> { | ||||
|  public: | ||||
|   typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(PairType)) RawPairType; | ||||
|   typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(PairType)) RawPairType; | ||||
|   typedef typename RawPairType::first_type KeyType; | ||||
|  | ||||
|   template <typename InnerMatcher> | ||||
| @@ -2152,7 +2151,7 @@ class KeyMatcher { | ||||
| template <typename PairType> | ||||
| class PairMatcherImpl : public MatcherInterface<PairType> { | ||||
|  public: | ||||
|   typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(PairType)) RawPairType; | ||||
|   typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(PairType)) RawPairType; | ||||
|   typedef typename RawPairType::first_type FirstType; | ||||
|   typedef typename RawPairType::second_type SecondType; | ||||
|  | ||||
| @@ -2259,7 +2258,7 @@ class PairMatcher { | ||||
| template <typename Container> | ||||
| class ElementsAreMatcherImpl : public MatcherInterface<Container> { | ||||
|  public: | ||||
|   typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) RawContainer; | ||||
|   typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) RawContainer; | ||||
|   typedef internal::StlContainerView<RawContainer> View; | ||||
|   typedef typename View::type StlContainer; | ||||
|   typedef typename View::const_reference StlContainerReference; | ||||
| @@ -2378,7 +2377,7 @@ class ElementsAreMatcher0 { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -2397,7 +2396,7 @@ class ElementsAreArrayMatcher { | ||||
|  | ||||
|   template <typename Container> | ||||
|   operator Matcher<Container>() const { | ||||
|     typedef GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Container)) | ||||
|     typedef GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(Container)) | ||||
|         RawContainer; | ||||
|     typedef typename internal::StlContainerView<RawContainer>::type::value_type | ||||
|         Element; | ||||
| @@ -2609,7 +2608,7 @@ inline PolymorphicMatcher< | ||||
|   return MakePolymorphicMatcher( | ||||
|       internal::PropertyMatcher<Class, PropertyType>( | ||||
|           property, | ||||
|           MatcherCast<GMOCK_REFERENCE_TO_CONST_(PropertyType)>(matcher))); | ||||
|           MatcherCast<GTEST_REFERENCE_TO_CONST_(PropertyType)>(matcher))); | ||||
|   // The call to MatcherCast() is required for supporting inner | ||||
|   // matchers of compatible types.  For example, it allows | ||||
|   //   Property(&Foo::bar, m) | ||||
| @@ -2893,11 +2892,11 @@ Truly(Predicate pred) { | ||||
| // values and order differences are not explained.) | ||||
| template <typename Container> | ||||
| inline PolymorphicMatcher<internal::ContainerEqMatcher<  // NOLINT | ||||
|                             GMOCK_REMOVE_CONST_(Container)> > | ||||
|                             GTEST_REMOVE_CONST_(Container)> > | ||||
|     ContainerEq(const Container& rhs) { | ||||
|   // This following line is for working around a bug in MSVC 8.0, | ||||
|   // which causes Container to be a const type sometimes. | ||||
|   typedef GMOCK_REMOVE_CONST_(Container) RawContainer; | ||||
|   typedef GTEST_REMOVE_CONST_(Container) RawContainer; | ||||
|   return MakePolymorphicMatcher( | ||||
|       internal::ContainerEqMatcher<RawContainer>(rhs)); | ||||
| } | ||||
|   | ||||
| @@ -162,7 +162,7 @@ ACTION_TEMPLATE(SetArgReferee, | ||||
|   // Ensures that argument #k is a reference.  If you get a compiler | ||||
|   // error on the next line, you are using SetArgReferee<k>(value) in | ||||
|   // a mock function whose k-th (0-based) argument is not a reference. | ||||
|   GMOCK_COMPILE_ASSERT_(internal::is_reference<argk_type>::value, | ||||
|   GTEST_COMPILE_ASSERT_(internal::is_reference<argk_type>::value, | ||||
|                         SetArgReferee_must_be_used_with_a_reference_argument); | ||||
|   ::std::tr1::get<k>(args) = value; | ||||
| } | ||||
|   | ||||
| @@ -1,725 +0,0 @@ | ||||
| // Copyright 2007, Google Inc. | ||||
| // All rights reserved. | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without | ||||
| // modification, are permitted provided that the following conditions are | ||||
| // met: | ||||
| // | ||||
| //     * Redistributions of source code must retain the above copyright | ||||
| // notice, this list of conditions and the following disclaimer. | ||||
| //     * Redistributions in binary form must reproduce the above | ||||
| // copyright notice, this list of conditions and the following disclaimer | ||||
| // in the documentation and/or other materials provided with the | ||||
| // distribution. | ||||
| //     * Neither the name of Google Inc. nor the names of its | ||||
| // contributors may be used to endorse or promote products derived from | ||||
| // this software without specific prior written permission. | ||||
| // | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
| // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
| // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
| // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
| // 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 a universal value printer that can print a | ||||
| // value of any type T: | ||||
| // | ||||
| //   void ::testing::internal::UniversalPrinter<T>::Print(value, ostream_ptr); | ||||
| // | ||||
| // A user can teach this function how to print a class type T by | ||||
| // defining either operator<<() or PrintTo() in the namespace that | ||||
| // defines T.  More specifically, the FIRST defined function in the | ||||
| // following list will be used (assuming T is defined in namespace | ||||
| // foo): | ||||
| // | ||||
| //   1. foo::PrintTo(const T&, ostream*) | ||||
| //   2. operator<<(ostream&, const T&) defined in either foo or the | ||||
| //      global namespace. | ||||
| // | ||||
| // If none of the above is defined, it will print the debug string of | ||||
| // the value if it is a protocol buffer, or print the raw bytes in the | ||||
| // value otherwise. | ||||
| // | ||||
| // To aid debugging: when T is a reference type, the address of the | ||||
| // value is also printed; when T is a (const) char pointer, both the | ||||
| // pointer value and the NUL-terminated string it points to are | ||||
| // printed. | ||||
| // | ||||
| // We also provide some convenient wrappers: | ||||
| // | ||||
| //   // Prints a value to a string.  For a (const or not) char | ||||
| //   // pointer, the NUL-terminated string (but not the pointer) is | ||||
| //   // printed. | ||||
| //   std::string ::testing::PrintToString(const T& value); | ||||
| // | ||||
| //   // Prints a value tersely: for a reference type, the referenced | ||||
| //   // value (but not the address) is printed; for a (const or not) char | ||||
| //   // pointer, the NUL-terminated string (but not the pointer) is | ||||
| //   // printed. | ||||
| //   void ::testing::internal::UniversalTersePrint(const T& value, ostream*); | ||||
| // | ||||
| //   // Prints value using the type inferred by the compiler.  The difference | ||||
| //   // from UniversalTersePrint() is that this function prints both the | ||||
| //   // pointer and the NUL-terminated string for a (const or not) char pointer. | ||||
| //   void ::testing::internal::UniversalPrint(const T& value, ostream*); | ||||
| // | ||||
| //   // Prints the fields of a tuple tersely to a string vector, one | ||||
| //   // element for each field. | ||||
| //   std::vector<string> UniversalTersePrintTupleFieldsToStrings( | ||||
| //       const Tuple& value); | ||||
| // | ||||
| // Known limitation: | ||||
| // | ||||
| // The print primitives print the elements of an STL-style container | ||||
| // using the compiler-inferred type of *iter where iter is a | ||||
| // const_iterator of the container.  When const_iterator is an input | ||||
| // iterator but not a forward iterator, this inferred type may not | ||||
| // match value_type, and the print output may be incorrect.  In | ||||
| // practice, this is rarely a problem as for most containers | ||||
| // const_iterator is a forward iterator.  We'll fix this if there's an | ||||
| // actual need for it.  Note that this fix cannot rely on value_type | ||||
| // being defined as many user-defined container types don't have | ||||
| // value_type. | ||||
|  | ||||
| #ifndef GMOCK_INCLUDE_GMOCK_GMOCK_PRINTERS_H_ | ||||
| #define GMOCK_INCLUDE_GMOCK_GMOCK_PRINTERS_H_ | ||||
|  | ||||
| #include <ostream>  // NOLINT | ||||
| #include <sstream> | ||||
| #include <string> | ||||
| #include <utility> | ||||
| #include <vector> | ||||
|  | ||||
| #include <gmock/internal/gmock-internal-utils.h> | ||||
| #include <gmock/internal/gmock-port.h> | ||||
| #include <gtest/gtest.h> | ||||
|  | ||||
| namespace testing { | ||||
|  | ||||
| // Definitions in the 'internal' and 'internal2' name spaces are | ||||
| // subject to change without notice.  DO NOT USE THEM IN USER CODE! | ||||
| namespace internal2 { | ||||
|  | ||||
| // Prints the given number of bytes in the given object to the given | ||||
| // ostream. | ||||
| void PrintBytesInObjectTo(const unsigned char* obj_bytes, | ||||
|                           size_t count, | ||||
|                           ::std::ostream* os); | ||||
|  | ||||
| // TypeWithoutFormatter<T, kIsProto>::PrintValue(value, os) is called | ||||
| // by the universal printer to print a value of type T when neither | ||||
| // operator<< nor PrintTo() is defined for type T.  When T is | ||||
| // ProtocolMessage, proto2::Message, or a subclass of those, kIsProto | ||||
| // will be true and the short debug string of the protocol message | ||||
| // value will be printed; otherwise kIsProto will be false and the | ||||
| // bytes in the value will be printed. | ||||
| template <typename T, bool kIsProto> | ||||
| class TypeWithoutFormatter { | ||||
|  public: | ||||
|   static void PrintValue(const T& value, ::std::ostream* os) { | ||||
|     PrintBytesInObjectTo(reinterpret_cast<const unsigned char*>(&value), | ||||
|                          sizeof(value), os); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| // We print a protobuf using its ShortDebugString() when the string | ||||
| // doesn't exceed this many characters; otherwise we print it using | ||||
| // DebugString() for better readability. | ||||
| const size_t kProtobufOneLinerMaxLength = 50; | ||||
|  | ||||
| template <typename T> | ||||
| class TypeWithoutFormatter<T, true> { | ||||
|  public: | ||||
|   static void PrintValue(const T& value, ::std::ostream* os) { | ||||
|     const ::testing::internal::string short_str = value.ShortDebugString(); | ||||
|     const ::testing::internal::string pretty_str = | ||||
|         short_str.length() <= kProtobufOneLinerMaxLength ? | ||||
|         short_str : ("\n" + value.DebugString()); | ||||
|     ::std::operator<<(*os, "<" + pretty_str + ">"); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| // Prints the given value to the given ostream.  If the value is a | ||||
| // protocol message, its short debug string is printed; otherwise the | ||||
| // bytes in the value are printed.  This is what | ||||
| // UniversalPrinter<T>::Print() does when it knows nothing about type | ||||
| // T and T has no << operator. | ||||
| // | ||||
| // A user can override this behavior for a class type Foo by defining | ||||
| // a << operator in the namespace where Foo is defined. | ||||
| // | ||||
| // We put this operator in namespace 'internal2' instead of 'internal' | ||||
| // to simplify the implementation, as much code in 'internal' needs to | ||||
| // use << in STL, which would conflict with our own << were it defined | ||||
| // in 'internal'. | ||||
| // | ||||
| // Note that this operator<< takes a generic std::basic_ostream<Char, | ||||
| // CharTraits> type instead of the more restricted std::ostream.  If | ||||
| // we define it to take an std::ostream instead, we'll get an | ||||
| // "ambiguous overloads" compiler error when trying to print a type | ||||
| // Foo that supports streaming to std::basic_ostream<Char, | ||||
| // CharTraits>, as the compiler cannot tell whether | ||||
| // operator<<(std::ostream&, const T&) or | ||||
| // operator<<(std::basic_stream<Char, CharTraits>, const Foo&) is more | ||||
| // specific. | ||||
| template <typename Char, typename CharTraits, typename T> | ||||
| ::std::basic_ostream<Char, CharTraits>& operator<<( | ||||
|     ::std::basic_ostream<Char, CharTraits>& os, const T& x) { | ||||
|   TypeWithoutFormatter<T, ::testing::internal::IsAProtocolMessage<T>::value>:: | ||||
|       PrintValue(x, &os); | ||||
|   return os; | ||||
| } | ||||
|  | ||||
| }  // namespace internal2 | ||||
| }  // namespace testing | ||||
|  | ||||
| // This namespace MUST NOT BE NESTED IN ::testing, or the name look-up | ||||
| // magic needed for implementing UniversalPrinter won't work. | ||||
| namespace testing_internal { | ||||
|  | ||||
| // Used to print a value that is not an STL-style container when the | ||||
| // user doesn't define PrintTo() for it. | ||||
| template <typename T> | ||||
| void DefaultPrintNonContainerTo(const T& value, ::std::ostream* os) { | ||||
|   // With the following statement, during unqualified name lookup, | ||||
|   // testing::internal2::operator<< appears as if it was declared in | ||||
|   // the nearest enclosing namespace that contains both | ||||
|   // ::testing_internal and ::testing::internal2, i.e. the global | ||||
|   // namespace.  For more details, refer to the C++ Standard section | ||||
|   // 7.3.4-1 [namespace.udir].  This allows us to fall back onto | ||||
|   // testing::internal2::operator<< in case T doesn't come with a << | ||||
|   // operator. | ||||
|   // | ||||
|   // We cannot write 'using ::testing::internal2::operator<<;', which | ||||
|   // gcc 3.3 fails to compile due to a compiler bug. | ||||
|   using namespace ::testing::internal2;  // NOLINT | ||||
|  | ||||
|   // Assuming T is defined in namespace foo, in the next statement, | ||||
|   // the compiler will consider all of: | ||||
|   // | ||||
|   //   1. foo::operator<< (thanks to Koenig look-up), | ||||
|   //   2. ::operator<< (as the current namespace is enclosed in ::), | ||||
|   //   3. testing::internal2::operator<< (thanks to the using statement above). | ||||
|   // | ||||
|   // The operator<< whose type matches T best will be picked. | ||||
|   // | ||||
|   // We deliberately allow #2 to be a candidate, as sometimes it's | ||||
|   // impossible to define #1 (e.g. when foo is ::std, defining | ||||
|   // anything in it is undefined behavior unless you are a compiler | ||||
|   // vendor.). | ||||
|   *os << value; | ||||
| } | ||||
|  | ||||
| }  // namespace testing_internal | ||||
|  | ||||
| namespace testing { | ||||
| namespace internal { | ||||
|  | ||||
| // UniversalPrinter<T>::Print(value, ostream_ptr) prints the given | ||||
| // value to the given ostream.  The caller must ensure that | ||||
| // 'ostream_ptr' is not NULL, or the behavior is undefined. | ||||
| // | ||||
| // We define UniversalPrinter as a class template (as opposed to a | ||||
| // function template), as we need to partially specialize it for | ||||
| // reference types, which cannot be done with function templates. | ||||
| template <typename T> | ||||
| class UniversalPrinter; | ||||
|  | ||||
| template <typename T> | ||||
| void UniversalPrint(const T& value, ::std::ostream* os); | ||||
|  | ||||
| // Used to print an STL-style container when the user doesn't define | ||||
| // a PrintTo() for it. | ||||
| template <typename C> | ||||
| void DefaultPrintTo(IsContainer /* dummy */, | ||||
|                     false_type /* is not a pointer */, | ||||
|                     const C& container, ::std::ostream* os) { | ||||
|   const size_t kMaxCount = 32;  // The maximum number of elements to print. | ||||
|   *os << '{'; | ||||
|   size_t count = 0; | ||||
|   for (typename C::const_iterator it = container.begin(); | ||||
|        it != container.end(); ++it, ++count) { | ||||
|     if (count > 0) { | ||||
|       *os << ','; | ||||
|       if (count == kMaxCount) {  // Enough has been printed. | ||||
|         *os << " ..."; | ||||
|         break; | ||||
|       } | ||||
|     } | ||||
|     *os << ' '; | ||||
|     // We cannot call PrintTo(*it, os) here as PrintTo() doesn't | ||||
|     // handle *it being a native array. | ||||
|     internal::UniversalPrint(*it, os); | ||||
|   } | ||||
|  | ||||
|   if (count > 0) { | ||||
|     *os << ' '; | ||||
|   } | ||||
|   *os << '}'; | ||||
| } | ||||
|  | ||||
| // Used to print a pointer that is neither a char pointer nor a member | ||||
| // pointer, when the user doesn't define PrintTo() for it.  (A member | ||||
| // variable pointer or member function pointer doesn't really point to | ||||
| // a location in the address space.  Their representation is | ||||
| // implementation-defined.  Therefore they will be printed as raw | ||||
| // bytes.) | ||||
| template <typename T> | ||||
| void DefaultPrintTo(IsNotContainer /* dummy */, | ||||
|                     true_type /* is a pointer */, | ||||
|                     T* p, ::std::ostream* os) { | ||||
|   if (p == NULL) { | ||||
|     *os << "NULL"; | ||||
|   } else { | ||||
|     // We want to print p as a const void*.  However, we cannot cast | ||||
|     // it to const void* directly, even using reinterpret_cast, as | ||||
|     // earlier versions of gcc (e.g. 3.4.5) cannot compile the cast | ||||
|     // when p is a function pointer.  Casting to UInt64 first solves | ||||
|     // the problem. | ||||
|     *os << reinterpret_cast<const void*>(reinterpret_cast<internal::UInt64>(p)); | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Used to print a non-container, non-pointer value when the user | ||||
| // doesn't define PrintTo() for it. | ||||
| template <typename T> | ||||
| void DefaultPrintTo(IsNotContainer /* dummy */, | ||||
|                     false_type /* is not a pointer */, | ||||
|                     const T& value, ::std::ostream* os) { | ||||
|   ::testing_internal::DefaultPrintNonContainerTo(value, os); | ||||
| } | ||||
|  | ||||
| // Prints the given value using the << operator if it has one; | ||||
| // otherwise prints the bytes in it.  This is what | ||||
| // UniversalPrinter<T>::Print() does when PrintTo() is not specialized | ||||
| // or overloaded for type T. | ||||
| // | ||||
| // A user can override this behavior for a class type Foo by defining | ||||
| // an overload of PrintTo() in the namespace where Foo is defined.  We | ||||
| // give the user this option as sometimes defining a << operator for | ||||
| // Foo is not desirable (e.g. the coding style may prevent doing it, | ||||
| // or there is already a << operator but it doesn't do what the user | ||||
| // wants). | ||||
| template <typename T> | ||||
| void PrintTo(const T& value, ::std::ostream* os) { | ||||
|   // DefaultPrintTo() is overloaded.  The type of its first two | ||||
|   // arguments determine which version will be picked.  If T is an | ||||
|   // STL-style container, the version for container will be called; if | ||||
|   // T is a pointer, the pointer version will be called; otherwise the | ||||
|   // generic version will be called. | ||||
|   // | ||||
|   // Note that we check for container types here, prior to we check | ||||
|   // for protocol message types in our operator<<.  The rationale is: | ||||
|   // | ||||
|   // For protocol messages, we want to give people a chance to | ||||
|   // override Google Mock's format by defining a PrintTo() or | ||||
|   // operator<<.  For STL containers, other formats can be | ||||
|   // incompatible with Google Mock's format for the container | ||||
|   // elements; therefore we check for container types here to ensure | ||||
|   // that our format is used. | ||||
|   // | ||||
|   // The second argument of DefaultPrintTo() is needed to bypass a bug | ||||
|   // in Symbian's C++ compiler that prevents it from picking the right | ||||
|   // overload between: | ||||
|   // | ||||
|   //   PrintTo(const T& x, ...); | ||||
|   //   PrintTo(T* x, ...); | ||||
|   DefaultPrintTo(IsContainerTest<T>(0), is_pointer<T>(), value, os); | ||||
| } | ||||
|  | ||||
| // The following list of PrintTo() overloads tells | ||||
| // UniversalPrinter<T>::Print() how to print standard types (built-in | ||||
| // types, strings, plain arrays, and pointers). | ||||
|  | ||||
| // Overloads for various char types. | ||||
| void PrintCharTo(char c, int char_code, ::std::ostream* os); | ||||
| inline void PrintTo(unsigned char c, ::std::ostream* os) { | ||||
|   PrintCharTo(c, c, os); | ||||
| } | ||||
| inline void PrintTo(signed char c, ::std::ostream* os) { | ||||
|   PrintCharTo(c, c, os); | ||||
| } | ||||
| inline void PrintTo(char c, ::std::ostream* os) { | ||||
|   // When printing a plain char, we always treat it as unsigned.  This | ||||
|   // way, the output won't be affected by whether the compiler thinks | ||||
|   // char is signed or not. | ||||
|   PrintTo(static_cast<unsigned char>(c), os); | ||||
| } | ||||
|  | ||||
| // Overloads for other simple built-in types. | ||||
| inline void PrintTo(bool x, ::std::ostream* os) { | ||||
|   *os << (x ? "true" : "false"); | ||||
| } | ||||
|  | ||||
| // Overload for wchar_t type. | ||||
| // Prints a wchar_t as a symbol if it is printable or as its internal | ||||
| // code otherwise and also as its decimal code (except for L'\0'). | ||||
| // The L'\0' char is printed as "L'\\0'". The decimal code is printed | ||||
| // as signed integer when wchar_t is implemented by the compiler | ||||
| // as a signed type and is printed as an unsigned integer when wchar_t | ||||
| // is implemented as an unsigned type. | ||||
| void PrintTo(wchar_t wc, ::std::ostream* os); | ||||
|  | ||||
| // Overloads for C strings. | ||||
| void PrintTo(const char* s, ::std::ostream* os); | ||||
| inline void PrintTo(char* s, ::std::ostream* os) { | ||||
|   PrintTo(implicit_cast<const char*>(s), os); | ||||
| } | ||||
|  | ||||
| // MSVC can be configured to define wchar_t as a typedef of unsigned | ||||
| // short.  It defines _NATIVE_WCHAR_T_DEFINED when wchar_t is a native | ||||
| // type.  When wchar_t is a typedef, defining an overload for const | ||||
| // wchar_t* would cause unsigned short* be printed as a wide string, | ||||
| // possibly causing invalid memory accesses. | ||||
| #if !defined(_MSC_VER) || defined(_NATIVE_WCHAR_T_DEFINED) | ||||
| // Overloads for wide C strings | ||||
| void PrintTo(const wchar_t* s, ::std::ostream* os); | ||||
| inline void PrintTo(wchar_t* s, ::std::ostream* os) { | ||||
|   PrintTo(implicit_cast<const wchar_t*>(s), os); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| // Overload for C arrays.  Multi-dimensional arrays are printed | ||||
| // properly. | ||||
|  | ||||
| // Prints the given number of elements in an array, without printing | ||||
| // the curly braces. | ||||
| template <typename T> | ||||
| void PrintRawArrayTo(const T a[], size_t count, ::std::ostream* os) { | ||||
|   UniversalPrinter<T>::Print(a[0], os); | ||||
|   for (size_t i = 1; i != count; i++) { | ||||
|     *os << ", "; | ||||
|     UniversalPrinter<T>::Print(a[i], os); | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Overloads for ::string and ::std::string. | ||||
| #if GTEST_HAS_GLOBAL_STRING | ||||
| void PrintStringTo(const ::string&s, ::std::ostream* os); | ||||
| inline void PrintTo(const ::string& s, ::std::ostream* os) { | ||||
|   PrintStringTo(s, os); | ||||
| } | ||||
| #endif  // GTEST_HAS_GLOBAL_STRING | ||||
|  | ||||
| void PrintStringTo(const ::std::string&s, ::std::ostream* os); | ||||
| inline void PrintTo(const ::std::string& s, ::std::ostream* os) { | ||||
|   PrintStringTo(s, os); | ||||
| } | ||||
|  | ||||
| // Overloads for ::wstring and ::std::wstring. | ||||
| #if GTEST_HAS_GLOBAL_WSTRING | ||||
| void PrintWideStringTo(const ::wstring&s, ::std::ostream* os); | ||||
| inline void PrintTo(const ::wstring& s, ::std::ostream* os) { | ||||
|   PrintWideStringTo(s, os); | ||||
| } | ||||
| #endif  // GTEST_HAS_GLOBAL_WSTRING | ||||
|  | ||||
| #if GTEST_HAS_STD_WSTRING | ||||
| void PrintWideStringTo(const ::std::wstring&s, ::std::ostream* os); | ||||
| inline void PrintTo(const ::std::wstring& s, ::std::ostream* os) { | ||||
|   PrintWideStringTo(s, os); | ||||
| } | ||||
| #endif  // GTEST_HAS_STD_WSTRING | ||||
|  | ||||
| // Overload for ::std::tr1::tuple.  Needed for printing function | ||||
| // arguments, which are packed as tuples. | ||||
|  | ||||
| // Helper function for printing a tuple.  T must be instantiated with | ||||
| // a tuple type. | ||||
| template <typename T> | ||||
| void PrintTupleTo(const T& t, ::std::ostream* os); | ||||
|  | ||||
| // Overloaded PrintTo() for tuples of various arities.  We support | ||||
| // tuples of up-to 10 fields.  The following implementation works | ||||
| // regardless of whether tr1::tuple is implemented using the | ||||
| // non-standard variadic template feature or not. | ||||
|  | ||||
| inline void PrintTo(const ::std::tr1::tuple<>& t, ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1> | ||||
| void PrintTo(const ::std::tr1::tuple<T1>& t, ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2> | ||||
| void PrintTo(const ::std::tr1::tuple<T1, T2>& t, ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2, typename T3> | ||||
| void PrintTo(const ::std::tr1::tuple<T1, T2, T3>& t, ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2, typename T3, typename T4> | ||||
| void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4>& t, ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2, typename T3, typename T4, typename T5> | ||||
| void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5>& t, | ||||
|              ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2, typename T3, typename T4, typename T5, | ||||
|           typename T6> | ||||
| void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6>& t, | ||||
|              ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2, typename T3, typename T4, typename T5, | ||||
|           typename T6, typename T7> | ||||
| void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7>& t, | ||||
|              ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2, typename T3, typename T4, typename T5, | ||||
|           typename T6, typename T7, typename T8> | ||||
| void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8>& t, | ||||
|              ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2, typename T3, typename T4, typename T5, | ||||
|           typename T6, typename T7, typename T8, typename T9> | ||||
| void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9>& t, | ||||
|              ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| template <typename T1, typename T2, typename T3, typename T4, typename T5, | ||||
|           typename T6, typename T7, typename T8, typename T9, typename T10> | ||||
| void PrintTo( | ||||
|     const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>& t, | ||||
|     ::std::ostream* os) { | ||||
|   PrintTupleTo(t, os); | ||||
| } | ||||
|  | ||||
| // Overload for std::pair. | ||||
| template <typename T1, typename T2> | ||||
| void PrintTo(const ::std::pair<T1, T2>& value, ::std::ostream* os) { | ||||
|   *os << '('; | ||||
|   UniversalPrinter<T1>::Print(value.first, os); | ||||
|   *os << ", "; | ||||
|   UniversalPrinter<T2>::Print(value.second, os); | ||||
|   *os << ')'; | ||||
| } | ||||
|  | ||||
| // Implements printing a non-reference type T by letting the compiler | ||||
| // pick the right overload of PrintTo() for T. | ||||
| template <typename T> | ||||
| class UniversalPrinter { | ||||
|  public: | ||||
|   // MSVC warns about adding const to a function type, so we want to | ||||
|   // disable the warning. | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(push)          // Saves the current warning state. | ||||
| #pragma warning(disable:4180)  // Temporarily disables warning 4180. | ||||
| #endif  // _MSC_VER | ||||
|  | ||||
|   // Note: we deliberately don't call this PrintTo(), as that name | ||||
|   // conflicts with ::testing::internal::PrintTo in the body of the | ||||
|   // function. | ||||
|   static void Print(const T& value, ::std::ostream* os) { | ||||
|     // By default, ::testing::internal::PrintTo() is used for printing | ||||
|     // the value. | ||||
|     // | ||||
|     // Thanks to Koenig look-up, if T is a class and has its own | ||||
|     // PrintTo() function defined in its namespace, that function will | ||||
|     // be visible here.  Since it is more specific than the generic ones | ||||
|     // in ::testing::internal, it will be picked by the compiler in the | ||||
|     // following statement - exactly what we want. | ||||
|     PrintTo(value, os); | ||||
|   } | ||||
|  | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(pop)           // Restores the warning state. | ||||
| #endif  // _MSC_VER | ||||
| }; | ||||
|  | ||||
| // UniversalPrintArray(begin, len, os) prints an array of 'len' | ||||
| // elements, starting at address 'begin'. | ||||
| template <typename T> | ||||
| void UniversalPrintArray(const T* begin, size_t len, ::std::ostream* os) { | ||||
|   if (len == 0) { | ||||
|     *os << "{}"; | ||||
|   } else { | ||||
|     *os << "{ "; | ||||
|     const size_t kThreshold = 18; | ||||
|     const size_t kChunkSize = 8; | ||||
|     // If the array has more than kThreshold elements, we'll have to | ||||
|     // omit some details by printing only the first and the last | ||||
|     // kChunkSize elements. | ||||
|     // TODO(wan@google.com): let the user control the threshold using a flag. | ||||
|     if (len <= kThreshold) { | ||||
|       PrintRawArrayTo(begin, len, os); | ||||
|     } else { | ||||
|       PrintRawArrayTo(begin, kChunkSize, os); | ||||
|       *os << ", ..., "; | ||||
|       PrintRawArrayTo(begin + len - kChunkSize, kChunkSize, os); | ||||
|     } | ||||
|     *os << " }"; | ||||
|   } | ||||
| } | ||||
| // This overload prints a (const) char array compactly. | ||||
| void UniversalPrintArray(const char* begin, size_t len, ::std::ostream* os); | ||||
|  | ||||
| // Implements printing an array type T[N]. | ||||
| template <typename T, size_t N> | ||||
| class UniversalPrinter<T[N]> { | ||||
|  public: | ||||
|   // Prints the given array, omitting some elements when there are too | ||||
|   // many. | ||||
|   static void Print(const T (&a)[N], ::std::ostream* os) { | ||||
|     UniversalPrintArray(a, N, os); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| // Implements printing a reference type T&. | ||||
| template <typename T> | ||||
| class UniversalPrinter<T&> { | ||||
|  public: | ||||
|   // MSVC warns about adding const to a function type, so we want to | ||||
|   // disable the warning. | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(push)          // Saves the current warning state. | ||||
| #pragma warning(disable:4180)  // Temporarily disables warning 4180. | ||||
| #endif  // _MSC_VER | ||||
|  | ||||
|   static void Print(const T& value, ::std::ostream* os) { | ||||
|     // Prints the address of the value.  We use reinterpret_cast here | ||||
|     // as static_cast doesn't compile when T is a function type. | ||||
|     *os << "@" << reinterpret_cast<const void*>(&value) << " "; | ||||
|  | ||||
|     // Then prints the value itself. | ||||
|     UniversalPrinter<T>::Print(value, os); | ||||
|   } | ||||
|  | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(pop)           // Restores the warning state. | ||||
| #endif  // _MSC_VER | ||||
| }; | ||||
|  | ||||
| // Prints a value tersely: for a reference type, the referenced value | ||||
| // (but not the address) is printed; for a (const) char pointer, the | ||||
| // NUL-terminated string (but not the pointer) is printed. | ||||
| template <typename T> | ||||
| void UniversalTersePrint(const T& value, ::std::ostream* os) { | ||||
|   UniversalPrinter<T>::Print(value, os); | ||||
| } | ||||
| inline void UniversalTersePrint(const char* str, ::std::ostream* os) { | ||||
|   if (str == NULL) { | ||||
|     *os << "NULL"; | ||||
|   } else { | ||||
|     UniversalPrinter<string>::Print(string(str), os); | ||||
|   } | ||||
| } | ||||
| inline void UniversalTersePrint(char* str, ::std::ostream* os) { | ||||
|   UniversalTersePrint(static_cast<const char*>(str), os); | ||||
| } | ||||
|  | ||||
| // Prints a value using the type inferred by the compiler.  The | ||||
| // difference between this and UniversalTersePrint() is that for a | ||||
| // (const) char pointer, this prints both the pointer and the | ||||
| // NUL-terminated string. | ||||
| template <typename T> | ||||
| void UniversalPrint(const T& value, ::std::ostream* os) { | ||||
|   UniversalPrinter<T>::Print(value, os); | ||||
| } | ||||
|  | ||||
| typedef ::std::vector<string> Strings; | ||||
|  | ||||
| // This helper template allows PrintTo() for tuples and | ||||
| // UniversalTersePrintTupleFieldsToStrings() to be defined by | ||||
| // induction on the number of tuple fields.  The idea is that | ||||
| // TuplePrefixPrinter<N>::PrintPrefixTo(t, os) prints the first N | ||||
| // fields in tuple t, and can be defined in terms of | ||||
| // TuplePrefixPrinter<N - 1>. | ||||
|  | ||||
| // The inductive case. | ||||
| template <size_t N> | ||||
| struct TuplePrefixPrinter { | ||||
|   // Prints the first N fields of a tuple. | ||||
|   template <typename Tuple> | ||||
|   static void PrintPrefixTo(const Tuple& t, ::std::ostream* os) { | ||||
|     TuplePrefixPrinter<N - 1>::PrintPrefixTo(t, os); | ||||
|     *os << ", "; | ||||
|     UniversalPrinter<typename ::std::tr1::tuple_element<N - 1, Tuple>::type> | ||||
|         ::Print(::std::tr1::get<N - 1>(t), os); | ||||
|   } | ||||
|  | ||||
|   // Tersely prints the first N fields of a tuple to a string vector, | ||||
|   // one element for each field. | ||||
|   template <typename Tuple> | ||||
|   static void TersePrintPrefixToStrings(const Tuple& t, Strings* strings) { | ||||
|     TuplePrefixPrinter<N - 1>::TersePrintPrefixToStrings(t, strings); | ||||
|     ::std::stringstream ss; | ||||
|     UniversalTersePrint(::std::tr1::get<N - 1>(t), &ss); | ||||
|     strings->push_back(ss.str()); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| // Base cases. | ||||
| template <> | ||||
| struct TuplePrefixPrinter<0> { | ||||
|   template <typename Tuple> | ||||
|   static void PrintPrefixTo(const Tuple&, ::std::ostream*) {} | ||||
|  | ||||
|   template <typename Tuple> | ||||
|   static void TersePrintPrefixToStrings(const Tuple&, Strings*) {} | ||||
| }; | ||||
| template <> | ||||
| template <typename Tuple> | ||||
| void TuplePrefixPrinter<1>::PrintPrefixTo(const Tuple& t, ::std::ostream* os) { | ||||
|   UniversalPrinter<typename ::std::tr1::tuple_element<0, Tuple>::type>:: | ||||
|       Print(::std::tr1::get<0>(t), os); | ||||
| } | ||||
|  | ||||
| // Helper function for printing a tuple.  T must be instantiated with | ||||
| // a tuple type. | ||||
| template <typename T> | ||||
| void PrintTupleTo(const T& t, ::std::ostream* os) { | ||||
|   *os << "("; | ||||
|   TuplePrefixPrinter< ::std::tr1::tuple_size<T>::value>:: | ||||
|       PrintPrefixTo(t, os); | ||||
|   *os << ")"; | ||||
| } | ||||
|  | ||||
| // Prints the fields of a tuple tersely to a string vector, one | ||||
| // element for each field.  See the comment before | ||||
| // UniversalTersePrint() for how we define "tersely". | ||||
| template <typename Tuple> | ||||
| Strings UniversalTersePrintTupleFieldsToStrings(const Tuple& value) { | ||||
|   Strings result; | ||||
|   TuplePrefixPrinter< ::std::tr1::tuple_size<Tuple>::value>:: | ||||
|       TersePrintPrefixToStrings(value, &result); | ||||
|   return result; | ||||
| } | ||||
|  | ||||
| }  // namespace internal | ||||
|  | ||||
| template <typename T> | ||||
| ::std::string PrintToString(const T& value) { | ||||
|   ::std::stringstream ss; | ||||
|   internal::UniversalTersePrint(value, &ss); | ||||
|   return ss.str(); | ||||
| } | ||||
|  | ||||
| }  // namespace testing | ||||
|  | ||||
| #endif  // GMOCK_INCLUDE_GMOCK_GMOCK_PRINTERS_H_ | ||||
| @@ -69,7 +69,6 @@ | ||||
| #include <gmock/gmock-actions.h> | ||||
| #include <gmock/gmock-cardinalities.h> | ||||
| #include <gmock/gmock-matchers.h> | ||||
| #include <gmock/gmock-printers.h> | ||||
| #include <gmock/internal/gmock-internal-utils.h> | ||||
| #include <gmock/internal/gmock-port.h> | ||||
| #include <gtest/gtest.h> | ||||
|   | ||||
| @@ -63,7 +63,6 @@ | ||||
| #include <gmock/gmock-more-actions.h> | ||||
| #include <gmock/gmock-generated-nice-strict.h> | ||||
| #include <gmock/gmock-matchers.h> | ||||
| #include <gmock/gmock-printers.h> | ||||
| #include <gmock/internal/gmock-internal-utils.h> | ||||
|  | ||||
| namespace testing { | ||||
|   | ||||
| @@ -57,9 +57,6 @@ | ||||
| #define GMOCK_ATTRIBUTE_UNUSED_ | ||||
| #endif  // __GNUC__ | ||||
|  | ||||
| class ProtocolMessage; | ||||
| namespace proto2 { class Message; } | ||||
|  | ||||
| namespace testing { | ||||
| namespace internal { | ||||
|  | ||||
| @@ -69,77 +66,6 @@ namespace internal { | ||||
| // "foo_bar_123" are converted to "foo bar 123". | ||||
| string ConvertIdentifierNameToWords(const char* id_name); | ||||
|  | ||||
| // Defining a variable of type CompileAssertTypesEqual<T1, T2> will cause a | ||||
| // compiler error iff T1 and T2 are different types. | ||||
| template <typename T1, typename T2> | ||||
| struct CompileAssertTypesEqual; | ||||
|  | ||||
| template <typename T> | ||||
| struct CompileAssertTypesEqual<T, T> { | ||||
| }; | ||||
|  | ||||
| // Removes the reference from a type if it is a reference type, | ||||
| // otherwise leaves it unchanged.  This is the same as | ||||
| // tr1::remove_reference, which is not widely available yet. | ||||
| template <typename T> | ||||
| struct RemoveReference { typedef T type; };  // NOLINT | ||||
| template <typename T> | ||||
| struct RemoveReference<T&> { typedef T type; };  // NOLINT | ||||
|  | ||||
| // A handy wrapper around RemoveReference that works when the argument | ||||
| // T depends on template parameters. | ||||
| #define GMOCK_REMOVE_REFERENCE_(T) \ | ||||
|     typename ::testing::internal::RemoveReference<T>::type | ||||
|  | ||||
| // Removes const from a type if it is a const type, otherwise leaves | ||||
| // it unchanged.  This is the same as tr1::remove_const, which is not | ||||
| // widely available yet. | ||||
| template <typename T> | ||||
| struct RemoveConst { typedef T type; };  // NOLINT | ||||
| template <typename T> | ||||
| struct RemoveConst<const T> { typedef T type; };  // NOLINT | ||||
|  | ||||
| // MSVC 8.0 has a bug which causes the above definition to fail to | ||||
| // remove the const in 'const int[3]'.  The following specialization | ||||
| // works around the bug.  However, it causes trouble with gcc and thus | ||||
| // needs to be conditionally compiled. | ||||
| #ifdef _MSC_VER | ||||
| template <typename T, size_t N> | ||||
| struct RemoveConst<T[N]> { | ||||
|   typedef typename RemoveConst<T>::type type[N]; | ||||
| }; | ||||
| #endif  // _MSC_VER | ||||
|  | ||||
| // A handy wrapper around RemoveConst that works when the argument | ||||
| // T depends on template parameters. | ||||
| #define GMOCK_REMOVE_CONST_(T) \ | ||||
|     typename ::testing::internal::RemoveConst<T>::type | ||||
|  | ||||
| // Adds reference to a type if it is not a reference type, | ||||
| // otherwise leaves it unchanged.  This is the same as | ||||
| // tr1::add_reference, which is not widely available yet. | ||||
| template <typename T> | ||||
| struct AddReference { typedef T& type; };  // NOLINT | ||||
| template <typename T> | ||||
| struct AddReference<T&> { typedef T& type; };  // NOLINT | ||||
|  | ||||
| // A handy wrapper around AddReference that works when the argument T | ||||
| // depends on template parameters. | ||||
| #define GMOCK_ADD_REFERENCE_(T) \ | ||||
|     typename ::testing::internal::AddReference<T>::type | ||||
|  | ||||
| // Adds a reference to const on top of T as necessary.  For example, | ||||
| // it transforms | ||||
| // | ||||
| //   char         ==> const char& | ||||
| //   const char   ==> const char& | ||||
| //   char&        ==> const char& | ||||
| //   const char&  ==> const char& | ||||
| // | ||||
| // The argument T must depend on some template parameters. | ||||
| #define GMOCK_REFERENCE_TO_CONST_(T) \ | ||||
|     GMOCK_ADD_REFERENCE_(const GMOCK_REMOVE_REFERENCE_(T)) | ||||
|  | ||||
| // PointeeOf<Pointer>::type is the type of a value pointed to by a | ||||
| // Pointer, which can be either a smart pointer or a raw pointer.  The | ||||
| // following default implementation is for the case where Pointer is a | ||||
| @@ -174,53 +100,6 @@ struct LinkedPtrLessThan { | ||||
|   } | ||||
| }; | ||||
|  | ||||
| // ImplicitlyConvertible<From, To>::value is a compile-time bool | ||||
| // constant that's true iff type From can be implicitly converted to | ||||
| // type To. | ||||
| template <typename From, typename To> | ||||
| class ImplicitlyConvertible { | ||||
|  private: | ||||
|   // We need the following helper functions only for their types. | ||||
|   // They have no implementations. | ||||
|  | ||||
|   // MakeFrom() is an expression whose type is From.  We cannot simply | ||||
|   // use From(), as the type From may not have a public default | ||||
|   // constructor. | ||||
|   static From MakeFrom(); | ||||
|  | ||||
|   // These two functions are overloaded.  Given an expression | ||||
|   // Helper(x), the compiler will pick the first version if x can be | ||||
|   // implicitly converted to type To; otherwise it will pick the | ||||
|   // second version. | ||||
|   // | ||||
|   // The first version returns a value of size 1, and the second | ||||
|   // version returns a value of size 2.  Therefore, by checking the | ||||
|   // size of Helper(x), which can be done at compile time, we can tell | ||||
|   // which version of Helper() is used, and hence whether x can be | ||||
|   // implicitly converted to type To. | ||||
|   static char Helper(To); | ||||
|   static char (&Helper(...))[2];  // NOLINT | ||||
|  | ||||
|   // We have to put the 'public' section after the 'private' section, | ||||
|   // or MSVC refuses to compile the code. | ||||
|  public: | ||||
|   // MSVC warns about implicitly converting from double to int for | ||||
|   // possible loss of data, so we need to temporarily disable the | ||||
|   // warning. | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(push)          // Saves the current warning state. | ||||
| #pragma warning(disable:4244)  // Temporarily disables warning 4244. | ||||
|   static const bool value = | ||||
|       sizeof(Helper(ImplicitlyConvertible::MakeFrom())) == 1; | ||||
| #pragma warning(pop)           // Restores the warning state. | ||||
| #else | ||||
|   static const bool value = | ||||
|       sizeof(Helper(ImplicitlyConvertible::MakeFrom())) == 1; | ||||
| #endif  // _MSV_VER | ||||
| }; | ||||
| template <typename From, typename To> | ||||
| const bool ImplicitlyConvertible<From, To>::value; | ||||
|  | ||||
| // Symbian compilation can be done with wchar_t being either a native | ||||
| // type or a typedef.  Using Google Mock with OpenC without wchar_t | ||||
| // should require the definition of _STLP_NO_WCHAR_T. | ||||
| @@ -385,32 +264,6 @@ struct LosslessArithmeticConvertible | ||||
|     : public LosslessArithmeticConvertibleImpl< | ||||
|   GMOCK_KIND_OF_(From), From, GMOCK_KIND_OF_(To), To> {};  // NOLINT | ||||
|  | ||||
| // IsAProtocolMessage<T>::value is a compile-time bool constant that's | ||||
| // true iff T is type ProtocolMessage, proto2::Message, or a subclass | ||||
| // of those. | ||||
| template <typename T> | ||||
| struct IsAProtocolMessage | ||||
|     : public bool_constant< | ||||
|   ImplicitlyConvertible<const T*, const ::ProtocolMessage*>::value || | ||||
|   ImplicitlyConvertible<const T*, const ::proto2::Message*>::value> { | ||||
| }; | ||||
|  | ||||
| // When the compiler sees expression IsContainerTest<C>(0), the first | ||||
| // overload of IsContainerTest will be picked if C is an STL-style | ||||
| // container class (since C::const_iterator* is a valid type and 0 can | ||||
| // be converted to it), while the second overload will be picked | ||||
| // otherwise (since C::const_iterator will be an invalid type in this | ||||
| // case).  Therefore, we can determine whether C is a container class | ||||
| // by checking the type of IsContainerTest<C>(0).  The value of the | ||||
| // expression is insignificant. | ||||
| typedef int IsContainer; | ||||
| template <class C> | ||||
| IsContainer IsContainerTest(typename C::const_iterator*) { return 0; } | ||||
|  | ||||
| typedef char IsNotContainer; | ||||
| template <class C> | ||||
| IsNotContainer IsContainerTest(...) { return '\0'; } | ||||
|  | ||||
| // This interface knows how to report a Google Mock failure (either | ||||
| // non-fatal or fatal). | ||||
| class FailureReporterInterface { | ||||
| @@ -514,149 +367,6 @@ inline T Invalid() { | ||||
| template <> | ||||
| inline void Invalid<void>() {} | ||||
|  | ||||
| // Utilities for native arrays. | ||||
|  | ||||
| // ArrayEq() compares two k-dimensional native arrays using the | ||||
| // elements' operator==, where k can be any integer >= 0.  When k is | ||||
| // 0, ArrayEq() degenerates into comparing a single pair of values. | ||||
|  | ||||
| template <typename T, typename U> | ||||
| bool ArrayEq(const T* lhs, size_t size, const U* rhs); | ||||
|  | ||||
| // This generic version is used when k is 0. | ||||
| template <typename T, typename U> | ||||
| inline bool ArrayEq(const T& lhs, const U& rhs) { return lhs == rhs; } | ||||
|  | ||||
| // This overload is used when k >= 1. | ||||
| template <typename T, typename U, size_t N> | ||||
| inline bool ArrayEq(const T(&lhs)[N], const U(&rhs)[N]) { | ||||
|   return internal::ArrayEq(lhs, N, rhs); | ||||
| } | ||||
|  | ||||
| // This helper reduces code bloat.  If we instead put its logic inside | ||||
| // the previous ArrayEq() function, arrays with different sizes would | ||||
| // lead to different copies of the template code. | ||||
| template <typename T, typename U> | ||||
| bool ArrayEq(const T* lhs, size_t size, const U* rhs) { | ||||
|   for (size_t i = 0; i != size; i++) { | ||||
|     if (!internal::ArrayEq(lhs[i], rhs[i])) | ||||
|       return false; | ||||
|   } | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| // Finds the first element in the iterator range [begin, end) that | ||||
| // equals elem.  Element may be a native array type itself. | ||||
| template <typename Iter, typename Element> | ||||
| Iter ArrayAwareFind(Iter begin, Iter end, const Element& elem) { | ||||
|   for (Iter it = begin; it != end; ++it) { | ||||
|     if (internal::ArrayEq(*it, elem)) | ||||
|       return it; | ||||
|   } | ||||
|   return end; | ||||
| } | ||||
|  | ||||
| // CopyArray() copies a k-dimensional native array using the elements' | ||||
| // operator=, where k can be any integer >= 0.  When k is 0, | ||||
| // CopyArray() degenerates into copying a single value. | ||||
|  | ||||
| template <typename T, typename U> | ||||
| void CopyArray(const T* from, size_t size, U* to); | ||||
|  | ||||
| // This generic version is used when k is 0. | ||||
| template <typename T, typename U> | ||||
| inline void CopyArray(const T& from, U* to) { *to = from; } | ||||
|  | ||||
| // This overload is used when k >= 1. | ||||
| template <typename T, typename U, size_t N> | ||||
| inline void CopyArray(const T(&from)[N], U(*to)[N]) { | ||||
|   internal::CopyArray(from, N, *to); | ||||
| } | ||||
|  | ||||
| // This helper reduces code bloat.  If we instead put its logic inside | ||||
| // the previous CopyArray() function, arrays with different sizes | ||||
| // would lead to different copies of the template code. | ||||
| template <typename T, typename U> | ||||
| void CopyArray(const T* from, size_t size, U* to) { | ||||
|   for (size_t i = 0; i != size; i++) { | ||||
|     internal::CopyArray(from[i], to + i); | ||||
|   } | ||||
| } | ||||
|  | ||||
| // The relation between an NativeArray object (see below) and the | ||||
| // native array it represents. | ||||
| enum RelationToSource { | ||||
|   kReference,  // The NativeArray references the native array. | ||||
|   kCopy        // The NativeArray makes a copy of the native array and | ||||
|                // owns the copy. | ||||
| }; | ||||
|  | ||||
| // Adapts a native array to a read-only STL-style container.  Instead | ||||
| // of the complete STL container concept, this adaptor only implements | ||||
| // members useful for Google Mock's container matchers.  New members | ||||
| // should be added as needed.  To simplify the implementation, we only | ||||
| // support Element being a raw type (i.e. having no top-level const or | ||||
| // reference modifier).  It's the client's responsibility to satisfy | ||||
| // this requirement.  Element can be an array type itself (hence | ||||
| // multi-dimensional arrays are supported). | ||||
| template <typename Element> | ||||
| class NativeArray { | ||||
|  public: | ||||
|   // STL-style container typedefs. | ||||
|   typedef Element value_type; | ||||
|   typedef const Element* const_iterator; | ||||
|  | ||||
|   // Constructs from a native array. | ||||
|   NativeArray(const Element* array, size_t count, RelationToSource relation) { | ||||
|     Init(array, count, relation); | ||||
|   } | ||||
|  | ||||
|   // Copy constructor. | ||||
|   NativeArray(const NativeArray& rhs) { | ||||
|     Init(rhs.array_, rhs.size_, rhs.relation_to_source_); | ||||
|   } | ||||
|  | ||||
|   ~NativeArray() { | ||||
|     // Ensures that the user doesn't instantiate NativeArray with a | ||||
|     // const or reference type. | ||||
|     testing::StaticAssertTypeEq<Element, | ||||
|         GMOCK_REMOVE_CONST_(GMOCK_REMOVE_REFERENCE_(Element))>(); | ||||
|     if (relation_to_source_ == kCopy) | ||||
|       delete[] array_; | ||||
|   } | ||||
|  | ||||
|   // STL-style container methods. | ||||
|   size_t size() const { return size_; } | ||||
|   const_iterator begin() const { return array_; } | ||||
|   const_iterator end() const { return array_ + size_; } | ||||
|   bool operator==(const NativeArray& rhs) const { | ||||
|     return size() == rhs.size() && | ||||
|         ArrayEq(begin(), size(), rhs.begin()); | ||||
|   } | ||||
|  | ||||
|  private: | ||||
|   // Not implemented as we don't want to support assignment. | ||||
|   void operator=(const NativeArray& rhs); | ||||
|  | ||||
|   // Initializes this object; makes a copy of the input array if | ||||
|   // 'relation' is kCopy. | ||||
|   void Init(const Element* array, size_t a_size, RelationToSource relation) { | ||||
|     if (relation == kReference) { | ||||
|       array_ = array; | ||||
|     } else { | ||||
|       Element* const copy = new Element[a_size]; | ||||
|       CopyArray(array, a_size, copy); | ||||
|       array_ = copy; | ||||
|     } | ||||
|     size_ = a_size; | ||||
|     relation_to_source_ = relation; | ||||
|   } | ||||
|  | ||||
|   const Element* array_; | ||||
|   size_t size_; | ||||
|   RelationToSource relation_to_source_; | ||||
| }; | ||||
|  | ||||
| // Given a raw type (i.e. having no top-level reference or const | ||||
| // modifier) RawContainer that's either an STL-style container or a | ||||
| // native array, class StlContainerView<RawContainer> has the | ||||
| @@ -682,7 +392,7 @@ class StlContainerView { | ||||
|   static const_reference ConstReference(const RawContainer& container) { | ||||
|     // Ensures that RawContainer is not a const type. | ||||
|     testing::StaticAssertTypeEq<RawContainer, | ||||
|         GMOCK_REMOVE_CONST_(RawContainer)>(); | ||||
|         GTEST_REMOVE_CONST_(RawContainer)>(); | ||||
|     return container; | ||||
|   } | ||||
|   static type Copy(const RawContainer& container) { return container; } | ||||
| @@ -692,7 +402,7 @@ class StlContainerView { | ||||
| template <typename Element, size_t N> | ||||
| class StlContainerView<Element[N]> { | ||||
|  public: | ||||
|   typedef GMOCK_REMOVE_CONST_(Element) RawElement; | ||||
|   typedef GTEST_REMOVE_CONST_(Element) RawElement; | ||||
|   typedef internal::NativeArray<RawElement> type; | ||||
|   // NativeArray<T> can represent a native array either by value or by | ||||
|   // reference (selected by a constructor argument), so 'const type' | ||||
| @@ -737,7 +447,7 @@ class StlContainerView<Element[N]> { | ||||
| template <typename ElementPointer, typename Size> | ||||
| class StlContainerView< ::std::tr1::tuple<ElementPointer, Size> > { | ||||
|  public: | ||||
|   typedef GMOCK_REMOVE_CONST_( | ||||
|   typedef GTEST_REMOVE_CONST_( | ||||
|       typename internal::PointeeOf<ElementPointer>::type) RawElement; | ||||
|   typedef internal::NativeArray<RawElement> type; | ||||
|   typedef const type const_reference; | ||||
|   | ||||
| @@ -50,149 +50,12 @@ | ||||
| // tr1/tuple.  gmock-port.h does this via gtest-port.h, which is | ||||
| // guaranteed to pull in the tuple header. | ||||
|  | ||||
| #if GTEST_OS_LINUX | ||||
|  | ||||
| #endif  // GTEST_OS_LINUX | ||||
|  | ||||
| namespace testing { | ||||
| namespace internal { | ||||
|  | ||||
| // For MS Visual C++, check the compiler version. At least VS 2003 is | ||||
| // required to compile Google Mock. | ||||
| #if defined(_MSC_VER) && _MSC_VER < 1310 | ||||
| #error "At least Visual C++ 2003 (7.1) is required to compile Google Mock." | ||||
| #endif | ||||
|  | ||||
| // Use implicit_cast as a safe version of static_cast for upcasting in | ||||
| // the type hierarchy (e.g. casting a Foo* to a SuperclassOfFoo* or a | ||||
| // const Foo*).  When you use implicit_cast, the compiler checks that | ||||
| // the cast is safe.  Such explicit implicit_casts are necessary in | ||||
| // surprisingly many situations where C++ demands an exact type match | ||||
| // instead of an argument type convertable to a target type. | ||||
| // | ||||
| // The syntax for using implicit_cast is the same as for static_cast: | ||||
| // | ||||
| //   implicit_cast<ToType>(expr) | ||||
| // | ||||
| // implicit_cast would have been part of the C++ standard library, | ||||
| // but the proposal was submitted too late.  It will probably make | ||||
| // its way into the language in the future. | ||||
| template<typename To> | ||||
| inline To implicit_cast(To x) { return x; } | ||||
|  | ||||
| // When you upcast (that is, cast a pointer from type Foo to type | ||||
| // SuperclassOfFoo), it's fine to use implicit_cast<>, since upcasts | ||||
| // always succeed.  When you downcast (that is, cast a pointer from | ||||
| // type Foo to type SubclassOfFoo), static_cast<> isn't safe, because | ||||
| // how do you know the pointer is really of type SubclassOfFoo?  It | ||||
| // could be a bare Foo, or of type DifferentSubclassOfFoo.  Thus, | ||||
| // when you downcast, you should use this macro.  In debug mode, we | ||||
| // use dynamic_cast<> to double-check the downcast is legal (we die | ||||
| // if it's not).  In normal mode, we do the efficient static_cast<> | ||||
| // instead.  Thus, it's important to test in debug mode to make sure | ||||
| // the cast is legal! | ||||
| //    This is the only place in the code we should use dynamic_cast<>. | ||||
| // In particular, you SHOULDN'T be using dynamic_cast<> in order to | ||||
| // do RTTI (eg code like this: | ||||
| //    if (dynamic_cast<Subclass1>(foo)) HandleASubclass1Object(foo); | ||||
| //    if (dynamic_cast<Subclass2>(foo)) HandleASubclass2Object(foo); | ||||
| // You should design the code some other way not to need this. | ||||
| template<typename To, typename From>  // use like this: down_cast<T*>(foo); | ||||
| inline To down_cast(From* f) {  // so we only accept pointers | ||||
|   // Ensures that To is a sub-type of From *.  This test is here only | ||||
|   // for compile-time type checking, and has no overhead in an | ||||
|   // optimized build at run-time, as it will be optimized away | ||||
|   // completely. | ||||
|   if (false) { | ||||
|     const To to = NULL; | ||||
|     ::testing::internal::implicit_cast<From*>(to); | ||||
|   } | ||||
|  | ||||
| #if GTEST_HAS_RTTI | ||||
|   assert(f == NULL || dynamic_cast<To>(f) != NULL);  // RTTI: debug mode only! | ||||
| #endif | ||||
|   return static_cast<To>(f); | ||||
| } | ||||
|  | ||||
| // The GMOCK_COMPILE_ASSERT_ macro can be used to verify that a compile time | ||||
| // expression is true. For example, you could use it to verify the | ||||
| // size of a static array: | ||||
| // | ||||
| //   GMOCK_COMPILE_ASSERT_(ARRAYSIZE(content_type_names) == CONTENT_NUM_TYPES, | ||||
| //                         content_type_names_incorrect_size); | ||||
| // | ||||
| // or to make sure a struct is smaller than a certain size: | ||||
| // | ||||
| //   GMOCK_COMPILE_ASSERT_(sizeof(foo) < 128, foo_too_large); | ||||
| // | ||||
| // The second argument to the macro is the name of the variable. If | ||||
| // the expression is false, most compilers will issue a warning/error | ||||
| // containing the name of the variable. | ||||
|  | ||||
| template <bool> | ||||
| struct CompileAssert { | ||||
| }; | ||||
|  | ||||
| #define GMOCK_COMPILE_ASSERT_(expr, msg) \ | ||||
|   typedef ::testing::internal::CompileAssert<(bool(expr))> \ | ||||
|       msg[bool(expr) ? 1 : -1] | ||||
|  | ||||
| // Implementation details of GMOCK_COMPILE_ASSERT_: | ||||
| // | ||||
| // - GMOCK_COMPILE_ASSERT_ works by defining an array type that has -1 | ||||
| //   elements (and thus is invalid) when the expression is false. | ||||
| // | ||||
| // - The simpler definition | ||||
| // | ||||
| //    #define GMOCK_COMPILE_ASSERT_(expr, msg) typedef char msg[(expr) ? 1 : -1] | ||||
| // | ||||
| //   does not work, as gcc supports variable-length arrays whose sizes | ||||
| //   are determined at run-time (this is gcc's extension and not part | ||||
| //   of the C++ standard).  As a result, gcc fails to reject the | ||||
| //   following code with the simple definition: | ||||
| // | ||||
| //     int foo; | ||||
| //     GMOCK_COMPILE_ASSERT_(foo, msg); // not supposed to compile as foo is | ||||
| //                                      // not a compile-time constant. | ||||
| // | ||||
| // - By using the type CompileAssert<(bool(expr))>, we ensures that | ||||
| //   expr is a compile-time constant.  (Template arguments must be | ||||
| //   determined at compile-time.) | ||||
| // | ||||
| // - The outter parentheses in CompileAssert<(bool(expr))> are necessary | ||||
| //   to work around a bug in gcc 3.4.4 and 4.0.1.  If we had written | ||||
| // | ||||
| //     CompileAssert<bool(expr)> | ||||
| // | ||||
| //   instead, these compilers will refuse to compile | ||||
| // | ||||
| //     GMOCK_COMPILE_ASSERT_(5 > 0, some_message); | ||||
| // | ||||
| //   (They seem to think the ">" in "5 > 0" marks the end of the | ||||
| //   template argument list.) | ||||
| // | ||||
| // - The array size is (bool(expr) ? 1 : -1), instead of simply | ||||
| // | ||||
| //     ((expr) ? 1 : -1). | ||||
| // | ||||
| //   This is to avoid running into a bug in MS VC 7.1, which | ||||
| //   causes ((0.0) ? 1 : -1) to incorrectly evaluate to 1. | ||||
|  | ||||
| #if GTEST_HAS_GLOBAL_STRING | ||||
| typedef ::string string; | ||||
| #else | ||||
| typedef ::std::string string; | ||||
| #endif  // GTEST_HAS_GLOBAL_STRING | ||||
|  | ||||
| #if GTEST_HAS_GLOBAL_WSTRING | ||||
| typedef ::wstring wstring; | ||||
| #elif GTEST_HAS_STD_WSTRING | ||||
| typedef ::std::wstring wstring; | ||||
| #endif  // GTEST_HAS_GLOBAL_WSTRING | ||||
|  | ||||
| }  // namespace internal | ||||
| }  // namespace testing | ||||
|  | ||||
| // Macro for referencing flags.  This is public as we want the user to | ||||
| // use this syntax to reference Google Mock flags. | ||||
| #define GMOCK_FLAG(name) FLAGS_gmock_##name | ||||
|   | ||||
| @@ -186,7 +186,6 @@ GtestTest(env, 'gmock-matchers_test', [gtest, gmock_main]) | ||||
| GtestTest(env, 'gmock-more-actions_test', [gtest, gmock_main]) | ||||
| GtestTest(env, 'gmock-nice-strict_test', [gtest, gmock_main]) | ||||
| GtestTest(env, 'gmock-port_test', [gtest, gmock_main]) | ||||
| GtestTest(env, 'gmock-printers_test', [gtest, gmock_main]) | ||||
| GtestTest(env, 'gmock-spec-builders_test', [gtest, gmock_main]) | ||||
| GtestTest(env, 'gmock_leak_test_', [gtest, gmock_main]) | ||||
| GtestTest(env, 'gmock_link_test', [gtest, gmock_main], | ||||
|   | ||||
| @@ -203,7 +203,7 @@ def _IncompleteByReferenceArgumentDiagnoser(msg): | ||||
|   """Diagnoses the IBRA disease, given the error messages by gcc.""" | ||||
|  | ||||
|   regex = (_FILE_LINE_RE + r'instantiated from here\n' | ||||
|            r'.*gmock-printers\.h.*error: invalid application of ' | ||||
|            r'.*gtest-printers\.h.*error: invalid application of ' | ||||
|            r'\'sizeof\' to incomplete type \'(?P<type>.*)\'') | ||||
|   diagnosis = """ | ||||
| In order to mock this function, Google Mock needs to see the definition | ||||
|   | ||||
| @@ -43,6 +43,5 @@ | ||||
| #include "src/gmock-cardinalities.cc" | ||||
| #include "src/gmock-internal-utils.cc" | ||||
| #include "src/gmock-matchers.cc" | ||||
| #include "src/gmock-printers.cc" | ||||
| #include "src/gmock-spec-builders.cc" | ||||
| #include "src/gmock.cc" | ||||
|   | ||||
| @@ -1,318 +0,0 @@ | ||||
| // Copyright 2007, Google Inc. | ||||
| // All rights reserved. | ||||
| // | ||||
| // Redistribution and use in source and binary forms, with or without | ||||
| // modification, are permitted provided that the following conditions are | ||||
| // met: | ||||
| // | ||||
| //     * Redistributions of source code must retain the above copyright | ||||
| // notice, this list of conditions and the following disclaimer. | ||||
| //     * Redistributions in binary form must reproduce the above | ||||
| // copyright notice, this list of conditions and the following disclaimer | ||||
| // in the documentation and/or other materials provided with the | ||||
| // distribution. | ||||
| //     * Neither the name of Google Inc. nor the names of its | ||||
| // contributors may be used to endorse or promote products derived from | ||||
| // this software without specific prior written permission. | ||||
| // | ||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
| // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
| // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
| // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
| // 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 a universal value printer that can print a | ||||
| // value of any type T: | ||||
| // | ||||
| //   void ::testing::internal::UniversalPrinter<T>::Print(value, ostream_ptr); | ||||
| // | ||||
| // It uses the << operator when possible, and prints the bytes in the | ||||
| // object otherwise.  A user can override its behavior for a class | ||||
| // type Foo by defining either operator<<(::std::ostream&, const Foo&) | ||||
| // or void PrintTo(const Foo&, ::std::ostream*) in the namespace that | ||||
| // defines Foo. | ||||
|  | ||||
| #include <gmock/gmock-printers.h> | ||||
| #include <ctype.h> | ||||
| #include <stdio.h> | ||||
| #include <ostream>  // NOLINT | ||||
| #include <string> | ||||
| #include <gmock/internal/gmock-port.h> | ||||
|  | ||||
| namespace testing { | ||||
|  | ||||
| namespace { | ||||
|  | ||||
| using ::std::ostream; | ||||
|  | ||||
| #if GTEST_OS_WINDOWS_MOBILE  // Windows CE does not define _snprintf_s. | ||||
| #define snprintf _snprintf | ||||
| #elif _MSC_VER >= 1400  // VC 8.0 and later deprecate snprintf and _snprintf. | ||||
| #define snprintf _snprintf_s | ||||
| #elif _MSC_VER | ||||
| #define snprintf _snprintf | ||||
| #endif  // GTEST_OS_WINDOWS_MOBILE | ||||
|  | ||||
| // Prints a segment of bytes in the given object. | ||||
| void PrintByteSegmentInObjectTo(const unsigned char* obj_bytes, size_t start, | ||||
|                                 size_t count, ostream* os) { | ||||
|   char text[5] = ""; | ||||
|   for (size_t i = 0; i != count; i++) { | ||||
|     const size_t j = start + i; | ||||
|     if (i != 0) { | ||||
|       // Organizes the bytes into groups of 2 for easy parsing by | ||||
|       // human. | ||||
|       if ((j % 2) == 0) { | ||||
|         *os << " "; | ||||
|       } | ||||
|     } | ||||
|     snprintf(text, sizeof(text), "%02X", obj_bytes[j]); | ||||
|     *os << text; | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Prints the bytes in the given value to the given ostream. | ||||
| void PrintBytesInObjectToImpl(const unsigned char* obj_bytes, size_t count, | ||||
|                               ostream* os) { | ||||
|   // Tells the user how big the object is. | ||||
|   *os << count << "-byte object <"; | ||||
|  | ||||
|   const size_t kThreshold = 132; | ||||
|   const size_t kChunkSize = 64; | ||||
|   // If the object size is bigger than kThreshold, we'll have to omit | ||||
|   // some details by printing only the first and the last kChunkSize | ||||
|   // bytes. | ||||
|   // TODO(wan): let the user control the threshold using a flag. | ||||
|   if (count < kThreshold) { | ||||
|     PrintByteSegmentInObjectTo(obj_bytes, 0, count, os); | ||||
|   } else { | ||||
|     PrintByteSegmentInObjectTo(obj_bytes, 0, kChunkSize, os); | ||||
|     *os << " ... "; | ||||
|     // Rounds up to 2-byte boundary. | ||||
|     const size_t resume_pos = (count - kChunkSize + 1)/2*2; | ||||
|     PrintByteSegmentInObjectTo(obj_bytes, resume_pos, count - resume_pos, os); | ||||
|   } | ||||
|   *os << ">"; | ||||
| } | ||||
|  | ||||
| }  // namespace | ||||
|  | ||||
| namespace internal2 { | ||||
|  | ||||
| // Delegates to PrintBytesInObjectToImpl() to print the bytes in the | ||||
| // given object.  The delegation simplifies the implementation, which | ||||
| // uses the << operator and thus is easier done outside of the | ||||
| // ::testing::internal namespace, which contains a << operator that | ||||
| // sometimes conflicts with the one in STL. | ||||
| void PrintBytesInObjectTo(const unsigned char* obj_bytes, size_t count, | ||||
|                           ostream* os) { | ||||
|   PrintBytesInObjectToImpl(obj_bytes, count, os); | ||||
| } | ||||
|  | ||||
| }  // namespace internal2 | ||||
|  | ||||
| namespace internal { | ||||
|  | ||||
| // Prints a wide char as a char literal without the quotes, escaping it | ||||
| // when necessary. | ||||
| static void PrintAsWideCharLiteralTo(wchar_t c, ostream* os) { | ||||
|   switch (c) { | ||||
|     case L'\0': | ||||
|       *os << "\\0"; | ||||
|       break; | ||||
|     case L'\'': | ||||
|       *os << "\\'"; | ||||
|       break; | ||||
|     case L'\?': | ||||
|       *os << "\\?"; | ||||
|       break; | ||||
|     case L'\\': | ||||
|       *os << "\\\\"; | ||||
|       break; | ||||
|     case L'\a': | ||||
|       *os << "\\a"; | ||||
|       break; | ||||
|     case L'\b': | ||||
|       *os << "\\b"; | ||||
|       break; | ||||
|     case L'\f': | ||||
|       *os << "\\f"; | ||||
|       break; | ||||
|     case L'\n': | ||||
|       *os << "\\n"; | ||||
|       break; | ||||
|     case L'\r': | ||||
|       *os << "\\r"; | ||||
|       break; | ||||
|     case L'\t': | ||||
|       *os << "\\t"; | ||||
|       break; | ||||
|     case L'\v': | ||||
|       *os << "\\v"; | ||||
|       break; | ||||
|     default: | ||||
|       // Checks whether c is printable or not. Printable characters are in | ||||
|       // the range [0x20,0x7E]. | ||||
|       // We test the value of c directly instead of calling isprint(), as | ||||
|       // isprint() is buggy on Windows mobile. | ||||
|       if (0x20 <= c && c <= 0x7E) { | ||||
|         *os << static_cast<char>(c); | ||||
|       } else { | ||||
|         // Buffer size enough for the maximum number of digits and \0. | ||||
|         char text[2 * sizeof(unsigned long) + 1] = ""; | ||||
|         snprintf(text, sizeof(text), "%lX", static_cast<unsigned long>(c)); | ||||
|         *os << "\\x" << text; | ||||
|       } | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Prints a char as if it's part of a string literal, escaping it when | ||||
| // necessary. | ||||
| static void PrintAsWideStringLiteralTo(wchar_t c, ostream* os) { | ||||
|   switch (c) { | ||||
|     case L'\'': | ||||
|       *os << "'"; | ||||
|       break; | ||||
|     case L'"': | ||||
|       *os << "\\\""; | ||||
|       break; | ||||
|     default: | ||||
|       PrintAsWideCharLiteralTo(c, os); | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Prints a char as a char literal without the quotes, escaping it | ||||
| // when necessary. | ||||
| static void PrintAsCharLiteralTo(char c, ostream* os) { | ||||
|   PrintAsWideCharLiteralTo(static_cast<unsigned char>(c), os); | ||||
| } | ||||
|  | ||||
| // Prints a char as if it's part of a string literal, escaping it when | ||||
| // necessary. | ||||
| static void PrintAsStringLiteralTo(char c, ostream* os) { | ||||
|   PrintAsWideStringLiteralTo(static_cast<unsigned char>(c), os); | ||||
| } | ||||
|  | ||||
| // Prints a char and its code.  The '\0' char is printed as "'\\0'", | ||||
| // other unprintable characters are also properly escaped using the | ||||
| // standard C++ escape sequence. | ||||
| void PrintCharTo(char c, int char_code, ostream* os) { | ||||
|   *os << "'"; | ||||
|   PrintAsCharLiteralTo(c, os); | ||||
|   *os << "'"; | ||||
|   if (c != '\0') | ||||
|     *os << " (" << char_code << ")"; | ||||
| } | ||||
|  | ||||
| // Prints a wchar_t as a symbol if it is printable or as its internal | ||||
| // code otherwise and also as its decimal code (except for L'\0'). | ||||
| // The L'\0' char is printed as "L'\\0'". The decimal code is printed | ||||
| // as signed integer when wchar_t is implemented by the compiler | ||||
| // as a signed type and is printed as an unsigned integer when wchar_t | ||||
| // is implemented as an unsigned type. | ||||
| void PrintTo(wchar_t wc, ostream* os) { | ||||
|   *os << "L'"; | ||||
|   PrintAsWideCharLiteralTo(wc, os); | ||||
|   *os << "'"; | ||||
|   if (wc != L'\0') { | ||||
|     // Type Int64 is used because it provides more storage than wchar_t thus | ||||
|     // when the compiler converts signed or unsigned implementation of wchar_t | ||||
|     // to Int64 it fills higher bits with either zeros or the sign bit | ||||
|     // passing it to operator <<() as either signed or unsigned integer. | ||||
|     *os << " (" << static_cast<Int64>(wc) << ")"; | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Prints the given array of characters to the ostream. | ||||
| // The array starts at *begin, the length is len, it may include '\0' characters | ||||
| // and may not be null-terminated. | ||||
| static void PrintCharsAsStringTo(const char* begin, size_t len, ostream* os) { | ||||
|   *os << "\""; | ||||
|   for (size_t index = 0; index < len; ++index) { | ||||
|     PrintAsStringLiteralTo(begin[index], os); | ||||
|   } | ||||
|   *os << "\""; | ||||
| } | ||||
|  | ||||
| // Prints a (const) char array of 'len' elements, starting at address 'begin'. | ||||
| void UniversalPrintArray(const char* begin, size_t len, ostream* os) { | ||||
|   PrintCharsAsStringTo(begin, len, os); | ||||
| } | ||||
|  | ||||
| // Prints the given array of wide characters to the ostream. | ||||
| // The array starts at *begin, the length is len, it may include L'\0' | ||||
| // characters and may not be null-terminated. | ||||
| static void PrintWideCharsAsStringTo(const wchar_t* begin, size_t len, | ||||
|                                      ostream* os) { | ||||
|   *os << "L\""; | ||||
|   for (size_t index = 0; index < len; ++index) { | ||||
|     PrintAsWideStringLiteralTo(begin[index], os); | ||||
|   } | ||||
|   *os << "\""; | ||||
| } | ||||
|  | ||||
| // Prints the given C string to the ostream. | ||||
| void PrintTo(const char* s, ostream* os) { | ||||
|   if (s == NULL) { | ||||
|     *os << "NULL"; | ||||
|   } else { | ||||
|     *os << implicit_cast<const void*>(s) << " pointing to "; | ||||
|     PrintCharsAsStringTo(s, strlen(s), os); | ||||
|   } | ||||
| } | ||||
|  | ||||
| // MSVC compiler can be configured to define whar_t as a typedef | ||||
| // of unsigned short. Defining an overload for const wchar_t* in that case | ||||
| // would cause pointers to unsigned shorts be printed as wide strings, | ||||
| // possibly accessing more memory than intended and causing invalid | ||||
| // memory accesses. MSVC defines _NATIVE_WCHAR_T_DEFINED symbol when | ||||
| // wchar_t is implemented as a native type. | ||||
| #if !defined(_MSC_VER) || defined(_NATIVE_WCHAR_T_DEFINED) | ||||
| // Prints the given wide C string to the ostream. | ||||
| void PrintTo(const wchar_t* s, ostream* os) { | ||||
|   if (s == NULL) { | ||||
|     *os << "NULL"; | ||||
|   } else { | ||||
|     *os << implicit_cast<const void*>(s) << " pointing to "; | ||||
|     PrintWideCharsAsStringTo(s, wcslen(s), os); | ||||
|   } | ||||
| } | ||||
| #endif  // wchar_t is native | ||||
|  | ||||
| // Prints a ::string object. | ||||
| #if GTEST_HAS_GLOBAL_STRING | ||||
| void PrintStringTo(const ::string& s, ostream* os) { | ||||
|   PrintCharsAsStringTo(s.data(), s.size(), os); | ||||
| } | ||||
| #endif  // GTEST_HAS_GLOBAL_STRING | ||||
|  | ||||
| void PrintStringTo(const ::std::string& s, ostream* os) { | ||||
|   PrintCharsAsStringTo(s.data(), s.size(), os); | ||||
| } | ||||
|  | ||||
| // Prints a ::wstring object. | ||||
| #if GTEST_HAS_GLOBAL_WSTRING | ||||
| void PrintWideStringTo(const ::wstring& s, ostream* os) { | ||||
|   PrintWideCharsAsStringTo(s.data(), s.size(), os); | ||||
| } | ||||
| #endif  // GTEST_HAS_GLOBAL_WSTRING | ||||
|  | ||||
| #if GTEST_HAS_STD_WSTRING | ||||
| void PrintWideStringTo(const ::std::wstring& s, ostream* os) { | ||||
|   PrintWideCharsAsStringTo(s.data(), s.size(), os); | ||||
| } | ||||
| #endif  // GTEST_HAS_STD_WSTRING | ||||
|  | ||||
| }  // namespace internal | ||||
|  | ||||
| }  // namespace testing | ||||
| @@ -74,9 +74,9 @@ using testing::SetArgumentPointee; | ||||
| using testing::SetErrnoAndReturn; | ||||
| #endif | ||||
|  | ||||
| #if GMOCK_HAS_PROTOBUF_ | ||||
| #if GTEST_HAS_PROTOBUF_ | ||||
| using testing::internal::TestMessage; | ||||
| #endif  // GMOCK_HAS_PROTOBUF_ | ||||
| #endif  // GTEST_HAS_PROTOBUF_ | ||||
|  | ||||
| // Tests that BuiltInDefaultValue<T*>::Get() returns NULL. | ||||
| TEST(BuiltInDefaultValueTest, IsNullForPointerTypes) { | ||||
| @@ -689,7 +689,7 @@ TEST(SetArgumentPointeeTest, SetsTheNthPointee) { | ||||
|   EXPECT_EQ('a', ch); | ||||
| } | ||||
|  | ||||
| #if GMOCK_HAS_PROTOBUF_ | ||||
| #if GTEST_HAS_PROTOBUF_ | ||||
|  | ||||
| // Tests that SetArgumentPointee<N>(proto_buffer) sets the v1 protobuf | ||||
| // variable pointed to by the N-th (0-based) argument to proto_buffer. | ||||
| @@ -786,7 +786,7 @@ TEST(SetArgumentPointeeTest, SetsTheNthPointeeOfProto2BufferBaseType) { | ||||
|   EXPECT_EQ("hi", dest.string_field()); | ||||
| } | ||||
|  | ||||
| #endif  // GMOCK_HAS_PROTOBUF_ | ||||
| #endif  // GTEST_HAS_PROTOBUF_ | ||||
|  | ||||
| // Sample functions and functors for testing Invoke() and etc. | ||||
| int Nullary() { return 1; } | ||||
|   | ||||
| @@ -96,102 +96,6 @@ TEST(ConvertIdentifierNameToWordsTest, WorksWhenNameIsMixture) { | ||||
|             ConvertIdentifierNameToWords("_Chapter11Section_1_")); | ||||
| } | ||||
|  | ||||
| // Tests that CompileAssertTypesEqual compiles when the type arguments are | ||||
| // equal. | ||||
| TEST(CompileAssertTypesEqual, CompilesWhenTypesAreEqual) { | ||||
|   CompileAssertTypesEqual<void, void>(); | ||||
|   CompileAssertTypesEqual<int*, int*>(); | ||||
| } | ||||
|  | ||||
| // Tests that RemoveReference does not affect non-reference types. | ||||
| TEST(RemoveReferenceTest, DoesNotAffectNonReferenceType) { | ||||
|   CompileAssertTypesEqual<int, RemoveReference<int>::type>(); | ||||
|   CompileAssertTypesEqual<const char, RemoveReference<const char>::type>(); | ||||
| } | ||||
|  | ||||
| // Tests that RemoveReference removes reference from reference types. | ||||
| TEST(RemoveReferenceTest, RemovesReference) { | ||||
|   CompileAssertTypesEqual<int, RemoveReference<int&>::type>(); | ||||
|   CompileAssertTypesEqual<const char, RemoveReference<const char&>::type>(); | ||||
| } | ||||
|  | ||||
| // Tests GMOCK_REMOVE_REFERENCE_. | ||||
|  | ||||
| template <typename T1, typename T2> | ||||
| void TestGMockRemoveReference() { | ||||
|   CompileAssertTypesEqual<T1, GMOCK_REMOVE_REFERENCE_(T2)>(); | ||||
| } | ||||
|  | ||||
| TEST(RemoveReferenceTest, MacroVersion) { | ||||
|   TestGMockRemoveReference<int, int>(); | ||||
|   TestGMockRemoveReference<const char, const char&>(); | ||||
| } | ||||
|  | ||||
|  | ||||
| // Tests that RemoveConst does not affect non-const types. | ||||
| TEST(RemoveConstTest, DoesNotAffectNonConstType) { | ||||
|   CompileAssertTypesEqual<int, RemoveConst<int>::type>(); | ||||
|   CompileAssertTypesEqual<char&, RemoveConst<char&>::type>(); | ||||
| } | ||||
|  | ||||
| // Tests that RemoveConst removes const from const types. | ||||
| TEST(RemoveConstTest, RemovesConst) { | ||||
|   CompileAssertTypesEqual<int, RemoveConst<const int>::type>(); | ||||
|   CompileAssertTypesEqual<char[2], RemoveConst<const char[2]>::type>(); | ||||
|   CompileAssertTypesEqual<char[2][3], RemoveConst<const char[2][3]>::type>(); | ||||
| } | ||||
|  | ||||
| // Tests GMOCK_REMOVE_CONST_. | ||||
|  | ||||
| template <typename T1, typename T2> | ||||
| void TestGMockRemoveConst() { | ||||
|   CompileAssertTypesEqual<T1, GMOCK_REMOVE_CONST_(T2)>(); | ||||
| } | ||||
|  | ||||
| TEST(RemoveConstTest, MacroVersion) { | ||||
|   TestGMockRemoveConst<int, int>(); | ||||
|   TestGMockRemoveConst<double&, double&>(); | ||||
|   TestGMockRemoveConst<char, const char>(); | ||||
| } | ||||
|  | ||||
| // Tests that AddReference does not affect reference types. | ||||
| TEST(AddReferenceTest, DoesNotAffectReferenceType) { | ||||
|   CompileAssertTypesEqual<int&, AddReference<int&>::type>(); | ||||
|   CompileAssertTypesEqual<const char&, AddReference<const char&>::type>(); | ||||
| } | ||||
|  | ||||
| // Tests that AddReference adds reference to non-reference types. | ||||
| TEST(AddReferenceTest, AddsReference) { | ||||
|   CompileAssertTypesEqual<int&, AddReference<int>::type>(); | ||||
|   CompileAssertTypesEqual<const char&, AddReference<const char>::type>(); | ||||
| } | ||||
|  | ||||
| // Tests GMOCK_ADD_REFERENCE_. | ||||
|  | ||||
| template <typename T1, typename T2> | ||||
| void TestGMockAddReference() { | ||||
|   CompileAssertTypesEqual<T1, GMOCK_ADD_REFERENCE_(T2)>(); | ||||
| } | ||||
|  | ||||
| TEST(AddReferenceTest, MacroVersion) { | ||||
|   TestGMockAddReference<int&, int>(); | ||||
|   TestGMockAddReference<const char&, const char&>(); | ||||
| } | ||||
|  | ||||
| // Tests GMOCK_REFERENCE_TO_CONST_. | ||||
|  | ||||
| template <typename T1, typename T2> | ||||
| void TestGMockReferenceToConst() { | ||||
|   CompileAssertTypesEqual<T1, GMOCK_REFERENCE_TO_CONST_(T2)>(); | ||||
| } | ||||
|  | ||||
| TEST(GMockReferenceToConstTest, Works) { | ||||
|   TestGMockReferenceToConst<const char&, char>(); | ||||
|   TestGMockReferenceToConst<const int&, const int>(); | ||||
|   TestGMockReferenceToConst<const double&, double>(); | ||||
|   TestGMockReferenceToConst<const string&, const string&>(); | ||||
| } | ||||
|  | ||||
| TEST(PointeeOfTest, WorksForSmartPointers) { | ||||
|   CompileAssertTypesEqual<const char, | ||||
|       PointeeOf<internal::linked_ptr<const char> >::type>(); | ||||
| @@ -217,38 +121,11 @@ TEST(GetRawPointerTest, WorksForRawPointers) { | ||||
|   EXPECT_EQ(&n, GetRawPointer(&n)); | ||||
| } | ||||
|  | ||||
| // Tests KindOf<T>. | ||||
|  | ||||
| class Base {}; | ||||
| class Derived : public Base {}; | ||||
|  | ||||
| // Tests that ImplicitlyConvertible<T1, T2>::value is a compile-time constant. | ||||
| TEST(ImplicitlyConvertibleTest, ValueIsCompileTimeConstant) { | ||||
|   GMOCK_COMPILE_ASSERT_((ImplicitlyConvertible<int, int>::value), const_true); | ||||
|   GMOCK_COMPILE_ASSERT_((!ImplicitlyConvertible<void*, int*>::value), | ||||
|                         const_false); | ||||
| } | ||||
|  | ||||
| // Tests that ImplicitlyConvertible<T1, T2>::value is true when T1 can | ||||
| // be implicitly converted to T2. | ||||
| TEST(ImplicitlyConvertibleTest, ValueIsTrueWhenConvertible) { | ||||
|   EXPECT_TRUE((ImplicitlyConvertible<int, double>::value)); | ||||
|   EXPECT_TRUE((ImplicitlyConvertible<double, int>::value)); | ||||
|   EXPECT_TRUE((ImplicitlyConvertible<int*, void*>::value)); | ||||
|   EXPECT_TRUE((ImplicitlyConvertible<int*, const int*>::value)); | ||||
|   EXPECT_TRUE((ImplicitlyConvertible<Derived&, const Base&>::value)); | ||||
|   EXPECT_TRUE((ImplicitlyConvertible<const Base, Base>::value)); | ||||
| } | ||||
|  | ||||
| // Tests that ImplicitlyConvertible<T1, T2>::value is false when T1 | ||||
| // cannot be implicitly converted to T2. | ||||
| TEST(ImplicitlyConvertibleTest, ValueIsFalseWhenNotConvertible) { | ||||
|   EXPECT_FALSE((ImplicitlyConvertible<double, int*>::value)); | ||||
|   EXPECT_FALSE((ImplicitlyConvertible<void*, int*>::value)); | ||||
|   EXPECT_FALSE((ImplicitlyConvertible<const int*, int*>::value)); | ||||
|   EXPECT_FALSE((ImplicitlyConvertible<Base&, Derived&>::value)); | ||||
| } | ||||
|  | ||||
| // Tests KindOf<T>. | ||||
|  | ||||
| TEST(KindOfTest, Bool) { | ||||
|   EXPECT_EQ(kBool, GMOCK_KIND_OF_(bool));  // NOLINT | ||||
| } | ||||
| @@ -382,46 +259,6 @@ TEST(LosslessArithmeticConvertibleTest, FloatingPointToFloatingPoint) { | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Tests that IsAProtocolMessage<T>::value is a compile-time constant. | ||||
| TEST(IsAProtocolMessageTest, ValueIsCompileTimeConstant) { | ||||
|   GMOCK_COMPILE_ASSERT_(IsAProtocolMessage<ProtocolMessage>::value, const_true); | ||||
|   GMOCK_COMPILE_ASSERT_(!IsAProtocolMessage<int>::value, const_false); | ||||
| } | ||||
|  | ||||
| // Tests that IsAProtocolMessage<T>::value is true when T is | ||||
| // ProtocolMessage or a sub-class of it. | ||||
| TEST(IsAProtocolMessageTest, ValueIsTrueWhenTypeIsAProtocolMessage) { | ||||
|   EXPECT_TRUE(IsAProtocolMessage< ::proto2::Message>::value); | ||||
|   EXPECT_TRUE(IsAProtocolMessage<ProtocolMessage>::value); | ||||
| #if GMOCK_HAS_PROTOBUF_ | ||||
|   EXPECT_TRUE(IsAProtocolMessage<const TestMessage>::value); | ||||
| #endif  // GMOCK_HAS_PROTOBUF_ | ||||
| } | ||||
|  | ||||
| // Tests that IsAProtocolMessage<T>::value is false when T is neither | ||||
| // ProtocolMessage nor a sub-class of it. | ||||
| TEST(IsAProtocolMessageTest, ValueIsFalseWhenTypeIsNotAProtocolMessage) { | ||||
|   EXPECT_FALSE(IsAProtocolMessage<int>::value); | ||||
|   EXPECT_FALSE(IsAProtocolMessage<const Base>::value); | ||||
| } | ||||
|  | ||||
| // Tests IsContainerTest. | ||||
|  | ||||
| class NonContainer {}; | ||||
|  | ||||
| TEST(IsContainerTestTest, WorksForNonContainer) { | ||||
|   EXPECT_EQ(sizeof(IsNotContainer), sizeof(IsContainerTest<int>(0))); | ||||
|   EXPECT_EQ(sizeof(IsNotContainer), sizeof(IsContainerTest<char[5]>(0))); | ||||
|   EXPECT_EQ(sizeof(IsNotContainer), sizeof(IsContainerTest<NonContainer>(0))); | ||||
| } | ||||
|  | ||||
| TEST(IsContainerTestTest, WorksForContainer) { | ||||
|   EXPECT_EQ(sizeof(IsContainer), | ||||
|             sizeof(IsContainerTest<std::vector<bool> >(0))); | ||||
|   EXPECT_EQ(sizeof(IsContainer), | ||||
|             sizeof(IsContainerTest<std::map<int, double> >(0))); | ||||
| } | ||||
|  | ||||
| // Tests the TupleMatches() template function. | ||||
|  | ||||
| TEST(TupleMatchesTest, WorksForSize0) { | ||||
| @@ -737,148 +574,6 @@ TEST(OnCallTest, LogsAnythingArgument) { | ||||
|  | ||||
| #endif  // GTEST_HAS_STREAM_REDIRECTION_ | ||||
|  | ||||
| // Tests ArrayEq(). | ||||
|  | ||||
| TEST(ArrayEqTest, WorksForDegeneratedArrays) { | ||||
|   EXPECT_TRUE(ArrayEq(5, 5L)); | ||||
|   EXPECT_FALSE(ArrayEq('a', 0)); | ||||
| } | ||||
|  | ||||
| TEST(ArrayEqTest, WorksForOneDimensionalArrays) { | ||||
|   const int a[] = { 0, 1 }; | ||||
|   long b[] = { 0, 1 }; | ||||
|   EXPECT_TRUE(ArrayEq(a, b)); | ||||
|   EXPECT_TRUE(ArrayEq(a, 2, b)); | ||||
|  | ||||
|   b[0] = 2; | ||||
|   EXPECT_FALSE(ArrayEq(a, b)); | ||||
|   EXPECT_FALSE(ArrayEq(a, 1, b)); | ||||
| } | ||||
|  | ||||
| TEST(ArrayEqTest, WorksForTwoDimensionalArrays) { | ||||
|   const char a[][3] = { "hi", "lo" }; | ||||
|   const char b[][3] = { "hi", "lo" }; | ||||
|   const char c[][3] = { "hi", "li" }; | ||||
|  | ||||
|   EXPECT_TRUE(ArrayEq(a, b)); | ||||
|   EXPECT_TRUE(ArrayEq(a, 2, b)); | ||||
|  | ||||
|   EXPECT_FALSE(ArrayEq(a, c)); | ||||
|   EXPECT_FALSE(ArrayEq(a, 2, c)); | ||||
| } | ||||
|  | ||||
| // Tests ArrayAwareFind(). | ||||
|  | ||||
| TEST(ArrayAwareFindTest, WorksForOneDimensionalArray) { | ||||
|   const char a[] = "hello"; | ||||
|   EXPECT_EQ(a + 4, ArrayAwareFind(a, a + 5, 'o')); | ||||
|   EXPECT_EQ(a + 5, ArrayAwareFind(a, a + 5, 'x')); | ||||
| } | ||||
|  | ||||
| TEST(ArrayAwareFindTest, WorksForTwoDimensionalArray) { | ||||
|   int a[][2] = { { 0, 1 }, { 2, 3 }, { 4, 5 } }; | ||||
|   const int b[2] = { 2, 3 }; | ||||
|   EXPECT_EQ(a + 1, ArrayAwareFind(a, a + 3, b)); | ||||
|  | ||||
|   const int c[2] = { 6, 7 }; | ||||
|   EXPECT_EQ(a + 3, ArrayAwareFind(a, a + 3, c)); | ||||
| } | ||||
|  | ||||
| // Tests CopyArray(). | ||||
|  | ||||
| TEST(CopyArrayTest, WorksForDegeneratedArrays) { | ||||
|   int n = 0; | ||||
|   CopyArray('a', &n); | ||||
|   EXPECT_EQ('a', n); | ||||
| } | ||||
|  | ||||
| TEST(CopyArrayTest, WorksForOneDimensionalArrays) { | ||||
|   const char a[3] = "hi"; | ||||
|   int b[3]; | ||||
|   CopyArray(a, &b); | ||||
|   EXPECT_TRUE(ArrayEq(a, b)); | ||||
|  | ||||
|   int c[3]; | ||||
|   CopyArray(a, 3, c); | ||||
|   EXPECT_TRUE(ArrayEq(a, c)); | ||||
| } | ||||
|  | ||||
| TEST(CopyArrayTest, WorksForTwoDimensionalArrays) { | ||||
|   const int a[2][3] = { { 0, 1, 2 }, { 3, 4, 5 } }; | ||||
|   int b[2][3]; | ||||
|   CopyArray(a, &b); | ||||
|   EXPECT_TRUE(ArrayEq(a, b)); | ||||
|  | ||||
|   int c[2][3]; | ||||
|   CopyArray(a, 2, c); | ||||
|   EXPECT_TRUE(ArrayEq(a, c)); | ||||
| } | ||||
|  | ||||
| // Tests NativeArray. | ||||
|  | ||||
| TEST(NativeArrayTest, ConstructorFromArrayWorks) { | ||||
|   const int a[3] = { 0, 1, 2 }; | ||||
|   NativeArray<int> na(a, 3, kReference); | ||||
|   EXPECT_EQ(3U, na.size()); | ||||
|   EXPECT_EQ(a, na.begin()); | ||||
| } | ||||
|  | ||||
| TEST(NativeArrayTest, CreatesAndDeletesCopyOfArrayWhenAskedTo) { | ||||
|   typedef int Array[2]; | ||||
|   Array* a = new Array[1]; | ||||
|   (*a)[0] = 0; | ||||
|   (*a)[1] = 1; | ||||
|   NativeArray<int> na(*a, 2, kCopy); | ||||
|   EXPECT_NE(*a, na.begin()); | ||||
|   delete[] a; | ||||
|   EXPECT_EQ(0, na.begin()[0]); | ||||
|   EXPECT_EQ(1, na.begin()[1]); | ||||
|  | ||||
|   // We rely on the heap checker to verify that na deletes the copy of | ||||
|   // array. | ||||
| } | ||||
|  | ||||
| TEST(NativeArrayTest, TypeMembersAreCorrect) { | ||||
|   StaticAssertTypeEq<char, NativeArray<char>::value_type>(); | ||||
|   StaticAssertTypeEq<int[2], NativeArray<int[2]>::value_type>(); | ||||
|  | ||||
|   StaticAssertTypeEq<const char*, NativeArray<char>::const_iterator>(); | ||||
|   StaticAssertTypeEq<const bool(*)[2], NativeArray<bool[2]>::const_iterator>(); | ||||
| } | ||||
|  | ||||
| TEST(NativeArrayTest, MethodsWork) { | ||||
|   const int a[3] = { 0, 1, 2 }; | ||||
|   NativeArray<int> na(a, 3, kCopy); | ||||
|   ASSERT_EQ(3U, na.size()); | ||||
|   EXPECT_EQ(3, na.end() - na.begin()); | ||||
|  | ||||
|   NativeArray<int>::const_iterator it = na.begin(); | ||||
|   EXPECT_EQ(0, *it); | ||||
|   ++it; | ||||
|   EXPECT_EQ(1, *it); | ||||
|   it++; | ||||
|   EXPECT_EQ(2, *it); | ||||
|   ++it; | ||||
|   EXPECT_EQ(na.end(), it); | ||||
|  | ||||
|   EXPECT_THAT(na, Eq(na)); | ||||
|  | ||||
|   NativeArray<int> na2(a, 3, kReference); | ||||
|   EXPECT_THAT(na, Eq(na2)); | ||||
|  | ||||
|   const int b1[3] = { 0, 1, 1 }; | ||||
|   const int b2[4] = { 0, 1, 2, 3 }; | ||||
|   EXPECT_THAT(na, Not(Eq(NativeArray<int>(b1, 3, kReference)))); | ||||
|   EXPECT_THAT(na, Not(Eq(NativeArray<int>(b2, 4, kCopy)))); | ||||
| } | ||||
|  | ||||
| TEST(NativeArrayTest, WorksForTwoDimensionalArray) { | ||||
|   const char a[2][3] = { "hi", "lo" }; | ||||
|   NativeArray<char[3]> na(a, 2, kReference); | ||||
|   ASSERT_EQ(2U, na.size()); | ||||
|   EXPECT_EQ(a, na.begin()); | ||||
| } | ||||
|  | ||||
| // Tests StlContainerView. | ||||
|  | ||||
| TEST(StlContainerViewTest, WorksForStlContainer) { | ||||
|   | ||||
| @@ -39,126 +39,5 @@ | ||||
| // NOTE: if this file is left without tests for some reason, put a dummy | ||||
| // test here to make references to symbols in the gtest library and avoid | ||||
| // 'undefined symbol' linker errors in gmock_main: | ||||
| // | ||||
| // TEST(DummyTest, Dummy) {} | ||||
|  | ||||
| namespace testing { | ||||
| namespace internal { | ||||
| // Needed to avoid name collisions in gmock_all_test.cc. | ||||
| namespace gmock_port_test { | ||||
|  | ||||
| class Base { | ||||
|  public: | ||||
|   // Copy constructor and assignment operator do exactly what we need, so we | ||||
|   // use them. | ||||
|   Base() : member_(0) {} | ||||
|   explicit Base(int n) : member_(n) {} | ||||
|   virtual ~Base() {} | ||||
|   int member() { return member_; } | ||||
|  | ||||
|  private: | ||||
|   int member_; | ||||
| }; | ||||
|  | ||||
| class Derived : public Base { | ||||
|  public: | ||||
|   explicit Derived(int n) : Base(n) {} | ||||
| }; | ||||
|  | ||||
| TEST(ImplicitCastTest, ConvertsPointers) { | ||||
|   Derived derived(0); | ||||
|   EXPECT_TRUE(&derived == ::testing::internal::implicit_cast<Base*>(&derived)); | ||||
| } | ||||
|  | ||||
| TEST(ImplicitCastTest, CanUseInheritance) { | ||||
|   Derived derived(1); | ||||
|   Base base = ::testing::internal::implicit_cast<Base>(derived); | ||||
|   EXPECT_EQ(derived.member(), base.member()); | ||||
| } | ||||
|  | ||||
| class Castable { | ||||
|  public: | ||||
|   Castable(bool* converted) : converted_(converted) {} | ||||
|   operator Base() { | ||||
|     *converted_ = true; | ||||
|     return Base(); | ||||
|   } | ||||
|  | ||||
|  private: | ||||
|   bool* converted_; | ||||
| }; | ||||
|  | ||||
| TEST(ImplicitCastTest, CanUseNonConstCastOperator) { | ||||
|   bool converted = false; | ||||
|   Castable castable(&converted); | ||||
|   Base base = ::testing::internal::implicit_cast<Base>(castable); | ||||
|   EXPECT_TRUE(converted); | ||||
| } | ||||
|  | ||||
| class ConstCastable { | ||||
|  public: | ||||
|   ConstCastable(bool* converted) : converted_(converted) {} | ||||
|   operator Base() const { | ||||
|     *converted_ = true; | ||||
|     return Base(); | ||||
|   } | ||||
|  | ||||
|  private: | ||||
|   bool* converted_; | ||||
| }; | ||||
|  | ||||
| TEST(ImplicitCastTest, CanUseConstCastOperatorOnConstValues) { | ||||
|   bool converted = false; | ||||
|   const ConstCastable const_castable(&converted); | ||||
|   Base base = ::testing::internal::implicit_cast<Base>(const_castable); | ||||
|   EXPECT_TRUE(converted); | ||||
| } | ||||
|  | ||||
| class ConstAndNonConstCastable { | ||||
|  public: | ||||
|   ConstAndNonConstCastable(bool* converted, bool* const_converted) | ||||
|       : converted_(converted), const_converted_(const_converted) {} | ||||
|   operator Base() { | ||||
|     *converted_ = true; | ||||
|     return Base(); | ||||
|   } | ||||
|   operator Base() const { | ||||
|     *const_converted_ = true; | ||||
|     return Base(); | ||||
|   } | ||||
|  | ||||
|  private: | ||||
|   bool* converted_; | ||||
|   bool* const_converted_; | ||||
| }; | ||||
|  | ||||
| TEST(ImplicitCastTest, CanSelectBetweenConstAndNonConstCasrAppropriately) { | ||||
|   bool converted = false; | ||||
|   bool const_converted = false; | ||||
|   ConstAndNonConstCastable castable(&converted, &const_converted); | ||||
|   Base base = ::testing::internal::implicit_cast<Base>(castable); | ||||
|   EXPECT_TRUE(converted); | ||||
|   EXPECT_FALSE(const_converted); | ||||
|  | ||||
|   converted = false; | ||||
|   const_converted = false; | ||||
|   const ConstAndNonConstCastable const_castable(&converted, &const_converted); | ||||
|   base = ::testing::internal::implicit_cast<Base>(const_castable); | ||||
|   EXPECT_FALSE(converted); | ||||
|   EXPECT_TRUE(const_converted); | ||||
| } | ||||
|  | ||||
| class To { | ||||
|  public: | ||||
|   To(bool* converted) { *converted = true; }  // NOLINT | ||||
| }; | ||||
|  | ||||
| TEST(ImplicitCastTest, CanUseImplicitConstructor) { | ||||
|   bool converted = false; | ||||
|   To to = ::testing::internal::implicit_cast<To>(&converted); | ||||
|   EXPECT_TRUE(converted); | ||||
| } | ||||
|  | ||||
| }  // namespace gmock_port_test | ||||
| }  // namespace internal | ||||
| }  // namespace testing | ||||
| TEST(DummyTest, Dummy) {} | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -44,6 +44,5 @@ | ||||
| #include "test/gmock-more-actions_test.cc" | ||||
| #include "test/gmock-nice-strict_test.cc" | ||||
| #include "test/gmock-port_test.cc" | ||||
| #include "test/gmock-printers_test.cc" | ||||
| #include "test/gmock-spec-builders_test.cc" | ||||
| #include "test/gmock_test.cc" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 zhanyong.wan
					zhanyong.wan