left_shift.pass.cpp 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is dual licensed under the MIT and the University of Illinois Open
  6. // Source Licenses. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. // test bitset<N> operator<<(size_t pos) const;
  10. #include <bitset>
  11. #include <cstdlib>
  12. #include <cassert>
  13. #pragma clang diagnostic ignored "-Wtautological-compare"
  14. template <std::size_t N>
  15. std::bitset<N>
  16. make_bitset()
  17. {
  18. std::bitset<N> v;
  19. for (std::size_t i = 0; i < N; ++i)
  20. v[i] = static_cast<bool>(std::rand() & 1);
  21. return v;
  22. }
  23. template <std::size_t N>
  24. void test_left_shift()
  25. {
  26. for (std::size_t s = 0; s <= N+1; ++s)
  27. {
  28. std::bitset<N> v1 = make_bitset<N>();
  29. std::bitset<N> v2 = v1;
  30. assert((v1 <<= s) == (v2 << s));
  31. }
  32. }
  33. int main()
  34. {
  35. test_left_shift<0>();
  36. test_left_shift<1>();
  37. test_left_shift<31>();
  38. test_left_shift<32>();
  39. test_left_shift<33>();
  40. test_left_shift<63>();
  41. test_left_shift<64>();
  42. test_left_shift<65>();
  43. test_left_shift<1000>();
  44. }