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<const ...> to span<const ..., 10>,
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.
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>
std::inplace_vector<int, 15> tr1(std::from_range, ref_view(m12));
std::inplace_vector<int, 10> tm2(std::from_range, m12); // { dg-error "(from here|expansion of)" }
- std::inplace_vector<int, 10> 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<int, 10> tr2(std::from_range, ref_view(m12));
StaticIota<__int128, 0> mm;
std::inplace_vector<int, 10> tm3(std::from_range, mm); // { dg-error "(from here|expansion of)" }
- std::inplace_vector<int, 10> 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<int, 10> tr3(std::from_range, ref_view(mm));
}
// { dg-error "static assertion failed" "" { target *-*-* } 0 }
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" }
}