mirror of
				https://github.com/llvm-mirror/libcxx.git
				synced 2025-10-25 04:56:13 +08:00 
			
		
		
		
	 a3eac518e6
			
		
	
	a3eac518e6
	
	
	
		
			
			Quite a few libcxx tests seem to follow the format: #if _LIBCPP_STD_VER > X // Do test. #else // Empty test. #endif We should instead use the UNSUPPORTED lit directive to exclude the test on earlier C++ standards. This gives us a more accurate number of test passes for those standards and avoids unnecessary conflicts with other lit directives on the same tests. Reviewers: bcraig, ericwf, mclow.lists Differential revision: http://reviews.llvm.org/D20730 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@271108 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.5 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.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| // UNSUPPORTED: c++98, c++03, c++11
 | |
| // <functional>
 | |
| 
 | |
| // bit_not
 | |
| 
 | |
| #include <functional>
 | |
| #include <type_traits>
 | |
| #include <cassert>
 | |
| 
 | |
| int main()
 | |
| {
 | |
|     typedef std::bit_not<int> F;
 | |
|     const F f = F();
 | |
|     static_assert((std::is_same<F::argument_type, int>::value), "" );
 | |
|     static_assert((std::is_same<F::result_type, int>::value), "" );
 | |
|     assert((f(0xEA95) & 0xFFFF ) == 0x156A);
 | |
|     assert((f(0x58D3) & 0xFFFF ) == 0xA72C);
 | |
|     assert((f(0)      & 0xFFFF ) == 0xFFFF);
 | |
|     assert((f(0xFFFF) & 0xFFFF ) == 0);
 | |
| 
 | |
|     typedef std::bit_not<> F2;
 | |
|     const F2 f2 = F2();
 | |
|     assert((f2(0xEA95)  & 0xFFFF ) == 0x156A);
 | |
|     assert((f2(0xEA95L) & 0xFFFF ) == 0x156A);
 | |
|     assert((f2(0x58D3)  & 0xFFFF ) == 0xA72C);
 | |
|     assert((f2(0x58D3L) & 0xFFFF ) == 0xA72C);
 | |
|     assert((f2(0)       & 0xFFFF ) == 0xFFFF);
 | |
|     assert((f2(0L)      & 0xFFFF ) == 0xFFFF);
 | |
|     assert((f2(0xFFFF)  & 0xFFFF ) == 0);
 | |
|     assert((f2(0xFFFFL)  & 0xFFFF ) == 0);
 | |
| 
 | |
|     constexpr int foo = std::bit_not<int> () (0xEA95) & 0xFFFF;
 | |
|     static_assert ( foo == 0x156A, "" );
 | |
| 
 | |
|     constexpr int bar = std::bit_not<> () (0xEA95) & 0xFFFF;
 | |
|     static_assert ( bar == 0x156A, "" );
 | |
| }
 |