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.