From b37d9e538123c71c6e3478ed902561131d1bf0be Mon Sep 17 00:00:00 2001 From: Jonathan Wakely Date: Wed, 12 Jun 2024 15:02:14 +0100 Subject: [PATCH] libstdc++: Add ranges::range_common_reference_t for C++20 (LWG 3860) LWG 3860 added this alias template. Both libc++ and MSVC treat this as a DR for C++20, so this change does so too. libstdc++-v3/ChangeLog: * include/bits/ranges_base.h (range_common_reference_t): New alias template, as per LWG 3860. * testsuite/std/ranges/range.cc: Check it. (cherry picked from commit 92b554a8412624a0aa3ca9b502976ebec7eff34e) --- libstdc++-v3/include/bits/ranges_base.h | 6 ++++++ libstdc++-v3/testsuite/std/ranges/range.cc | 6 ++++++ 2 files changed, 12 insertions(+) diff --git a/libstdc++-v3/include/bits/ranges_base.h b/libstdc++-v3/include/bits/ranges_base.h index 67ac8db8b469..937fbbae12eb 100644 --- a/libstdc++-v3/include/bits/ranges_base.h +++ b/libstdc++-v3/include/bits/ranges_base.h @@ -537,6 +537,12 @@ namespace ranges using range_rvalue_reference_t = iter_rvalue_reference_t>; + // _GLIBCXX_RESOLVE_LIB_DEFECTS + // 3860. range_common_reference_t is missing + template + using range_common_reference_t + = iter_common_reference_t>; + /// [range.sized] The sized_range concept. template concept sized_range = range<_Tp> diff --git a/libstdc++-v3/testsuite/std/ranges/range.cc b/libstdc++-v3/testsuite/std/ranges/range.cc index 184356591375..760f6ffacfdb 100644 --- a/libstdc++-v3/testsuite/std/ranges/range.cc +++ b/libstdc++-v3/testsuite/std/ranges/range.cc @@ -83,3 +83,9 @@ static_assert( same_as, char&&> ); static_assert( same_as, WritableObject> ); + +// LWG 3860. range_common_reference_t is missing +static_assert( same_as, + char&> ); +static_assert( same_as, + char&> ); -- 2.47.2