//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // test bitset& operator<<=(size_t pos); #include #include #include #include #include "../bitset_test_cases.h" #include "test_macros.h" template void test_right_shift() { std::vector > const cases = get_test_cases(); for (std::size_t c = 0; c != cases.size(); ++c) { for (std::size_t s = 0; s <= N+1; ++s) { std::bitset v1 = cases[c]; std::bitset v2 = v1; v1 >>= s; for (std::size_t i = 0; i < v1.size(); ++i) if (i + s < v1.size()) assert(v1[i] == v2[i + s]); else assert(v1[i] == 0); } } } int main(int, char**) { test_right_shift<0>(); test_right_shift<1>(); test_right_shift<31>(); test_right_shift<32>(); test_right_shift<33>(); test_right_shift<63>(); test_right_shift<64>(); test_right_shift<65>(); test_right_shift<1000>(); return 0; }