template<typename _Tp>
concept __static_sized_range = sized_range<_Tp> && requires (_Tp& __t)
{ static_cast<char(*)[size_t(ranges::size(__t) >= 0)]>(nullptr); };
+
+ template<__static_sized_range _Range>
+ consteval range_size_t<_Range>
+ __static_size()
+ {
+ auto __conjure = [](_Range& __r)
+ {
+ if constexpr (ranges::size(__r) <= size_t(-1))
+ return integral_constant<size_t, size_t(ranges::size(__r))>{};
+ else
+ return integral_constant<range_size_t<_Range>, ranges::size(__r)>{};
+ };
+ return range_size_t<_Range>(decltype(__conjure(std::declval<_Range&>()))::value);
+ }
#endif // C++26
template<typename _Derived>
constexpr bool
empty() const requires requires { ranges::empty(*_M_r); }
- { return 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);
+ }
constexpr auto
size() const requires sized_range<_Range>
- { return ranges::size(*_M_r); }
+ {
+#if __cplusplus > 202302L
+ if constexpr (__static_sized_range<_Range>)
+ return ranges::__static_size<_Range>();
+ else
+#endif
+ 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)" }
- // ref_view is not statically sized due pointer dereference
- std::inplace_vector<int, 10> tr2(std::from_range, ref_view(m12));
+ std::inplace_vector<int, 10> tr2(std::from_range, ref_view(m12)); // { dg-error "(from here|expansion of)" }
StaticIota<__int128, 0> mm;
std::inplace_vector<int, 10> tm3(std::from_range, 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));
+ std::inplace_vector<int, 10> tr3(std::from_range, ref_view(mm)); // { dg-error "(from here|expansion of)" }
}
// { dg-error "static assertion failed" "" { target *-*-* } 0 }
test_one(a1); // { dg-error "from here" }
test_one(s1); // { 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(ref_view(a1)); // { dg-error "from here" }
+ test_one(a5 | std::views::adjacent<5> | std::views::elements<0>); // { dg-error "from here" }
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" }
- // 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(ref_view(a5)); // { dg-error "from here" }
+ test_five(a7 | std::views::adjacent<3> | std::views::elements<0>); // { dg-error "from here" }
test_five(s7 | std::views::adjacent<3> | std::views::elements<0>); // { dg-error "from here" }
}