Index: libcxx/docs/FeatureTestMacroTable.rst =================================================================== --- libcxx/docs/FeatureTestMacroTable.rst +++ libcxx/docs/FeatureTestMacroTable.rst @@ -206,7 +206,7 @@ ------------------------------------------------- ----------------- ``__cpp_lib_erase_if`` ``202002L`` ------------------------------------------------- ----------------- - ``__cpp_lib_generic_unordered_lookup`` *unimplemented* + ``__cpp_lib_generic_unordered_lookup`` ``201811L`` ------------------------------------------------- ----------------- ``__cpp_lib_interpolate`` ``201902L`` ------------------------------------------------- ----------------- Index: libcxx/include/unordered_map =================================================================== --- libcxx/include/unordered_map +++ libcxx/include/unordered_map @@ -173,10 +173,22 @@ iterator find(const key_type& k); const_iterator find(const key_type& k) const; + template + iterator find(const K& x); // C++20 + template + const_iterator find(const K& x) const; // C++20 size_type count(const key_type& k) const; + template + size_type count(const K& k) const; // C++20 bool contains(const key_type& k) const; // C++20 + template + bool contains(const K& k) const; // C++20 pair equal_range(const key_type& k); pair equal_range(const key_type& k) const; + template + pair equal_range(const K& k); // C++20 + template + pair equal_range(const K& k) const; // C++20 mapped_type& operator[](const key_type& k); mapped_type& operator[](key_type&& k); @@ -355,10 +367,22 @@ iterator find(const key_type& k); const_iterator find(const key_type& k) const; + template + iterator find(const K& x); // C++20 + template + const_iterator find(const K& x) const; // C++20 size_type count(const key_type& k) const; + template + size_type count(const K& k) const; // C++20 bool contains(const key_type& k) const; // C++20 + template + bool contains(const K& k) const; // C++20 pair equal_range(const key_type& k); pair equal_range(const key_type& k) const; + template + pair equal_range(const K& k); // C++20 + template + pair equal_range(const K& k) const; // C++20 size_type bucket_count() const noexcept; size_type max_bucket_count() const noexcept; @@ -423,7 +447,7 @@ _LIBCPP_BEGIN_NAMESPACE_STD -template ::value && !__libcpp_is_final<_Hash>::value> class __unordered_map_hasher : private _Hash @@ -445,6 +469,12 @@ _LIBCPP_INLINE_VISIBILITY size_t operator()(const _Key& __x) const {return static_cast(*this)(__x);} +#if _LIBCPP_STD_VER > 17 + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + size_t operator()(const _K2& __x) const + {return static_cast(*this)(__x);} +#endif void swap(__unordered_map_hasher&__y) _NOEXCEPT_(__is_nothrow_swappable<_Hash>::value) { @@ -453,8 +483,8 @@ } }; -template -class __unordered_map_hasher<_Key, _Cp, _Hash, false> +template +class __unordered_map_hasher<_Key, _Cp, _Hash, _Pred, false> { _Hash __hash_; public: @@ -474,6 +504,12 @@ _LIBCPP_INLINE_VISIBILITY size_t operator()(const _Key& __x) const {return __hash_(__x);} +#if _LIBCPP_STD_VER > 17 + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + size_t operator()(const _K2& __x) const + {return __hash_(__x);} +#endif void swap(__unordered_map_hasher&__y) _NOEXCEPT_(__is_nothrow_swappable<_Hash>::value) { @@ -482,17 +518,17 @@ } }; -template +template inline _LIBCPP_INLINE_VISIBILITY void -swap(__unordered_map_hasher<_Key, _Cp, _Hash, __b>& __x, - __unordered_map_hasher<_Key, _Cp, _Hash, __b>& __y) +swap(__unordered_map_hasher<_Key, _Cp, _Hash, _Pred, __b>& __x, + __unordered_map_hasher<_Key, _Cp, _Hash, _Pred, __b>& __y) _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) { __x.swap(__y); } -template ::value && !__libcpp_is_final<_Pred>::value> class __unordered_map_equal : private _Pred @@ -517,6 +553,24 @@ _LIBCPP_INLINE_VISIBILITY bool operator()(const _Key& __x, const _Cp& __y) const {return static_cast(*this)(__x, __y.__get_value().first);} +#if _LIBCPP_STD_VER > 17 + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + bool operator()(const _Cp& __x, const _K2& __y) const + {return static_cast(*this)(__x.__get_value().first, __y);} + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + bool operator()(const _K2& __x, const _Cp& __y) const + {return static_cast(*this)(__x, __y.__get_value().first);} + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + bool operator()(const _Key& __x, const _K2& __y) const + {return static_cast(*this)(__x, __y);} + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + bool operator()(const _K2& __x, const _Key& __y) const + {return static_cast(*this)(__x, __y);} +#endif void swap(__unordered_map_equal&__y) _NOEXCEPT_(__is_nothrow_swappable<_Pred>::value) { @@ -525,8 +579,8 @@ } }; -template -class __unordered_map_equal<_Key, _Cp, _Pred, false> +template +class __unordered_map_equal<_Key, _Cp, _Pred, _Hash, false> { _Pred __pred_; public: @@ -549,6 +603,24 @@ _LIBCPP_INLINE_VISIBILITY bool operator()(const _Key& __x, const _Cp& __y) const {return __pred_(__x, __y.__get_value().first);} +#if _LIBCPP_STD_VER > 17 + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + bool operator()(const _Cp& __x, const _K2& __y) const + {return __pred_(__x.__get_value().first, __y);} + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + bool operator()(const _K2& __x, const _Cp& __y) const + {return __pred_(__x, __y.__get_value().first);} + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + bool operator()(const _Key& __x, const _K2& __y) const + {return __pred_(__x, __y);} + template ::value && __is_transparent<_Pred, _K2>::value>> + _LIBCPP_INLINE_VISIBILITY + bool operator()(const _K2& __x, const _Key& __y) const + {return __pred_(__x, __y);} +#endif void swap(__unordered_map_equal&__y) _NOEXCEPT_(__is_nothrow_swappable<_Pred>::value) { @@ -557,11 +629,11 @@ } }; -template +template inline _LIBCPP_INLINE_VISIBILITY void -swap(__unordered_map_equal<_Key, _Cp, _Pred, __b>& __x, - __unordered_map_equal<_Key, _Cp, _Pred, __b>& __y) +swap(__unordered_map_equal<_Key, _Cp, _Pred, _Hash, __b>& __x, + __unordered_map_equal<_Key, _Cp, _Pred, _Hash, __b>& __y) _NOEXCEPT_(_NOEXCEPT_(__x.swap(__y))) { __x.swap(__y); @@ -858,11 +930,11 @@ "Invalid allocator::value_type"); private: - typedef __hash_value_type __value_type; - typedef __unordered_map_hasher __hasher; - typedef __unordered_map_equal __key_equal; + typedef __hash_value_type __value_type; + typedef __unordered_map_hasher __hasher; + typedef __unordered_map_equal __key_equal; typedef typename __rebind_alloc_helper, - __value_type>::type __allocator_type; + __value_type>::type __allocator_type; typedef __hash_table<__value_type, __hasher, __key_equal, __allocator_type> __table; @@ -1280,11 +1352,30 @@ iterator find(const key_type& __k) {return __table_.find(__k);} _LIBCPP_INLINE_VISIBILITY const_iterator find(const key_type& __k) const {return __table_.find(__k);} + + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, iterator> find(const _K2& __k) {return __table_.find(__k);} + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, const_iterator> find(const _K2& __k) const {return __table_.find(__k);} + #endif // _LIBCPP_STD_VER > 17 + _LIBCPP_INLINE_VISIBILITY size_type count(const key_type& __k) const {return __table_.__count_unique(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, size_type> count(const _K2& __k) const {return __table_.__count_unique(__k);} + #endif // _LIBCPP_STD_VER > 17 #if _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY bool contains(const key_type& __k) const {return find(__k) != end();} + + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, bool> contains(const _K2& __k) const {return find(__k) != end();} #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY pair equal_range(const key_type& __k) @@ -1292,6 +1383,14 @@ _LIBCPP_INLINE_VISIBILITY pair equal_range(const key_type& __k) const {return __table_.__equal_range_unique(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, pair> equal_range(const _K2& __k) {return __table_.__equal_range_unique(__k);} + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, pair> equal_range(const _K2& __k) const {return __table_.__equal_range_unique(__k);} + #endif // _LIBCPP_STD_VER > 17 mapped_type& operator[](const key_type& __k); #ifndef _LIBCPP_CXX03_LANG @@ -1762,11 +1861,11 @@ "Invalid allocator::value_type"); private: - typedef __hash_value_type __value_type; - typedef __unordered_map_hasher __hasher; - typedef __unordered_map_equal __key_equal; + typedef __hash_value_type __value_type; + typedef __unordered_map_hasher __hasher; + typedef __unordered_map_equal __key_equal; typedef typename __rebind_alloc_helper, - __value_type>::type __allocator_type; + __value_type>::type __allocator_type; typedef __hash_table<__value_type, __hasher, __key_equal, __allocator_type> __table; @@ -2059,11 +2158,28 @@ iterator find(const key_type& __k) {return __table_.find(__k);} _LIBCPP_INLINE_VISIBILITY const_iterator find(const key_type& __k) const {return __table_.find(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, iterator> find(const _K2& __k) {return __table_.find(__k);} + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, const_iterator> find(const _K2& __k) const {return __table_.find(__k);} + #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY size_type count(const key_type& __k) const {return __table_.__count_multi(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, size_type> count(const _K2& __k) const {return __table_.__count_multi(__k);} + #endif // _LIBCPP_STD_VER > 17 #if _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY bool contains(const key_type& __k) const {return find(__k) != end();} + + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, bool> contains(const _K2& __k) const {return find(__k) != end();} #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY pair equal_range(const key_type& __k) @@ -2071,6 +2187,14 @@ _LIBCPP_INLINE_VISIBILITY pair equal_range(const key_type& __k) const {return __table_.__equal_range_multi(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, pair> equal_range(const _K2& __k) {return __table_.__equal_range_multi(__k);} + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, pair> equal_range(const _K2& __k) const {return __table_.__equal_range_multi(__k);} + #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY size_type bucket_count() const _NOEXCEPT {return __table_.bucket_count();} Index: libcxx/include/unordered_set =================================================================== --- libcxx/include/unordered_set +++ libcxx/include/unordered_set @@ -145,10 +145,22 @@ iterator find(const key_type& k); const_iterator find(const key_type& k) const; + template + iterator find(const K& x); // C++20 + template + const_iterator find(const K& x) const; // C++20 size_type count(const key_type& k) const; + template + size_type count(const K& k) const; // C++20 bool contains(const key_type& k) const; // C++20 + template + bool contains(const K& k) const; // C++20 pair equal_range(const key_type& k); pair equal_range(const key_type& k) const; + template + pair equal_range(const K& k); // C++20 + template + pair equal_range(const K& k) const; // C++20 size_type bucket_count() const noexcept; size_type max_bucket_count() const noexcept; @@ -310,10 +322,22 @@ iterator find(const key_type& k); const_iterator find(const key_type& k) const; + template + iterator find(const K& x); // C++20 + template + const_iterator find(const K& x) const; // C++20 size_type count(const key_type& k) const; + template + size_type count(const K& k) const; // C++20 bool contains(const key_type& k) const; // C++20 + template + bool contains(const K& k) const; // C++20 pair equal_range(const key_type& k); pair equal_range(const key_type& k) const; + template + pair equal_range(const K& k); // C++20 + template + pair equal_range(const K& k) const; // C++20 size_type bucket_count() const noexcept; size_type max_bucket_count() const noexcept; @@ -679,11 +703,28 @@ iterator find(const key_type& __k) {return __table_.find(__k);} _LIBCPP_INLINE_VISIBILITY const_iterator find(const key_type& __k) const {return __table_.find(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, iterator> find(const _K2& __k) {return __table_.find(__k);} + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, const_iterator> find(const _K2& __k) const {return __table_.find(__k);} + #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY size_type count(const key_type& __k) const {return __table_.__count_unique(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, size_type> count(const _K2& __k) const {return __table_.__count_unique(__k);} + #endif // _LIBCPP_STD_VER > 17 #if _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY bool contains(const key_type& __k) const {return find(__k) != end();} + + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, bool> contains(const _K2& __k) const {return find(__k) != end();} #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY pair equal_range(const key_type& __k) @@ -691,6 +732,14 @@ _LIBCPP_INLINE_VISIBILITY pair equal_range(const key_type& __k) const {return __table_.__equal_range_unique(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, pair> equal_range(const _K2& __k) {return __table_.__equal_range_unique(__k);} + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, pair> equal_range(const _K2& __k) const {return __table_.__equal_range_unique(__k);} + #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY size_type bucket_count() const _NOEXCEPT {return __table_.bucket_count();} @@ -1314,11 +1363,28 @@ iterator find(const key_type& __k) {return __table_.find(__k);} _LIBCPP_INLINE_VISIBILITY const_iterator find(const key_type& __k) const {return __table_.find(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, iterator> find(const _K2& __k) {return __table_.find(__k);} + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, const_iterator> find(const _K2& __k) const {return __table_.find(__k);} + #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY size_type count(const key_type& __k) const {return __table_.__count_multi(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, size_type> count(const _K2& __k) const {return __table_.__count_multi(__k);} + #endif // _LIBCPP_STD_VER > 17 #if _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY bool contains(const key_type& __k) const {return find(__k) != end();} + + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, bool> contains(const _K2& __k) const {return find(__k) != end();} #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY pair equal_range(const key_type& __k) @@ -1326,6 +1392,14 @@ _LIBCPP_INLINE_VISIBILITY pair equal_range(const key_type& __k) const {return __table_.__equal_range_multi(__k);} + #if _LIBCPP_STD_VER > 17 + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, pair> equal_range(const _K2& __k) {return __table_.__equal_range_multi(__k);} + template + _LIBCPP_INLINE_VISIBILITY + _EnableIf<__is_transparent::value && __is_transparent::value, pair> equal_range(const _K2& __k) const {return __table_.__equal_range_multi(__k);} + #endif // _LIBCPP_STD_VER > 17 _LIBCPP_INLINE_VISIBILITY size_type bucket_count() const _NOEXCEPT {return __table_.bucket_count();} Index: libcxx/include/version =================================================================== --- libcxx/include/version +++ libcxx/include/version @@ -260,7 +260,7 @@ # endif # define __cpp_lib_endian 201907L # define __cpp_lib_erase_if 202002L -// # define __cpp_lib_generic_unordered_lookup 201811L +# define __cpp_lib_generic_unordered_lookup 201811L # define __cpp_lib_interpolate 201902L # if !defined(_LIBCPP_HAS_NO_BUILTIN_IS_CONSTANT_EVALUATED) # define __cpp_lib_is_constant_evaluated 201811L Index: libcxx/test/std/containers/unord/unord.map/contains.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.map/contains.transparent.pass.cpp @@ -0,0 +1,62 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_map + +// template +// bool contains(const K& x) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = const unord_map_type >; + test_transparent_contains(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = const unord_map_type; + test_transparent_contains(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = const unord_map_type, + std::equal_to<> >; + test_non_transparent_contains(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = const unord_map_type >; + test_non_transparent_contains(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = const unord_map_type, + std::equal_to >; + test_non_transparent_contains(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.map/count.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.map/count.transparent.pass.cpp @@ -0,0 +1,63 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_map + +// template +// size_type count(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = const unord_map_type >; + test_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = + const unord_map_type; + test_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = const unord_map_type, std::equal_to<> >; + test_non_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = + const unord_map_type >; + test_non_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = + const unord_map_type, std::equal_to >; + test_non_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.map/equal_range_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.map/equal_range_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_map + +// template +// pair equal_range(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = const unord_map_type >; + test_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = const unord_map_type; + test_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = const unord_map_type, + std::equal_to<> >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = const unord_map_type >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = const unord_map_type, + std::equal_to >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.map/equal_range_non_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.map/equal_range_non_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_map + +// template +// pair equal_range(const K& k); + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = unord_map_type >; + test_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = unord_map_type; + test_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = unord_map_type, + std::equal_to<> >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = unord_map_type >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = unord_map_type, + std::equal_to >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.map/find_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.map/find_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_map + +// template +// const_iterator find(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = const unord_map_type >; + test_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = const unord_map_type; + test_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = const unord_map_type, + std::equal_to<> >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = const unord_map_type >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = const unord_map_type, + std::equal_to >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.map/find_non_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.map/find_non_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_map + +// template +// iterator find(const K& k); + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = unord_map_type >; + test_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = unord_map_type; + test_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = unord_map_type, + std::equal_to<> >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = unord_map_type >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = unord_map_type, + std::equal_to >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multimap/contains.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multimap/contains.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multimap + +// template +// bool contains(const K& x) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = unord_map_type >; + test_transparent_contains(ilist_type{{1, 2}, {1, 3}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = unord_map_type; + test_transparent_contains(ilist_type{{1, 2}, {1, 3}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = unord_map_type, + std::equal_to<> >; + test_non_transparent_contains(ilist_type{{1, 2}, {1, 3}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = unord_map_type >; + test_non_transparent_contains( + ilist_type{{1, 2}, {1, 3}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = unord_map_type, + std::equal_to >; + test_non_transparent_contains( + ilist_type{{1, 2}, {1, 3}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multimap/count.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multimap/count.transparent.pass.cpp @@ -0,0 +1,63 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multimap + +// template +// size_type count(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = const unord_map_type >; + test_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = + const unord_map_type; + test_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = const unord_map_type, std::equal_to<> >; + test_non_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = + const unord_map_type >; + test_non_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = + const unord_map_type, std::equal_to >; + test_non_transparent_count(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multimap/equal_range_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multimap/equal_range_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multimap + +// template +// pair equal_range(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = const unord_map_type >; + test_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = const unord_map_type; + test_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = const unord_map_type, + std::equal_to<> >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = const unord_map_type >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = const unord_map_type, + std::equal_to >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multimap/equal_range_non_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multimap/equal_range_non_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multimap + +// template +// pair equal_range(const K& k); + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = unord_map_type >; + test_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = unord_map_type; + test_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = unord_map_type, + std::equal_to<> >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = unord_map_type >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = unord_map_type, + std::equal_to >; + test_non_transparent_equal_range(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multimap/find_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multimap/find_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multimap + +// template +// const_iterator find(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = const unord_map_type >; + test_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = const unord_map_type; + test_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = const unord_map_type, + std::equal_to<> >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = const unord_map_type >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = const unord_map_type, + std::equal_to >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multimap/find_non_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multimap/find_non_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multimap + +// template +// iterator find(const K& k); + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list >; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using map_type = unord_map_type >; + test_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using map_type = unord_map_type; + test_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using map_type = unord_map_type, + std::equal_to<> >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using map_type = unord_map_type >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using map_type = unord_map_type, + std::equal_to >; + test_non_transparent_find(ilist_type{{1, 2}, {2, 3}}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multiset/contains.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multiset/contains.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator> +// class unordered_multiset + +// template +// bool contains(const K& x) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = unord_set_type >; + test_transparent_contains(ilist_type{1,1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = unord_set_type; + test_transparent_contains(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = unord_set_type, + std::equal_to<> >; + test_non_transparent_contains(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = unord_set_type >; + test_non_transparent_contains( + ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = unord_set_type, + std::equal_to >; + test_non_transparent_contains( + ilist_type{1,1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multiset/count.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multiset/count.transparent.pass.cpp @@ -0,0 +1,63 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multiset + +// template +// size_type count(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = const unord_set_type >; + test_transparent_count(ilist_type{1,1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = + const unord_set_type; + test_transparent_count(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = const unord_set_type, std::equal_to<> >; + test_non_transparent_count(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = + const unord_set_type >; + test_non_transparent_count(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = + const unord_set_type, std::equal_to >; + test_non_transparent_count(ilist_type{1,1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multiset/equal_range_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multiset/equal_range_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multiset + +// template +// pair equal_range(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = const unord_set_type >; + test_transparent_equal_range(ilist_type{1,1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = const unord_set_type; + test_transparent_equal_range(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = const unord_set_type, + std::equal_to<> >; + test_non_transparent_equal_range(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = const unord_set_type >; + test_non_transparent_equal_range(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = const unord_set_type, + std::equal_to >; + test_non_transparent_equal_range(ilist_type{1,1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multiset/equal_range_non_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multiset/equal_range_non_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multiset + +// template +// pair equal_range(const K& k); + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = unord_set_type >; + test_transparent_equal_range(ilist_type{1,1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = unord_set_type; + test_transparent_equal_range(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = unord_set_type, + std::equal_to<> >; + test_non_transparent_equal_range(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = unord_set_type >; + test_non_transparent_equal_range(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = unord_set_type, + std::equal_to >; + test_non_transparent_equal_range(ilist_type{1,1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multiset/find_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multiset/find_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multiset + +// template +// const_iterator find(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = const unord_set_type >; + test_transparent_find(ilist_type{1,1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = const unord_set_type; + test_transparent_find(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = const unord_set_type, + std::equal_to<> >; + test_non_transparent_find(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = const unord_set_type >; + test_non_transparent_find(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = const unord_set_type, + std::equal_to >; + test_non_transparent_find(ilist_type{1,1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.multiset/find_non_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.multiset/find_non_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_multiset + +// template +// iterator find(const K& k); + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = unord_set_type >; + test_transparent_find(ilist_type{1,1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = unord_set_type; + test_transparent_find(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = unord_set_type, + std::equal_to<> >; + test_non_transparent_find(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = unord_set_type >; + test_non_transparent_find(ilist_type{1,1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = unord_set_type, + std::equal_to >; + test_non_transparent_find(ilist_type{1,1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.set/contains.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.set/contains.transparent.pass.cpp @@ -0,0 +1,62 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator> +// class unordered_multiset + +// template +// bool contains(const K& x) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = const unord_set_type >; + test_transparent_contains(ilist_type{1, 2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = const unord_set_type; + test_transparent_contains(ilist_type{1, 2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = const unord_set_type, + std::equal_to<> >; + test_non_transparent_contains(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = const unord_set_type >; + test_non_transparent_contains(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = const unord_set_type, + std::equal_to >; + test_non_transparent_contains(ilist_type{1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.set/count.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.set/count.transparent.pass.cpp @@ -0,0 +1,63 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_set + +// template +// size_type count(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = const unord_set_type >; + test_transparent_count(ilist_type{1, 2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = + const unord_set_type; + test_transparent_count(ilist_type{1, 2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = const unord_set_type, std::equal_to<> >; + test_non_transparent_count(ilist_type{1, 2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = + const unord_set_type >; + test_non_transparent_count(ilist_type{1, 2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = + const unord_set_type, std::equal_to >; + test_non_transparent_count(ilist_type{1, 2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.set/equal_range_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.set/equal_range_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_set + +// template +// pair equal_range(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = const unord_set_type >; + test_transparent_equal_range(ilist_type{1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = const unord_set_type; + test_transparent_equal_range(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = const unord_set_type, + std::equal_to<> >; + test_non_transparent_equal_range(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = const unord_set_type >; + test_non_transparent_equal_range(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = const unord_set_type, + std::equal_to >; + test_non_transparent_equal_range(ilist_type{1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.set/equal_range_non_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.set/equal_range_non_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_set + +// template +// pair equal_range(const K& k); + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = unord_set_type >; + test_transparent_equal_range(ilist_type{1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = unord_set_type; + test_transparent_equal_range(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = unord_set_type, + std::equal_to<> >; + test_non_transparent_equal_range(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = unord_set_type >; + test_non_transparent_equal_range(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = unord_set_type, + std::equal_to >; + test_non_transparent_equal_range(ilist_type{1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.set/find_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.set/find_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_set + +// template +// const_iterator find(const K& k) const; + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = const unord_set_type >; + test_transparent_find(ilist_type{1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = const unord_set_type; + test_transparent_find(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = const unord_set_type, + std::equal_to<> >; + test_non_transparent_find(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = const unord_set_type >; + test_non_transparent_find(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = const unord_set_type, + std::equal_to >; + test_non_transparent_find(ilist_type{1,2}); + } + + return 0; +} Index: libcxx/test/std/containers/unord/unord.set/find_non_const.transparent.pass.cpp =================================================================== --- /dev/null +++ libcxx/test/std/containers/unord/unord.set/find_non_const.transparent.pass.cpp @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// + +// template , class Pred = equal_to, +// class Alloc = allocator>> +// class unordered_set + +// template +// iterator find(const K& k); + +// UNSUPPORTED: c++03, c++11, c++14, c++17 + +#include +#include + +#include "test_transparent_unordered.h" + +int main(int, char**) +{ + using ilist_type = std::initializer_list; + + { + // Make sure conversions don't happen for transparent non-final hasher and key_equal + using set_type = unord_set_type >; + test_transparent_find(ilist_type{1,2}); + } + + { + // Make sure conversions don't happen for transparent final hasher and key_equal + using set_type = unord_set_type; + test_transparent_find(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent hasher + using set_type = unord_set_type, + std::equal_to<> >; + test_non_transparent_find(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for non-transparent key_equal + using set_type = unord_set_type >; + test_non_transparent_find(ilist_type{1,2}); + } + + { + // Make sure conversions do happen for both non-transparent hasher and key_equal + using set_type = unord_set_type, + std::equal_to >; + test_non_transparent_find(ilist_type{1,2}); + } + + return 0; +} Index: libcxx/test/std/language.support/support.limits/support.limits.general/unordered_map.version.pass.cpp =================================================================== --- libcxx/test/std/language.support/support.limits/support.limits.general/unordered_map.version.pass.cpp +++ libcxx/test/std/language.support/support.limits/support.limits.general/unordered_map.version.pass.cpp @@ -131,17 +131,11 @@ # error "__cpp_lib_erase_if should have the value 202002L in c++2a" # endif -# if !defined(_LIBCPP_VERSION) -# ifndef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" -# endif -# if __cpp_lib_generic_unordered_lookup != 201811L -# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" -# endif -# else // _LIBCPP_VERSION -# ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined because it is unimplemented in libc++!" -# endif +# ifndef __cpp_lib_generic_unordered_lookup +# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" +# endif +# if __cpp_lib_generic_unordered_lookup != 201811L +# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" # endif # ifndef __cpp_lib_node_extract Index: libcxx/test/std/language.support/support.limits/support.limits.general/unordered_set.version.pass.cpp =================================================================== --- libcxx/test/std/language.support/support.limits/support.limits.general/unordered_set.version.pass.cpp +++ libcxx/test/std/language.support/support.limits/support.limits.general/unordered_set.version.pass.cpp @@ -115,17 +115,11 @@ # error "__cpp_lib_erase_if should have the value 202002L in c++2a" # endif -# if !defined(_LIBCPP_VERSION) -# ifndef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" -# endif -# if __cpp_lib_generic_unordered_lookup != 201811L -# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" -# endif -# else // _LIBCPP_VERSION -# ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined because it is unimplemented in libc++!" -# endif +# ifndef __cpp_lib_generic_unordered_lookup +# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" +# endif +# if __cpp_lib_generic_unordered_lookup != 201811L +# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" # endif # ifndef __cpp_lib_node_extract Index: libcxx/test/std/language.support/support.limits/support.limits.general/version.version.pass.cpp =================================================================== --- libcxx/test/std/language.support/support.limits/support.limits.general/version.version.pass.cpp +++ libcxx/test/std/language.support/support.limits/support.limits.general/version.version.pass.cpp @@ -1992,17 +1992,11 @@ # error "__cpp_lib_generic_associative_lookup should have the value 201304L in c++2a" # endif -# if !defined(_LIBCPP_VERSION) -# ifndef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" -# endif -# if __cpp_lib_generic_unordered_lookup != 201811L -# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" -# endif -# else // _LIBCPP_VERSION -# ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined because it is unimplemented in libc++!" -# endif +# ifndef __cpp_lib_generic_unordered_lookup +# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" +# endif +# if __cpp_lib_generic_unordered_lookup != 201811L +# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" # endif # if !defined(_LIBCPP_VERSION) Index: libcxx/test/support/is_transparent.h =================================================================== --- libcxx/test/support/is_transparent.h +++ libcxx/test/support/is_transparent.h @@ -11,6 +11,8 @@ #include "test_macros.h" +#include // for std::equal_to + // testing transparent #if TEST_STD_VER > 11 @@ -79,6 +81,48 @@ bool operator <(const C2Int& rhs, const C2Int& lhs) { return rhs.get() < lhs.get(); } bool operator <(const C2Int& rhs, int lhs) { return rhs.get() < lhs; } -#endif +#endif // TEST_STD_VER > 11 + +#if TEST_STD_VER > 17 + +struct transparent_hash { + template + constexpr std::size_t operator()(T&& t) const + noexcept(noexcept(static_cast(std::forward(t)))) { + return static_cast(std::forward(t)); + } + + using is_transparent = void; +}; + +struct transparent_hash_final final : transparent_hash {}; + +struct transparent_equal_final final : std::equal_to<> {}; + +struct Comp2Int { // convertible from int + Comp2Int() : i_(0) {} + Comp2Int(int i) : i_(i) { ++conversions_count; } + static int get_conversions_count() { return conversions_count; } + static void reset_conversions_count() { conversions_count = 0; } + operator int() const noexcept { return i_; } + +private: + static int conversions_count; + int i_; +}; + +bool operator==(int rhs, const Comp2Int& lhs) { + return rhs == static_cast(lhs); +} +bool operator==(const Comp2Int& rhs, const Comp2Int& lhs) { + return static_cast(lhs) == static_cast(rhs); +} +bool operator==(const Comp2Int& rhs, int lhs) { + return static_cast(rhs) == lhs; +} + +int Comp2Int::conversions_count; + +#endif // TEST_STD_VER > 17 #endif // TRANSPARENT_H Index: libcxx/test/support/test_transparent_unordered.h =================================================================== --- /dev/null +++ libcxx/test/support/test_transparent_unordered.h @@ -0,0 +1,138 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#ifndef TEST_TRANSPARENT_UNORDERED_H +#define TEST_TRANSPARENT_UNORDERED_H + +#include "test_macros.h" +#include "is_transparent.h" + +// testing transparent unordered containers +#if TEST_STD_VER > 17 + +template