diff --git a/libstdc++-v3/include/bits/ranges_algo.h b/libstdc++-v3/include/bits/ranges_algo.h index cda3042c11f..ecf1378742d 100644 --- a/libstdc++-v3/include/bits/ranges_algo.h +++ b/libstdc++-v3/include/bits/ranges_algo.h @@ -1396,6 +1396,13 @@ namespace ranges inline constexpr __unique_fn unique{}; + namespace __detail + { + template + concept __can_reread_output = input_iterator<_Out> + && same_as<_Tp, iter_value_t<_Out>>; + } + template using unique_copy_result = in_out_result<_Iter, _Out>; @@ -1407,8 +1414,7 @@ namespace ranges projected<_Iter, _Proj>> _Comp = ranges::equal_to> requires indirectly_copyable<_Iter, _Out> && (forward_iterator<_Iter> - || (input_iterator<_Out> - && same_as, iter_value_t<_Out>>) + || __detail::__can_reread_output<_Out, iter_value_t<_Iter>> || indirectly_copyable_storable<_Iter, _Out>) constexpr unique_copy_result<_Iter, _Out> operator()(_Iter __first, _Sent __last, _Out __result, @@ -1432,8 +1438,7 @@ namespace ranges } return {__next, std::move(++__result)}; } - else if constexpr (input_iterator<_Out> - && same_as, iter_value_t<_Out>>) + else if constexpr (__detail::__can_reread_output<_Out, iter_value_t<_Iter>>) { *__result = *__first; while (++__first != __last) @@ -1467,8 +1472,7 @@ namespace ranges projected, _Proj>> _Comp = ranges::equal_to> requires indirectly_copyable, _Out> && (forward_iterator> - || (input_iterator<_Out> - && same_as, iter_value_t<_Out>>) + || __detail::__can_reread_output<_Out, range_value_t<_Range>> || indirectly_copyable_storable, _Out>) constexpr unique_copy_result, _Out> operator()(_Range&& __r, _Out __result, diff --git a/libstdc++-v3/testsuite/std/ranges/range.cc b/libstdc++-v3/testsuite/std/ranges/range.cc index 795aca472e5..aa29af471a4 100644 --- a/libstdc++-v3/testsuite/std/ranges/range.cc +++ b/libstdc++-v3/testsuite/std/ranges/range.cc @@ -75,9 +75,6 @@ static_assert( same_as, static_assert( same_as, std::ptrdiff_t> ); -static_assert( same_as, - char> ); - static_assert( same_as, char&> ); static_assert( same_as, diff --git a/libstdc++-v3/testsuite/util/testsuite_iterators.h b/libstdc++-v3/testsuite/util/testsuite_iterators.h index 67da06b8482..4e668d648f2 100644 --- a/libstdc++-v3/testsuite/util/testsuite_iterators.h +++ b/libstdc++-v3/testsuite/util/testsuite_iterators.h @@ -122,7 +122,7 @@ namespace __gnu_test */ template struct output_iterator_wrapper - : public std::iterator + : public std::iterator { protected: output_iterator_wrapper() : ptr(0), SharedInfo(0)