mirror of
				https://github.com/llvm-mirror/libcxx.git
				synced 2025-10-25 04:56:13 +08:00 
			
		
		
		
	 a90c6dd460
			
		
	
	a90c6dd460
	
	
	
		
			
			git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@224658 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.4 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.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| // test numeric_limits
 | |
| 
 | |
| // infinity()
 | |
| 
 | |
| #include <limits>
 | |
| #include <cfloat>
 | |
| #include <cassert>
 | |
| 
 | |
| template <class T>
 | |
| void
 | |
| test(T expected)
 | |
| {
 | |
|     assert(std::numeric_limits<T>::infinity() == expected);
 | |
|     assert(std::numeric_limits<const T>::infinity() == expected);
 | |
|     assert(std::numeric_limits<volatile T>::infinity() == expected);
 | |
|     assert(std::numeric_limits<const volatile T>::infinity() == expected);
 | |
| }
 | |
| 
 | |
| extern float zero;
 | |
| 
 | |
| int main()
 | |
| {
 | |
|     test<bool>(false);
 | |
|     test<char>(0);
 | |
|     test<signed char>(0);
 | |
|     test<unsigned char>(0);
 | |
|     test<wchar_t>(0);
 | |
| #ifndef _LIBCPP_HAS_NO_UNICODE_CHARS
 | |
|     test<char16_t>(0);
 | |
|     test<char32_t>(0);
 | |
| #endif  // _LIBCPP_HAS_NO_UNICODE_CHARS
 | |
|     test<short>(0);
 | |
|     test<unsigned short>(0);
 | |
|     test<int>(0);
 | |
|     test<unsigned int>(0);
 | |
|     test<long>(0);
 | |
|     test<unsigned long>(0);
 | |
|     test<long long>(0);
 | |
|     test<unsigned long long>(0);
 | |
| #ifndef _LIBCPP_HAS_NO_INT128
 | |
|     test<__int128_t>(0);
 | |
|     test<__uint128_t>(0);
 | |
| #endif
 | |
|     test<float>(1./zero);
 | |
|     test<double>(1./zero);
 | |
|     test<long double>(1./zero);
 | |
| }
 | |
| 
 | |
| float zero = 0;
 |