comparison libstdc++-v3/testsuite/23_containers/unordered_set/modifiers/92878_92947.cc @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents
children
comparison
equal deleted inserted replaced
145:1830386684a0 152:2b5abeee2509
1 // { dg-options "-std=gnu++2a" }
2 // { dg-do run { target c++2a } }
3
4 // Copyright (C) 2020 Free Software Foundation, Inc.
5 //
6 // This file is part of the GNU ISO C++ Library. This library is free
7 // software; you can redistribute it and/or modify it under the
8 // terms of the GNU General Public License as published by the
9 // Free Software Foundation; either version 3, or (at your option)
10 // any later version.
11 //
12 // This library is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 // GNU General Public License for more details.
16 //
17 // You should have received a copy of the GNU General Public License along
18 // with this library; see the file COPYING3. If not see
19 // <http://www.gnu.org/licenses/>.
20
21 #include <unordered_set>
22 #include <testsuite_hooks.h>
23
24 struct aggressive_aggregate
25 {
26 int a;
27 int b;
28 };
29
30 bool operator==(const aggressive_aggregate& a,
31 const aggressive_aggregate& b)
32 {
33 return a.a == b.a;
34 };
35
36 namespace std {
37 template<> struct hash<aggressive_aggregate> {
38 size_t operator()(const aggressive_aggregate& x) const {
39 return std::hash<int>()(x.a);
40 }
41 };
42 }
43
44 void test_emplace()
45 {
46 std::unordered_set<aggressive_aggregate> x;
47 auto emplaced = x.emplace(1, 2);
48 VERIFY(emplaced.first->a == 1);
49 VERIFY(emplaced.first->b == 2);
50 emplaced = x.emplace(2);
51 VERIFY(emplaced.first->a == 2);
52 VERIFY(emplaced.first->b == 0);
53 emplaced = x.emplace();
54 VERIFY(emplaced.first->a == 0);
55 VERIFY(emplaced.first->b == 0);
56 }
57
58 void test_emplace_hint()
59 {
60 std::unordered_set<aggressive_aggregate> x;
61 auto it = x.emplace_hint(x.begin(),
62 3, 2);
63 VERIFY(it->a == 3);
64 VERIFY(it->b == 2);
65 it = x.emplace_hint(x.begin(),
66 4);
67 VERIFY(it->a == 4);
68 VERIFY(it->b == 0);
69 it = x.emplace_hint(x.begin());
70 VERIFY(it->a == 0);
71 VERIFY(it->b == 0);
72 }
73
74 int main()
75 {
76 test_emplace();
77 test_emplace_hint();
78 }