Implement P0513R0 - "Poisoning the Hash"
Summary: Exactly what the title says. This patch also adds a `std::hash<nullptr_t>` specialization in C++17, but it was not added by this paper and I can't find the actual paper that adds it. See http://wg21.link/P0513R0 for more info. If there are no comments in the next couple of days I'll commit this Reviewers: mclow.lists, K-ballo, EricWF Reviewed By: EricWF Subscribers: cfe-commits Differential Revision: https://reviews.llvm.org/D28938 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@292684 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -1534,7 +1534,8 @@ auto swap(variant<_Types...>& __lhs,
|
||||
}
|
||||
|
||||
template <class... _Types>
|
||||
struct _LIBCPP_TEMPLATE_VIS hash<variant<_Types...>> {
|
||||
struct _LIBCPP_TEMPLATE_VIS hash<
|
||||
__enable_hash_helper<variant<_Types...>, remove_const_t<_Types>...>> {
|
||||
using argument_type = variant<_Types...>;
|
||||
using result_type = size_t;
|
||||
|
||||
@@ -1547,7 +1548,8 @@ struct _LIBCPP_TEMPLATE_VIS hash<variant<_Types...>> {
|
||||
: __variant::__visit_alt(
|
||||
[](const auto& __alt) {
|
||||
using __alt_type = decay_t<decltype(__alt)>;
|
||||
using __value_type = typename __alt_type::__value_type;
|
||||
using __value_type = remove_const_t<
|
||||
typename __alt_type::__value_type>;
|
||||
return hash<__value_type>{}(__alt.__value);
|
||||
},
|
||||
__v);
|
||||
|
||||
Reference in New Issue
Block a user