[compiler-rt][rtsan] inotify api for Linux interception. (#124177)
[llvm-project.git] / libcxx / test / std / containers / container.adaptors / flat.map / flat.map.modifiers / swap_member.pass.cpp
blobd2d8f5673edeb436aaa77c75a390bb7a3eac9c46
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 // UNSUPPORTED: c++03, c++11, c++14, c++17, c++20
11 // <flat_map>
13 // void swap(flat_map& y) noexcept;
15 #include <flat_map>
16 #include <cassert>
17 #include <deque>
18 #include <functional>
19 #include <vector>
21 #include "MinSequenceContainer.h"
22 #include "MoveOnly.h"
23 #include "min_allocator.h"
24 #include "test_macros.h"
25 #include "../helpers.h"
27 // test noexcept
29 template <class T>
30 concept NoExceptMemberSwap = requires(T t1, T t2) {
31 { t1.swap(t2) } noexcept;
34 static_assert(NoExceptMemberSwap<std::flat_map<int, int>>);
35 #ifndef TEST_HAS_NO_EXCEPTIONS
36 static_assert(
37 NoExceptMemberSwap<std::flat_map<int, int, std::less<int>, ThrowOnMoveContainer<int>, ThrowOnMoveContainer<int>>>);
38 #endif
40 template <class KeyContainer, class ValueContainer>
41 void test() {
42 using Key = typename KeyContainer::value_type;
43 using Value = typename ValueContainer::value_type;
44 using M = std::flat_map<Key, Value, std::less<Key>, KeyContainer, ValueContainer>;
45 using V = std::pair<const Key, Value>;
47 M m1;
48 M m2;
49 M m1_save = m1;
50 M m2_save = m2;
51 m1.swap(m2);
52 assert(m1 == m2_save);
53 assert(m2 == m1_save);
56 V ar2[] = {V(5, 5), V(6, 6), V(7, 7), V(8, 8), V(9, 9), V(10, 10), V(11, 11), V(12, 12)};
57 M m1;
58 M m2(ar2, ar2 + sizeof(ar2) / sizeof(ar2[0]));
59 M m1_save = m1;
60 M m2_save = m2;
61 m1.swap(m2);
62 assert(m1 == m2_save);
63 assert(m2 == m1_save);
66 V ar1[] = {V(1, 1), V(2, 2), V(3, 3), V(4, 4)};
67 M m1(ar1, ar1 + sizeof(ar1) / sizeof(ar1[0]));
68 M m2;
69 M m1_save = m1;
70 M m2_save = m2;
71 m1.swap(m2);
72 assert(m1 == m2_save);
73 assert(m2 == m1_save);
76 V ar1[] = {V(1, 1), V(2, 2), V(3, 3), V(4, 4)};
77 V ar2[] = {V(5, 5), V(6, 6), V(7, 7), V(8, 8), V(9, 9), V(10, 10), V(11, 11), V(12, 12)};
78 M m1(ar1, ar1 + sizeof(ar1) / sizeof(ar1[0]));
79 M m2(ar2, ar2 + sizeof(ar2) / sizeof(ar2[0]));
80 M m1_save = m1;
81 M m2_save = m2;
82 m1.swap(m2);
83 assert(m1 == m2_save);
84 assert(m2 == m1_save);
88 int main(int, char**) {
89 test<std::vector<int>, std::vector<double>>();
90 test<std::deque<int>, std::vector<double>>();
91 test<MinSequenceContainer<int>, MinSequenceContainer<double>>();
92 test<std::vector<int, min_allocator<int>>, std::vector<double, min_allocator<double>>>();
94 return 0;