std::ranges::repeat_view<W, Bound>::iterator
|
struct /*iterator*/;
|
(1) | (since C++23) (exposition only*) |
The return type of repeat_view::begin.
Member types
| Member type | Definition |
index-type |
|
iterator_concept |
std::random_access_iterator_tag |
iterator_category |
std::random_access_iterator_tag |
value_type |
W |
difference_type |
|
Data members
Typical implementation of this iterator type contains two data members:
value_(exposition only*) - A pointer of type const W* that holds the pointer to the value to repeat;current_(exposition only*) - An object of type /*index-type*/ that holds the current position.
Member functions
|
(constructor)
(C++23)
|
constructs an iterator (public member function) |
|
operator*
(C++23)
|
returns the current subrange (public member function) |
|
operator[]
(C++23)
|
accesses an element by index (public member function) |
|
operator++operator++(int)operator--operator--(int)operator+=operator-=
(C++23)
|
advances or decrements the underlying iterator (public member function) |
std::ranges::repeat_view::iterator::iterator
|
/*iterator*/() = default;
|
(1) | (since C++23) |
|
constexpr explicit /*iterator*/(
const W* value, /*index-type*/ b = /*index-type*/() ); |
(2) | (since C++23) (exposition only*) |
value_with nullptr_t via its default member initializer;index_via its default member initializer (= /*index-type*/()).
value_ with value and bound_ with b. If Bound is not std::unreachable_sentinel_t then b must be non-negative. This constructor is not a part of the public interface.std::ranges::repeat_view::iterator::operator*
|
constexpr const W& operator*() const noexcept;
|
(since C++23) | |
Equivalent to return *value_;.
std::ranges::repeat_view::iterator::operator[]
|
constexpr const W& operator[]( difference_type n ) const noexcept;
|
(since C++23) | |
Equivalent to return *(*this + n);.
std::ranges::repeat_view::iterator::operator++
|
constexpr /*iterator*/& operator++();
|
(1) | (since C++23) |
|
constexpr void operator++(int);
|
(2) | (since C++23) |
std::ranges::repeat_view::iterator::operator--
|
constexpr /*iterator*/& operator--();
|
(1) | (since C++23) |
|
constexpr /*iterator*/ operator--(int);
|
(2) | (since C++23) |
bound_ must be positive.std::ranges::repeat_view::iterator::operator+=
|
constexpr /*iterator*/& operator+=( difference_type n );
|
(since C++23) | |
Equivalent to current_ += n; return *this;. If Bound is not std::unreachable_sentinel_t then (bound_ + n) must be non-negative.
std::ranges::repeat_view::iterator::operator-=
|
constexpr /*iterator*/& operator-=( difference_type n );
|
(since C++23) | |
Equivalent to current_ -= n; return *this;. If Bound is not std::unreachable_sentinel_t, then (bound_ - n) must be non-negative.
Non-member functions
|
operator==operator<=>
(C++23)
|
compares the underlying iterators (function) |
|
operator+operator-
(C++23)
|
performs iterator arithmetic (function) |
operator==, <=>(std::ranges::repeat_view::iterator)
|
friend constexpr bool operator==( const /*iterator*/& x, const /*iterator*/& y );
|
(1) | (since C++23) |
|
friend constexpr auto operator<=>( const /*iterator*/& x, const /*iterator*/& y );
|
(2) | (since C++23) |
The != operator is synthesized from operator==.
These functions are not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when iterator is an associated class of the arguments.
operator+(std::ranges::repeat_view::iterator)
|
friend constexpr /*iterator*/ operator+( /*iterator*/ i, difference_type n );
|
(1) | (since C++23) |
|
friend constexpr /*iterator*/ operator+( difference_type n, /*iterator*/ i );
|
(2) | (since C++23) |
Equivalent to i += n; return i;.
These functions are not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when iterator is an associated class of the arguments.
operator-(std::ranges::repeat_view::iterator)
|
friend constexpr /*iterator*/ operator-( /*iterator*/ i, difference_type n );
|
(1) | (since C++23) |
|
friend constexpr difference_type operator-( const /*iterator*/& x,
const /*iterator*/& y ); |
(2) | (since C++23) |
These functions are not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when iterator is an associated class of the arguments.
Notes
iterator is always random_access_iterator.