]>
| Commit | Line | Data |
|---|---|---|
| af13a7a6 BK |
1 | // <unordered_map> -*- C++ -*- |
| 2 | ||
| 6441eb6d | 3 | // Copyright (C) 2007-2025 Free Software Foundation, Inc. |
| af13a7a6 BK |
4 | // |
| 5 | // This file is part of the GNU ISO C++ Library. This library is free | |
| 6 | // software; you can redistribute it and/or modify it under the | |
| 7 | // terms of the GNU General Public License as published by the | |
| 748086b7 | 8 | // Free Software Foundation; either version 3, or (at your option) |
| af13a7a6 BK |
9 | // any later version. |
| 10 | ||
| 11 | // This library is distributed in the hope that it will be useful, | |
| 12 | // but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | // GNU General Public License for more details. | |
| 15 | ||
| 748086b7 JJ |
16 | // Under Section 7 of GPL version 3, you are granted additional |
| 17 | // permissions described in the GCC Runtime Library Exception, version | |
| 18 | // 3.1, as published by the Free Software Foundation. | |
| 19 | ||
| 20 | // You should have received a copy of the GNU General Public License and | |
| 21 | // a copy of the GCC Runtime Library Exception along with this program; | |
| 22 | // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see | |
| 23 | // <http://www.gnu.org/licenses/>. | |
| af13a7a6 BK |
24 | |
| 25 | /** @file include/unordered_map | |
| 26 | * This is a Standard C++ Library header. | |
| 27 | */ | |
| 28 | ||
| 29 | #ifndef _GLIBCXX_UNORDERED_MAP | |
| 30 | #define _GLIBCXX_UNORDERED_MAP 1 | |
| 31 | ||
| 63a598de | 32 | #ifdef _GLIBCXX_SYSHDR |
| af13a7a6 | 33 | #pragma GCC system_header |
| 63a598de | 34 | #endif |
| af13a7a6 | 35 | |
| 18f176d0 AA |
36 | #include <bits/requires_hosted.h> // container |
| 37 | ||
| 734f5023 | 38 | #if __cplusplus < 201103L |
| ab65a4c7 | 39 | # include <bits/c++0x_warning.h> |
| 57317d2a | 40 | #else |
| af13a7a6 | 41 | |
| 988499f4 | 42 | #include <initializer_list> |
| 3b2524b1 | 43 | #include <bits/unordered_map.h> |
| f67a9881 | 44 | #include <bits/range_access.h> |
| 188588e4 | 45 | #include <bits/erase_if.h> |
| af13a7a6 | 46 | |
| a93a597a BK |
47 | #ifdef _GLIBCXX_DEBUG |
| 48 | # include <debug/unordered_map> | |
| 49 | #endif | |
| 50 | ||
| efe6efb6 | 51 | #define __glibcxx_want_allocator_traits_is_always_equal |
| ae54d8cb | 52 | #define __glibcxx_want_containers_ranges |
| 7ffa63df JW |
53 | #define __glibcxx_want_erase_if |
| 54 | #define __glibcxx_want_generic_unordered_lookup | |
| 55 | #define __glibcxx_want_node_extract | |
| 56 | #define __glibcxx_want_nonmember_container_access | |
| 57 | #define __glibcxx_want_unordered_map_try_emplace | |
| 65b4cba9 | 58 | #define __glibcxx_want_tuple_like |
| 7ffa63df JW |
59 | #include <bits/version.h> |
| 60 | ||
| 1fc9d0b0 | 61 | #if __cplusplus >= 201703L |
| 8ccdc7ce | 62 | #include <bits/memory_resource.h> |
| 1fc9d0b0 JW |
63 | namespace std _GLIBCXX_VISIBILITY(default) |
| 64 | { | |
| 65 | _GLIBCXX_BEGIN_NAMESPACE_VERSION | |
| 66 | namespace pmr | |
| 67 | { | |
| 1fc9d0b0 JW |
68 | template<typename _Key, typename _Tp, typename _Hash = std::hash<_Key>, |
| 69 | typename _Pred = std::equal_to<_Key>> | |
| 70 | using unordered_map | |
| 71 | = std::unordered_map<_Key, _Tp, _Hash, _Pred, | |
| 72 | polymorphic_allocator<pair<const _Key, _Tp>>>; | |
| 73 | template<typename _Key, typename _Tp, typename _Hash = std::hash<_Key>, | |
| 74 | typename _Pred = std::equal_to<_Key>> | |
| 75 | using unordered_multimap | |
| 76 | = std::unordered_multimap<_Key, _Tp, _Hash, _Pred, | |
| 77 | polymorphic_allocator<pair<const _Key, _Tp>>>; | |
| 78 | } // namespace pmr | |
| 79 | _GLIBCXX_END_NAMESPACE_VERSION | |
| 80 | } // namespace std | |
| 81 | #endif // C++17 | |
| 188588e4 ESR |
82 | |
| 83 | #if __cplusplus > 201703L | |
| 84 | namespace std _GLIBCXX_VISIBILITY(default) | |
| 85 | { | |
| 86 | _GLIBCXX_BEGIN_NAMESPACE_VERSION | |
| 87 | template<typename _Key, typename _Tp, typename _Hash, typename _CPred, | |
| 88 | typename _Alloc, typename _Predicate> | |
| 0b44b4b8 | 89 | inline typename unordered_map<_Key, _Tp, _Hash, _CPred, _Alloc>::size_type |
| 188588e4 ESR |
90 | erase_if(unordered_map<_Key, _Tp, _Hash, _CPred, _Alloc>& __cont, |
| 91 | _Predicate __pred) | |
| 5f40d34b | 92 | { |
| f54ceb20 | 93 | _GLIBCXX_STD_C::unordered_map<_Key, _Tp, _Hash, _CPred, _Alloc>& |
| 5f40d34b FD |
94 | __ucont = __cont; |
| 95 | return __detail::__erase_nodes_if(__cont, __ucont, __pred); | |
| 96 | } | |
| 188588e4 ESR |
97 | |
| 98 | template<typename _Key, typename _Tp, typename _Hash, typename _CPred, | |
| 99 | typename _Alloc, typename _Predicate> | |
| 0b44b4b8 ESR |
100 | inline typename unordered_multimap<_Key, _Tp, _Hash, _CPred, _Alloc>:: |
| 101 | size_type | |
| 188588e4 ESR |
102 | erase_if(unordered_multimap<_Key, _Tp, _Hash, _CPred, _Alloc>& __cont, |
| 103 | _Predicate __pred) | |
| 5f40d34b | 104 | { |
| f54ceb20 | 105 | _GLIBCXX_STD_C::unordered_multimap<_Key, _Tp, _Hash, _CPred, _Alloc>& |
| 5f40d34b FD |
106 | __ucont = __cont; |
| 107 | return __detail::__erase_nodes_if(__cont, __ucont, __pred); | |
| 108 | } | |
| 188588e4 ESR |
109 | _GLIBCXX_END_NAMESPACE_VERSION |
| 110 | } // namespace std | |
| 111 | #endif // C++20 | |
| 112 | ||
| 734f5023 | 113 | #endif // C++11 |
| 57317d2a | 114 | |
| e133ace8 | 115 | #endif // _GLIBCXX_UNORDERED_MAP |