mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 03:32:35 +08:00
Revert "unordered_map: Reuse insert logic in emplace when possible, NFC"
This reverts commit r258575. EricWF sent me an email (no link since it was off-list) requesting to review this pre-commit instead of post-commit. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@258625 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -922,32 +922,8 @@ public:
|
||||
#ifndef _LIBCPP_HAS_NO_VARIADICS
|
||||
|
||||
template <class... _Args>
|
||||
pair<iterator, bool> emplace(_Args&&... __args)
|
||||
{return __emplace_dispatch(std::forward<_Args>(__args)...);}
|
||||
pair<iterator, bool> emplace(_Args&&... __args);
|
||||
|
||||
private:
|
||||
template <class _Arg>
|
||||
pair<iterator, bool> __emplace_dispatch(_Arg&& __arg)
|
||||
{
|
||||
typedef is_constructible<value_type, _Arg> __constructible;
|
||||
return __emplace_insert_if_constructible(std::forward<_Arg>(__arg),
|
||||
__constructible());
|
||||
}
|
||||
template <class _Arg1, class... _Args>
|
||||
pair<iterator, bool> __emplace_dispatch(_Arg1&& __arg1, _Args&&... __args)
|
||||
{return __emplace_impl(std::forward<_Arg1>(__arg1), std::forward<_Args>(__args)...);}
|
||||
|
||||
template <class _Arg>
|
||||
pair<iterator, bool> __emplace_insert_if_constructible(_Arg&& __arg, false_type)
|
||||
{return __emplace_impl(std::forward<_Arg>(__arg));}
|
||||
template <class _Arg>
|
||||
pair<iterator, bool> __emplace_insert_if_constructible(_Arg&& __arg, true_type)
|
||||
{return insert(std::forward<_Arg>(__arg));}
|
||||
|
||||
template <class... _Args>
|
||||
pair<iterator, bool> __emplace_impl(_Args&&... __args);
|
||||
|
||||
public:
|
||||
template <class... _Args>
|
||||
_LIBCPP_INLINE_VISIBILITY
|
||||
#if _LIBCPP_DEBUG_LEVEL >= 2
|
||||
@@ -956,7 +932,7 @@ public:
|
||||
_LIBCPP_ASSERT(__get_const_db()->__find_c_from_i(&__p) == this,
|
||||
"unordered_map::emplace_hint(const_iterator, args...) called with an iterator not"
|
||||
" referring to this unordered_map");
|
||||
return emplace(_VSTD::forward<_Args>(__args)...).first;
|
||||
return __table_.__emplace_unique(_VSTD::forward<_Args>(__args)...).first;
|
||||
}
|
||||
#else
|
||||
iterator emplace_hint(const_iterator, _Args&&... __args)
|
||||
@@ -1501,7 +1477,7 @@ unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__construct_node(_A0&& __a0,
|
||||
template <class _Key, class _Tp, class _Hash, class _Pred, class _Alloc>
|
||||
template <class... _Args>
|
||||
pair<typename unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::iterator, bool>
|
||||
unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::__emplace_impl(_Args&&... __args)
|
||||
unordered_map<_Key, _Tp, _Hash, _Pred, _Alloc>::emplace(_Args&&... __args)
|
||||
{
|
||||
__node_holder __h = __construct_node(_VSTD::forward<_Args>(__args)...);
|
||||
pair<iterator, bool> __r = __table_.__node_insert_unique(__h.get());
|
||||
|
Reference in New Issue
Block a user