From b74f0db11a4e62e044b816c5d275df37ee728396 Mon Sep 17 00:00:00 2001 From: Jonathan Wakely Date: Fri, 18 Aug 2017 19:20:43 +0100 Subject: [PATCH] Simplify allocator usage in unordered containers * include/bits/hashtable_policy.h (_ReuseOrAllocNode): Remove __value_alloc_type and __value_alloc_traits typedefs. (_ReuseOrAllocNode::operator()): Call construct and destroy on the node allocator. (_Hashtable_alloc): Simplify __value_alloc_traits typedef. (_Hashtable_alloc<_NodeAlloc>::_M_allocate_node(_Args&&...)): Call construct on the node allocator. (_Hashtable_alloc<_NodeAlloc>::_M_deallocate_node(__node_type*)): Call destroy on the node allocator. From-SVN: r251187 --- libstdc++-v3/ChangeLog | 10 +++++++ libstdc++-v3/include/bits/hashtable_policy.h | 29 ++++++++------------ 2 files changed, 21 insertions(+), 18 deletions(-) diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 710cc9dd691..1b17da249d2 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,5 +1,15 @@ 2017-08-18 Jonathan Wakely + * include/bits/hashtable_policy.h (_ReuseOrAllocNode): Remove + __value_alloc_type and __value_alloc_traits typedefs. + (_ReuseOrAllocNode::operator()): Call construct and destroy on the + node allocator. + (_Hashtable_alloc): Simplify __value_alloc_traits typedef. + (_Hashtable_alloc<_NodeAlloc>::_M_allocate_node(_Args&&...)): Call + construct on the node allocator. + (_Hashtable_alloc<_NodeAlloc>::_M_deallocate_node(__node_type*)): Call + destroy on the node allocator. + PR libstdc++/81891 * include/bits/hashtable.h (_Hashtable(_InputIterator, _InputIterator, size_type, const _H1&, const _H2&, const _Hash&, const _Equal&, diff --git a/libstdc++-v3/include/bits/hashtable_policy.h b/libstdc++-v3/include/bits/hashtable_policy.h index a3a31d1fb11..5f2d8776aaa 100644 --- a/libstdc++-v3/include/bits/hashtable_policy.h +++ b/libstdc++-v3/include/bits/hashtable_policy.h @@ -111,9 +111,6 @@ namespace __detail private: using __node_alloc_type = _NodeAlloc; using __hashtable_alloc = _Hashtable_alloc<__node_alloc_type>; - using __value_alloc_type = typename __hashtable_alloc::__value_alloc_type; - using __value_alloc_traits = - typename __hashtable_alloc::__value_alloc_traits; using __node_alloc_traits = typename __hashtable_alloc::__node_alloc_traits; using __node_type = typename __hashtable_alloc::__node_type; @@ -135,18 +132,17 @@ namespace __detail __node_type* __node = _M_nodes; _M_nodes = _M_nodes->_M_next(); __node->_M_nxt = nullptr; - __value_alloc_type __a(_M_h._M_node_allocator()); - __value_alloc_traits::destroy(__a, __node->_M_valptr()); + auto& __a = _M_h._M_node_allocator(); + __node_alloc_traits::destroy(__a, __node->_M_valptr()); __try { - __value_alloc_traits::construct(__a, __node->_M_valptr(), - std::forward<_Arg>(__arg)); + __node_alloc_traits::construct(__a, __node->_M_valptr(), + std::forward<_Arg>(__arg)); } __catch(...) { __node->~__node_type(); - __node_alloc_traits::deallocate(_M_h._M_node_allocator(), - __node, 1); + __node_alloc_traits::deallocate(__a, __node, 1); __throw_exception_again; } return __node; @@ -2000,10 +1996,8 @@ namespace __detail // Use __gnu_cxx to benefit from _S_always_equal and al. using __node_alloc_traits = __gnu_cxx::__alloc_traits<__node_alloc_type>; - using __value_type = typename __node_type::value_type; - using __value_alloc_type = - __alloc_rebind<__node_alloc_type, __value_type>; - using __value_alloc_traits = std::allocator_traits<__value_alloc_type>; + using __value_alloc_traits = typename __node_alloc_traits::template + rebind_traits; using __node_base = __detail::_Hash_node_base; using __bucket_type = __node_base*; @@ -2057,10 +2051,10 @@ namespace __detail __node_type* __n = std::__addressof(*__nptr); __try { - __value_alloc_type __a(_M_node_allocator()); ::new ((void*)__n) __node_type; - __value_alloc_traits::construct(__a, __n->_M_valptr(), - std::forward<_Args>(__args)...); + __node_alloc_traits::construct(_M_node_allocator(), + __n->_M_valptr(), + std::forward<_Args>(__args)...); return __n; } __catch(...) @@ -2076,8 +2070,7 @@ namespace __detail { typedef typename __node_alloc_traits::pointer _Ptr; auto __ptr = std::pointer_traits<_Ptr>::pointer_to(*__n); - __value_alloc_type __a(_M_node_allocator()); - __value_alloc_traits::destroy(__a, __n->_M_valptr()); + __node_alloc_traits::destroy(_M_node_allocator(), __n->_M_valptr()); __n->~__node_type(); __node_alloc_traits::deallocate(_M_node_allocator(), __ptr, 1); } -- 2.30.2