Merge pull request #2639 from trzecieu:trzeci/move_ctor_assign
PiperOrigin-RevId: 286896167
This commit is contained in:
		@@ -1405,12 +1405,15 @@ constexpr bool InstantiateTypedTestCase_P_IsDeprecated() { return true; }
 | 
				
			|||||||
      : public parent_class {                                                 \
 | 
					      : public parent_class {                                                 \
 | 
				
			||||||
   public:                                                                    \
 | 
					   public:                                                                    \
 | 
				
			||||||
    GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)() {}                   \
 | 
					    GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)() {}                   \
 | 
				
			||||||
 | 
					    ~GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)() = default;          \
 | 
				
			||||||
 | 
					    GTEST_DISALLOW_COPY_AND_ASSIGN_(GTEST_TEST_CLASS_NAME_(test_suite_name,   \
 | 
				
			||||||
 | 
					                                                           test_name));       \
 | 
				
			||||||
 | 
					    GTEST_DISALLOW_MOVE_AND_ASSIGN_(GTEST_TEST_CLASS_NAME_(test_suite_name,   \
 | 
				
			||||||
 | 
					                                                           test_name));       \
 | 
				
			||||||
                                                                              \
 | 
					                                                                              \
 | 
				
			||||||
   private:                                                                   \
 | 
					   private:                                                                   \
 | 
				
			||||||
    void TestBody() override;                                                 \
 | 
					    void TestBody() override;                                                 \
 | 
				
			||||||
    static ::testing::TestInfo* const test_info_ GTEST_ATTRIBUTE_UNUSED_;     \
 | 
					    static ::testing::TestInfo* const test_info_ GTEST_ATTRIBUTE_UNUSED_;     \
 | 
				
			||||||
    GTEST_DISALLOW_COPY_AND_ASSIGN_(GTEST_TEST_CLASS_NAME_(test_suite_name,   \
 | 
					 | 
				
			||||||
                                                           test_name));       \
 | 
					 | 
				
			||||||
  };                                                                          \
 | 
					  };                                                                          \
 | 
				
			||||||
                                                                              \
 | 
					                                                                              \
 | 
				
			||||||
  ::testing::TestInfo* const GTEST_TEST_CLASS_NAME_(test_suite_name,          \
 | 
					  ::testing::TestInfo* const GTEST_TEST_CLASS_NAME_(test_suite_name,          \
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -190,8 +190,10 @@
 | 
				
			|||||||
//   GTEST_AMBIGUOUS_ELSE_BLOCKER_ - for disabling a gcc warning.
 | 
					//   GTEST_AMBIGUOUS_ELSE_BLOCKER_ - for disabling a gcc warning.
 | 
				
			||||||
//   GTEST_ATTRIBUTE_UNUSED_  - declares that a class' instances or a
 | 
					//   GTEST_ATTRIBUTE_UNUSED_  - declares that a class' instances or a
 | 
				
			||||||
//                              variable don't have to be used.
 | 
					//                              variable don't have to be used.
 | 
				
			||||||
//   GTEST_DISALLOW_ASSIGN_   - disables operator=.
 | 
					//   GTEST_DISALLOW_ASSIGN_   - disables copy operator=.
 | 
				
			||||||
//   GTEST_DISALLOW_COPY_AND_ASSIGN_ - disables copy ctor and operator=.
 | 
					//   GTEST_DISALLOW_COPY_AND_ASSIGN_ - disables copy ctor and operator=.
 | 
				
			||||||
 | 
					//   GTEST_DISALLOW_MOVE_ASSIGN_   - disables move operator=.
 | 
				
			||||||
 | 
					//   GTEST_DISALLOW_MOVE_AND_ASSIGN_ - disables move ctor and operator=.
 | 
				
			||||||
//   GTEST_MUST_USE_RESULT_   - declares that a function's result must be used.
 | 
					//   GTEST_MUST_USE_RESULT_   - declares that a function's result must be used.
 | 
				
			||||||
//   GTEST_INTENTIONAL_CONST_COND_PUSH_ - start code section where MSVC C4127 is
 | 
					//   GTEST_INTENTIONAL_CONST_COND_PUSH_ - start code section where MSVC C4127 is
 | 
				
			||||||
//                                        suppressed (constant conditional).
 | 
					//                                        suppressed (constant conditional).
 | 
				
			||||||
@@ -666,10 +668,10 @@ typedef struct _RTL_CRITICAL_SECTION GTEST_CRITICAL_SECTION;
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// A macro to disallow operator=
 | 
					// A macro to disallow copy operator=
 | 
				
			||||||
// This should be used in the private: declarations for a class.
 | 
					// This should be used in the private: declarations for a class.
 | 
				
			||||||
#define GTEST_DISALLOW_ASSIGN_(type) \
 | 
					#define GTEST_DISALLOW_ASSIGN_(type) \
 | 
				
			||||||
  void operator=(type const &) = delete
 | 
					  type& operator=(type const &) = delete
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// A macro to disallow copy constructor and operator=
 | 
					// A macro to disallow copy constructor and operator=
 | 
				
			||||||
// This should be used in the private: declarations for a class.
 | 
					// This should be used in the private: declarations for a class.
 | 
				
			||||||
@@ -677,6 +679,17 @@ typedef struct _RTL_CRITICAL_SECTION GTEST_CRITICAL_SECTION;
 | 
				
			|||||||
  type(type const &) = delete; \
 | 
					  type(type const &) = delete; \
 | 
				
			||||||
  GTEST_DISALLOW_ASSIGN_(type)
 | 
					  GTEST_DISALLOW_ASSIGN_(type)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// A macro to disallow move operator=
 | 
				
			||||||
 | 
					// This should be used in the private: declarations for a class.
 | 
				
			||||||
 | 
					#define GTEST_DISALLOW_MOVE_ASSIGN_(type) \
 | 
				
			||||||
 | 
					  type& operator=(type &&) noexcept = delete
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// A macro to disallow move constructor and operator=
 | 
				
			||||||
 | 
					// This should be used in the private: declarations for a class.
 | 
				
			||||||
 | 
					#define GTEST_DISALLOW_MOVE_AND_ASSIGN_(type) \
 | 
				
			||||||
 | 
					  type(type &&) noexcept = delete; \
 | 
				
			||||||
 | 
					  GTEST_DISALLOW_MOVE_ASSIGN_(type)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Tell the compiler to warn about unused return values for functions declared
 | 
					// Tell the compiler to warn about unused return values for functions declared
 | 
				
			||||||
// with this macro.  The macro should be used on function declarations
 | 
					// with this macro.  The macro should be used on function declarations
 | 
				
			||||||
// following the argument list:
 | 
					// following the argument list:
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user