std::ranges::lazy_split_view<V, Pattern>::inner_iterator
struct /*inner_iterator*/;
(exposition only*)
The return type of lazy_split_view::
outer_iterator
::value_type::begin().
Const
matches the template argument of outer_iterator
.
Contents
- 1 Member types
- 2 Data members
- 3 Member functions
- 4 Member functions
- 5 std::ranges::lazy_split_view::inner_iterator::inner_iterator
- 6 std::ranges::lazy_split_view::inner_iterator::base
- 7 std::ranges::lazy_split_view::inner_iterator::operator*
- 8 std::ranges::lazy_split_view::inner_iterator::operator++
- 9 operator==(std::ranges::split_view::inner_iterator)
- 10 iter_move(std::ranges::split_view::inner_iterator)
- 11 iter_swap(std::ranges::split_view::inner_iterator)
[edit] Member types
iterator_concept
-
outer_iterator
<Const>::iterator_concept, that is std::forward_iterator_tag , ifBase
modelsforward_range
. - std::input_iterator_tag , otherwise.
iterator_category
(conditionally present)
Present only if Base
models forward_range
.
- std::forward_iterator_tag if std::iterator_traits <ranges::iterator_t <Base>>::iterator_category models std::derived_from <std::forward_iterator_tag >.
- std::iterator_traits <ranges::iterator_t <Base>>::iterator_category otherwise.
value_type
ranges::range_value_t <Base>
difference_type
ranges::range_difference_t <Base>
[edit] Data members
outer_iterator
<Const> i_
(private)
an iterator into the underlying view
of the parent object lazy_split_view
(exposition-only member object*)
incremented_
(private)
a flag that indicates whether the operator++ was invoked on this object at least once(exposition-only member object*)
[edit] Member functions
(public member function)
(public member function)
(public member function)
(public member function)
[edit] Member functions
std::ranges::lazy_split_view::inner_iterator::inner_iterator
i_
via its default member initializer (= /*outer_iterator*/<Const>()).The data member incremented_
is initialized with its default member initializer to false.
std::ranges::lazy_split_view::inner_iterator::base
requires ranges::forward_range <V>;
Returns a copy of the underlying iterator.
std::ranges::lazy_split_view::inner_iterator::operator*
Returns the element the underlying iterator points to.
Equivalent to return *i_./*cur*/();.
std::ranges::lazy_split_view::inner_iterator::operator++
incremented_ = true;
if constexpr (!ranges::forward_range <Base>)
{
if constexpr (Pattern::size() == 0)
return *this;
}
++i_./*cur*/();
if constexpr (ranges::forward_range <Base>)
{
auto tmp = *this;
++*this;
return tmp;
}
else
++*this; // no return statement
[edit] Non-member functions
(function)
(function)
operator==(std::ranges::split_view::inner_iterator)
const /*inner_iterator*/& y )
std::default_sentinel_t );
auto [pcur, pend] = ranges::subrange {x.i_.parent_->pattern_}; auto end = ranges::end (x.i_.parent_->base_); if constexpr (/*tiny_range*/<Pattern>) { const auto& cur = x.i_./*cur*/(); if (cur == end) return true; if (pcur == pend) return x.incremented_; return *cur == *pcur; } else { auto cur = x.i_./*cur*/(); if (cur == end) return true; if (pcur == pend) return x.incremented_; do { if (*cur != *pcur) return false; if (++pcur == pend) return true; } while (++cur != end); return false; }
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 std::ranges::split_view::inner_iterator
is an associated class of the arguments.
iter_move(std::ranges::split_view::inner_iterator)
noexcept(noexcept(ranges::iter_move (i.i_./*cur*/())));
Equivalent to return ranges::iter_move (i.i_./*cur*/());.
This function is not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when std::ranges::split_view::inner_iterator
is an associated class of the arguments.
iter_swap(std::ranges::split_view::inner_iterator)
const /*inner_iterator*/& y )
noexcept(noexcept(ranges::iter_swap (x.i_.current, y.i_.current)))
Equivalent to ranges::iter_swap (x.i_./*cur*/(), y.i_./*cur*/()).
This function is not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when std::ranges::split_view::inner_iterator
is an associated class of the arguments.
[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 3591 | C++20 | the && overload of base might invalidate outer iterators
|
constraints added |
LWG 3593 | C++20 | the const& overload of base returns a reference but might not be noexcept
|
made noexcept |