mirror of
				https://github.com/llvm-mirror/libcxx.git
				synced 2025-10-23 01:18:52 +08:00 
			
		
		
		
	 069bdd52c1
			
		
	
	069bdd52c1
	
	
	
		
			
			integers which remain unused and are subsequently leaked, so the test fail when run under valgrind. Unless I'm overlooking a subtle reason why they are needed I think they can be removed, allowing these tests to pass under valgrind. The attached patch removes the variables. If there is a reason for them to exist, I can change this to just delete them at the end of the test. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@161195 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===----------------------------------------------------------------------===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is dual licensed under the MIT and the University of Illinois Open
 | |
| // Source Licenses. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| // <memory>
 | |
| 
 | |
| // shared_ptr
 | |
| 
 | |
| // template <class T, class D>
 | |
| //     bool operator==(const unique_ptr<T, D>& x, nullptr_t) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator==(nullptr_t, const unique_ptr<T, D>& y) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator!=(const unique_ptr<T, D>& x, nullptr_t) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator!=(nullptr_t, const unique_ptr<T, D>& y) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator<(const unique_ptr<T, D>& x, nullptr_t) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator<(nullptr_t, const unique_ptr<T, D>& y) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator<=(const unique_ptr<T, D>& x, nullptr_t) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator<=(nullptr_t, const unique_ptr<T, D>& y) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator>(const unique_ptr<T, D>& x, nullptr_t) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator>(nullptr_t, const unique_ptr<T, D>& y) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator>=(const unique_ptr<T, D>& x, nullptr_t) noexcept;
 | |
| // template <class T, class D>
 | |
| //     bool operator>=(nullptr_t, const unique_ptr<T, D>& y) noexcept;
 | |
| 
 | |
| #include <memory>
 | |
| #include <cassert>
 | |
| 
 | |
| void do_nothing(int*) {}
 | |
| 
 | |
| int main()
 | |
| {
 | |
|     const std::unique_ptr<int> p1(new int(1));
 | |
|     assert(!(p1 == nullptr));
 | |
|     assert(!(nullptr == p1));
 | |
|     assert(!(p1 < nullptr));
 | |
|     assert( (nullptr < p1));
 | |
|     assert(!(p1 <= nullptr));
 | |
|     assert( (nullptr <= p1));
 | |
|     assert( (p1 > nullptr));
 | |
|     assert(!(nullptr > p1));
 | |
|     assert( (p1 >= nullptr));
 | |
|     assert(!(nullptr >= p1));
 | |
| 
 | |
|     const std::unique_ptr<int> p2;
 | |
|     assert( (p2 == nullptr));
 | |
|     assert( (nullptr == p2));
 | |
|     assert(!(p2 < nullptr));
 | |
|     assert(!(nullptr < p2));
 | |
|     assert( (p2 <= nullptr));
 | |
|     assert( (nullptr <= p2));
 | |
|     assert(!(p2 > nullptr));
 | |
|     assert(!(nullptr > p2));
 | |
|     assert( (p2 >= nullptr));
 | |
|     assert( (nullptr >= p2));
 | |
| }
 |