+2011-01-24 Johannes Singler <singler@kit.edu>
+
+ PR libstdc++/47433
+ * include/parallel/losertree.h
+ (_LoserTree<>::__delete_min_insert):
+ Do not qualify swap with std:: for value type,
+ but include a using directive instead.
+ (_LoserTreeUnguarded<>::__delete_min_insert): Likewise.
+ * include/parallel/balanced_quicksort.h (__qsb_divide):
+ Use std::iter_swap instead of std::swap.
+ (__qsb_local_sort_with_helping): Likewise.
+ * include/parallel/partition.h (__parallel_partition):
+ Likewise. (__parallel_nth_element): Likewise.
+
2011-01-24 Johannes Singler <singler@kit.edu>
PR libstdc++/47437
// Swap pivot value to end.
if (__pivot_pos != (__end - 1))
- std::swap(*__pivot_pos, *(__end - 1));
+ std::iter_swap(__pivot_pos, __end - 1);
__pivot_pos = __end - 1;
__gnu_parallel::__binder2nd<_Compare, _ValueType, _ValueType, bool>
__num_threads);
// Swap back pivot to middle.
- std::swap(*(__begin + __split_pos), *__pivot_pos);
+ std::iter_swap(__begin + __split_pos, __pivot_pos);
__pivot_pos = __begin + __split_pos;
#if _GLIBCXX_ASSERTIONS
// Swap __pivot_pos value to end.
if (__pivot_pos != (__end - 1))
- std::swap(*__pivot_pos, *(__end - 1));
+ std::iter_swap(__pivot_pos, __end - 1);
__pivot_pos = __end - 1;
__gnu_parallel::__binder2nd
#endif
// Swap pivot back to middle.
if (__split_pos1 != __pivot_pos)
- std::swap(*__split_pos1, *__pivot_pos);
+ std::iter_swap(__split_pos1, __pivot_pos);
__pivot_pos = __split_pos1;
// In case all elements are equal, __split_pos1 == 0.
void
__delete_min_insert(_Tp __key, bool __sup)
{
+ using std::swap;
#if _GLIBCXX_ASSERTIONS
// no dummy sequence can ever be at the top!
_GLIBCXX_PARALLEL_ASSERT(_M_losers[0]._M_source != -1);
// The other one is smaller.
std::swap(_M_losers[__pos]._M_sup, __sup);
std::swap(_M_losers[__pos]._M_source, __source);
- std::swap(_M_losers[__pos]._M_key, __key);
+ swap(_M_losers[__pos]._M_key, __key);
}
}
void
__delete_min_insert(_Tp __key, bool __sup)
{
+ using std::swap;
#if _GLIBCXX_ASSERTIONS
// no dummy sequence can ever be at the top!
_GLIBCXX_PARALLEL_ASSERT(_M_losers[0]._M_source != -1);
// The other one is smaller.
std::swap(_M_losers[__pos]._M_sup, __sup);
std::swap(_M_losers[__pos]._M_source, __source);
- std::swap(_M_losers[__pos]._M_key, __key);
+ swap(_M_losers[__pos]._M_key, __key);
}
}
void
__delete_min_insert(_Tp __key, bool)
{
+ using std::swap;
#if _GLIBCXX_ASSERTIONS
// no dummy sequence can ever be at the top!
_GLIBCXX_PARALLEL_ASSERT(_M_losers[0]._M_source != -1);
{
// The other one is smaller.
std::swap(_M_losers[__pos]._M_source, __source);
- std::swap(_M_losers[__pos]._M_key, __key);
+ swap(_M_losers[__pos]._M_key, __key);
}
}
{
// The other one is smaller.
std::swap(_M_losers[__pos]._M_source, __source);
- std::swap(_M_losers[__pos]._M_key, __key);
+ swap(_M_losers[__pos]._M_key, __key);
}
}
// Fetch new chunk(__s).
break;
- std::swap(__begin[__thread_left],
- __begin[__thread_right]);
+ std::iter_swap(__begin + __thread_left,
+ __begin + __thread_right);
++__thread_left;
--__thread_right;
}
if (__final_left == __final_right)
break;
- std::swap(__begin[__final_left], __begin[__final_right]);
+ std::iter_swap(__begin + __final_left, __begin + __final_right);
++__final_left;
--__final_right;
}
// Swap __pivot_pos value to end.
if (__pivot_pos != (__end - 1))
- std::swap(*__pivot_pos, *(__end - 1));
+ std::iter_swap(__pivot_pos, __end - 1);
__pivot_pos = __end - 1;
// _Compare must have first_value_type, second_value_type,
// Swap pivot back to middle.
if (__split_pos1 != __pivot_pos)
- std::swap(*__split_pos1, *__pivot_pos);
+ std::iter_swap(__split_pos1, __pivot_pos);
__pivot_pos = __split_pos1;
// In case all elements are equal, __split_pos1 == 0