]> git.ipfire.org Git - thirdparty/gcc.git/blame - libstdc++-v3/testsuite/23_containers/unordered_set/hash_policy/power2_rehash.cc
Update copyright years.
[thirdparty/gcc.git] / libstdc++-v3 / testsuite / 23_containers / unordered_set / hash_policy / power2_rehash.cc
CommitLineData
8d9254fc 1// Copyright (C) 2016-2020 Free Software Foundation, Inc.
732eb076
FD
2//
3// This file is part of the GNU ISO C++ Library. This library is free
4// software; you can redistribute it and/or modify it under the
5// terms of the GNU General Public License as published by the
6// Free Software Foundation; either version 3, or (at your option)
7// any later version.
8//
9// This library is distributed in the hope that it will be useful,
10// but WITHOUT ANY WARRANTY; without even the implied warranty of
11// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12// GNU General Public License for more details.
13//
14// You should have received a copy of the GNU General Public License along
15// with this library; see the file COPYING3. If not see
16// <http://www.gnu.org/licenses/>.
17//
52066eae 18// { dg-do run { target c++11 } }
732eb076 19
29dbb034 20#include <limits>
732eb076
FD
21#include <unordered_set>
22
23#include <testsuite_hooks.h>
24
25void test01()
26{
732eb076
FD
27 std::__detail::_Power2_rehash_policy policy;
28 VERIFY( policy._M_next_bkt(1) == 2 );
de6f5f57 29 VERIFY( policy._M_next_bkt(2) == 2 );
732eb076
FD
30 VERIFY( policy._M_next_bkt(3) == 4 );
31 VERIFY( policy._M_next_bkt(5) == 8 );
de6f5f57 32 VERIFY( policy._M_next_bkt(16) == 16 );
732eb076
FD
33 VERIFY( policy._M_next_bkt(33) == 64 );
34 VERIFY( policy._M_next_bkt((std::size_t(1) << (sizeof(std::size_t) * 8 - 2)) + 1)
35 == (std::size_t(1) << (sizeof(std::size_t) * 8 - 1)) );
36}
37
29dbb034
FD
38void test02()
39{
29dbb034
FD
40 std::__detail::_Power2_rehash_policy policy;
41
de6f5f57 42 for (std::size_t i = 3;;)
29dbb034
FD
43 {
44 auto nxt = policy._M_next_bkt(i);
45
de6f5f57 46 if (nxt <= i)
29dbb034 47 {
de6f5f57 48 // Lower or equal only when reaching max.
29dbb034
FD
49 constexpr auto mx = std::numeric_limits<std::size_t>::max();
50 VERIFY( nxt == policy._M_next_bkt(mx) );
51 break;
52 }
53
de6f5f57
FD
54 VERIFY( nxt >= i );
55 i = nxt + 1;
29dbb034
FD
56 }
57}
58
732eb076
FD
59int main()
60{
61 test01();
29dbb034 62 test02();
732eb076
FD
63 return 0;
64}