]> git.ipfire.org Git - thirdparty/gcc.git/blob - libstdc++-v3/testsuite/23_containers/unordered_multimap/allocator/move_assign.cc
Update copyright years.
[thirdparty/gcc.git] / libstdc++-v3 / testsuite / 23_containers / unordered_multimap / allocator / move_assign.cc
1 // Copyright (C) 2013-2024 Free Software Foundation, Inc.
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
18 // { dg-do run { target c++11 } }
19
20 #include <unordered_map>
21 #include <testsuite_hooks.h>
22 #include <testsuite_allocator.h>
23 #include <testsuite_counter_type.h>
24
25 using __gnu_test::propagating_allocator;
26 using __gnu_test::counter_type;
27
28 typedef std::pair<const counter_type, counter_type> value_type;
29
30 void test01()
31 {
32 typedef propagating_allocator<value_type, false> alloc_type;
33 typedef __gnu_test::counter_type_hasher hash;
34 typedef std::unordered_multimap<counter_type, counter_type, hash,
35 std::equal_to<counter_type>,
36 alloc_type> test_type;
37
38 test_type v1(alloc_type(1));
39 v1.emplace(std::piecewise_construct,
40 std::make_tuple(1), std::make_tuple(1));
41
42 test_type v2(alloc_type(2));
43 v2.emplace(std::piecewise_construct,
44 std::make_tuple(2), std::make_tuple(2));
45
46 counter_type::reset();
47
48 v2 = std::move(v1);
49
50 VERIFY( 1 == v1.get_allocator().get_personality() );
51 VERIFY( 2 == v2.get_allocator().get_personality() );
52
53 // No move because key is const.
54 VERIFY( counter_type::move_assign_count == 0 );
55 }
56
57 void test02()
58 {
59 typedef propagating_allocator<value_type, true> alloc_type;
60 typedef __gnu_test::counter_type_hasher hash;
61 typedef std::unordered_multimap<counter_type, counter_type, hash,
62 std::equal_to<counter_type>,
63 alloc_type> test_type;
64
65 test_type v1(alloc_type(1));
66 v1.emplace(std::piecewise_construct,
67 std::make_tuple(1), std::make_tuple(1));
68
69 auto it = v1.begin();
70
71 test_type v2(alloc_type(2));
72 v2.emplace(std::piecewise_construct,
73 std::make_tuple(2), std::make_tuple(2));
74
75 counter_type::reset();
76
77 v2 = std::move(v1);
78
79 VERIFY(1 == v1.get_allocator().get_personality());
80 VERIFY(1 == v2.get_allocator().get_personality());
81
82 VERIFY( counter_type::move_assign_count == 0 );
83 VERIFY( counter_type::destructor_count == 2 );
84
85 VERIFY( it == v2.begin() );
86 }
87
88 int main()
89 {
90 test01();
91 test02();
92 return 0;
93 }