From: Tomasz KamiƄski Date: Tue, 26 May 2026 16:01:40 +0000 (+0200) Subject: libstdc++: Revert making ref_view statically sized. X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=bd02a048e92a778c2d3fcc011b8a88e1ac6f8183;p=thirdparty%2Fgcc.git libstdc++: Revert making ref_view statically sized. This patch reverts all changes except introduction of ranges::__static_size from r17-810-g7239744d25dadf. In addition to expected errors from breaking inplace_vector preconditions, this lead to change in the return type of define_static_array, when applied on (adapted) ref_view: int x[10]; auto x = define_static_array(x | views::transform(...)); Type of x changed from span to span, due size being statically know. This was considered beyond the scope of implementation freedom, and we should wait for acceptance of P3928R0 instead. libstdc++-v3/ChangeLog: * include/std/ranges (ref_view::size()): Only call ranges::size(*_M_r). (ref_view::empty): Only call ranges::empty(*_M_r). * testsuite/23_containers/inplace_vector/cons/from_iota_neg.cc: Except no errors from ref_view uses. * testsuite/23_containers/inplace_vector/cons/from_range_neg.cc: Likewise. --- diff --git a/libstdc++-v3/include/std/ranges b/libstdc++-v3/include/std/ranges index 2f11cc2336f..7d8b37f8c5c 100644 --- a/libstdc++-v3/include/std/ranges +++ b/libstdc++-v3/include/std/ranges @@ -1382,25 +1382,11 @@ namespace views::__adaptor constexpr bool empty() const requires requires { ranges::empty(*_M_r); } - { -#if __cplusplus > 202302L - if constexpr (__static_sized_range<_Range>) - return ranges::__static_size<_Range>() == 0; - else -#endif - return ranges::empty(*_M_r); - } + { return ranges::empty(*_M_r); } constexpr auto size() const requires sized_range<_Range> - { -#if __cplusplus > 202302L - if constexpr (__static_sized_range<_Range>) - return ranges::__static_size<_Range>(); - else -#endif - return ranges::size(*_M_r); - } + { return ranges::size(*_M_r); } constexpr auto data() const requires contiguous_range<_Range> diff --git a/libstdc++-v3/testsuite/23_containers/inplace_vector/cons/from_iota_neg.cc b/libstdc++-v3/testsuite/23_containers/inplace_vector/cons/from_iota_neg.cc index 6b66b5d97ed..ae0b96175b7 100644 --- a/libstdc++-v3/testsuite/23_containers/inplace_vector/cons/from_iota_neg.cc +++ b/libstdc++-v3/testsuite/23_containers/inplace_vector/cons/from_iota_neg.cc @@ -33,12 +33,14 @@ test_all() std::inplace_vector tr1(std::from_range, ref_view(m12)); std::inplace_vector tm2(std::from_range, m12); // { dg-error "(from here|expansion of)" } - std::inplace_vector tr2(std::from_range, ref_view(m12)); // { dg-error "(from here|expansion of)" } + // ref_view is not statically sized due pointer dereference + std::inplace_vector tr2(std::from_range, ref_view(m12)); StaticIota<__int128, 0> mm; std::inplace_vector tm3(std::from_range, mm); // { dg-error "(from here|expansion of)" } - std::inplace_vector tr3(std::from_range, ref_view(mm)); // { dg-error "(from here|expansion of)" } + // ref_view is not statically sized due pointer dereference + std::inplace_vector tr3(std::from_range, ref_view(mm)); } // { dg-error "static assertion failed" "" { target *-*-* } 0 } diff --git a/libstdc++-v3/testsuite/23_containers/inplace_vector/cons/from_range_neg.cc b/libstdc++-v3/testsuite/23_containers/inplace_vector/cons/from_range_neg.cc index ea187761e5e..48d5b4c56f5 100644 --- a/libstdc++-v3/testsuite/23_containers/inplace_vector/cons/from_range_neg.cc +++ b/libstdc++-v3/testsuite/23_containers/inplace_vector/cons/from_range_neg.cc @@ -62,14 +62,16 @@ test_all() test_one(a1); // { dg-error "from here" } test_one(s1); // { dg-error "from here" } - test_one(ref_view(a1)); // { dg-error "from here" } - test_one(a5 | std::views::adjacent<5> | std::views::elements<0>); // { dg-error "from here" } + // ref_view is not statically sized due pointer dereference + test_one(ref_view(a1)); + test_one(a5 | std::views::adjacent<7> | std::views::elements<0>); test_one(s5 | std::views::adjacent<5> | std::views::elements<0>); // { dg-error "from here" } test_five(a5); // { dg-error "from here" } test_five(s5); // { dg-error "from here" } - test_five(ref_view(a5)); // { dg-error "from here" } - test_five(a7 | std::views::adjacent<3> | std::views::elements<0>); // { dg-error "from here" } + // ref_view is not statically sized due pointer dereference + test_five(ref_view(a5)); + test_five(a7 | std::views::adjacent<3> | std::views::elements<0>); test_five(s7 | std::views::adjacent<3> | std::views::elements<0>); // { dg-error "from here" } }