[range.take.sentinel] (original) (raw)
25 Ranges library [ranges]
25.7 Range adaptors [range.adaptors]
25.7.10 Take view [range.take]
25.7.10.3 Class template take_view::sentinel [range.take.sentinel]
namespace std::ranges { template<view V> template<bool Const> class take_view<V>::sentinel { private: using Base = maybe-const<Const, V>; template<bool OtherConst> using CI = counted_iterator<iterator_t<_maybe-const_<OtherConst, V>>>; sentinel_t<_Base_> end_ = sentinel_t<_Base_>(); public: sentinel() = default;constexpr explicit sentinel(sentinel_t<_Base_> end);constexpr sentinel(sentinel<!Const> s) requires Const && convertible_to<sentinel_t<V>, sentinel_t<_Base_>>;constexpr sentinel_t<_Base_> base() const;friend constexpr bool operator==(const CI<Const>& y, const sentinel& x);template<bool OtherConst = !Const> requires sentinel_for<sentinel_t<_Base_>, iterator_t<_maybe-const_<OtherConst, V>>> friend constexpr bool operator==(const CI<OtherConst>& y, const sentinel& x);};}
constexpr explicit _sentinel_(sentinel_t<_Base_> end);
Effects: Initializes end_ with end.
constexpr _sentinel_(_sentinel_<!Const> s) requires Const && [convertible_to](concept.convertible#concept:convertible%5Fto "18.4.4 Concept convertible_to [concept.convertible]")<sentinel_t<V>, sentinel_t<_Base_>>;
Effects: Initializes end_ with std::move(s.end_).
constexpr sentinel_t<_Base_> base() const;
Effects: Equivalent to: return end_;
friend constexpr bool operator==(const _CI_<Const>& y, const _sentinel_& x);template<bool OtherConst = !Const> requires [sentinel_for](iterator.concept.sentinel#concept:sentinel%5Ffor "24.3.4.7 Concept sentinel_for [iterator.concept.sentinel]")<sentinel_t<_Base_>, iterator_t<_maybe-const_<OtherConst, V>>> friend constexpr bool operator==(const _CI_<OtherConst>& y, const _sentinel_& x);
Effects: Equivalent to:return y.count() == 0 || y.base() == x.end_;