mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-21 23:30:38 +08:00

MSVC has compiler warnings C4127 "conditional expression is constant" (enabled by /W4) and C6326 "Potential comparison of a constant with another constant" (enabled by /analyze). They're potentially useful, although they're slightly annoying to library devs who know what they're doing. In the latest version of the compiler, C4127 is suppressed when the compiler sees simple tests like "if (name_of_thing)", so extracting comparison expressions into named constants is a workaround. At the same time, using std::integral_constant avoids C6326, which doesn't look at template arguments. test/std/containers/sequences/vector.bool/emplace.pass.cpp Replace 1 == 1 with true, which is the same as far as the library is concerned. Fixes D28837. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@292432 91177308-0d34-0410-b5e6-96231b3b80d8
54 lines
1.8 KiB
C++
54 lines
1.8 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 unsigned long to_ulong() const;
|
|
|
|
#include <bitset>
|
|
#include <algorithm>
|
|
#include <type_traits>
|
|
#include <limits>
|
|
#include <climits>
|
|
#include <cassert>
|
|
|
|
template <std::size_t N>
|
|
void test_to_ulong()
|
|
{
|
|
const std::size_t M = sizeof(unsigned long) * CHAR_BIT < N ? sizeof(unsigned long) * CHAR_BIT : N;
|
|
const bool is_M_zero = std::integral_constant<bool, M == 0>::value; // avoid compiler warnings
|
|
const std::size_t X = is_M_zero ? sizeof(unsigned long) * CHAR_BIT - 1 : sizeof(unsigned long) * CHAR_BIT - M;
|
|
const std::size_t max = is_M_zero ? 0 : std::size_t(std::numeric_limits<unsigned long>::max()) >> X;
|
|
std::size_t tests[] = {0,
|
|
std::min<std::size_t>(1, max),
|
|
std::min<std::size_t>(2, max),
|
|
std::min<std::size_t>(3, max),
|
|
std::min(max, max-3),
|
|
std::min(max, max-2),
|
|
std::min(max, max-1),
|
|
max};
|
|
for (std::size_t i = 0; i < sizeof(tests)/sizeof(tests[0]); ++i)
|
|
{
|
|
std::size_t j = tests[i];
|
|
std::bitset<N> v(j);
|
|
assert(j == v.to_ulong());
|
|
}
|
|
}
|
|
|
|
int main()
|
|
{
|
|
test_to_ulong<0>();
|
|
test_to_ulong<1>();
|
|
test_to_ulong<31>();
|
|
test_to_ulong<32>();
|
|
test_to_ulong<33>();
|
|
test_to_ulong<63>();
|
|
test_to_ulong<64>();
|
|
test_to_ulong<65>();
|
|
test_to_ulong<1000>();
|
|
}
|