1 //===----------------------------------------------------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // test unsigned long long to_ullong() const;
14 #include <type_traits>
18 template <std::size_t N>
21 const std::size_t M = sizeof(unsigned long long) * CHAR_BIT < N ? sizeof(unsigned long long) * CHAR_BIT : N;
22 const bool is_M_zero = std::integral_constant<bool, M == 0>::value; // avoid compiler warnings
23 const std::size_t X = is_M_zero ? sizeof(unsigned long long) * CHAR_BIT - 1 : sizeof(unsigned long long) * CHAR_BIT - M;
24 const unsigned long long max = is_M_zero ? 0 : (unsigned long long)(-1) >> X;
25 unsigned long long tests[] = {0,
26 std::min<unsigned long long>(1, max),
27 std::min<unsigned long long>(2, max),
28 std::min<unsigned long long>(3, max),
33 for (std::size_t i = 0; i < sizeof(tests)/sizeof(tests[0]); ++i)
35 unsigned long long j = tests[i];
37 assert(j == v.to_ullong());
39 { // test values bigger than can fit into the bitset
40 const unsigned long long val = 0x55AAAAFFFFAAAA55ULL;
41 const bool canFit = N < sizeof(unsigned long long) * CHAR_BIT;
42 const unsigned long long mask = canFit ? (1ULL << (canFit ? N : 0)) - 1 : (unsigned long long)(-1); // avoid compiler warnings
43 std::bitset<N> v(val);
44 assert(v.to_ullong() == (val & mask)); // we shouldn't return bit patterns from outside the limits of the bitset.
50 // test_to_ullong<0>();
58 test_to_ullong<1000>();