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.

llvm-svn: 258625
This commit is contained in:
Duncan P. N. Exon Smith 2016-01-23 15:12:47 +00:00
parent ead22d095e
commit ad783ce909
1 changed files with 3 additions and 27 deletions

View File

@ -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());