On this page
std::ranges::filter_view<V,Pred>::iterator
|  | (since C++20) (exposition only*) | 
The return type of filter_view::begin.
This is a bidirectional_iterator if V models bidirectional_range, a forward_iterator if V models forward_range, and input_iterator otherwise.
Modification of the element denoted by this iterator is permitted, but results in undefined behavior if the resulting value does not satisfy the filter's predicate.
Member types
| Member type | Definition | 
|---|---|
| iterator_concept | 
 | 
| iterator_category | Defined if and only if  
 | 
| value_type | ranges::range_value_t<V> | 
| difference_type | ranges::range_difference_t<V> | 
Data members
| Member name | Definition | 
|---|---|
| current_(private) | An iterator of type ranges::iterator_t<V>into the underlyingview.(exposition-only member object*) | 
| parent_(private) | A pointer of type ranges::filter_view<V, Pred>*to the parentfilter_viewobject.(exposition-only member object*) | 
Member functions
| (C++20)
        | constructs an iterator (public member function) | 
| (C++20)
        | returns the underlying iterator (public member function) | 
| (C++20)
        | forwards to the underlying iterator (public member function) | 
| (C++20)
        | advances the iterator (public member function) | 
| (C++20)
        | decrements the iterator (public member function) | 
std::ranges::filter_view::iterator::iterator
|  | (1) | (since C++20) | 
|  | (2) | (since C++20) | 
current_ and parent_ with their default member initializers, which are = ranges::iterator_t<V>() and = nullptr respectively.
   std::ranges::filter_view::iterator::base
|  | (1) | (since C++20) | 
|  | (2) | (since C++20) | 
return current_;.
   return std::move(current_);.
   std::ranges::filter_view::iterator::operator*,->
|  | (1) | (since C++20) | 
|  | (2) | (since C++20) | 
return *current_;.
   return current_;.For a type
I, /*has-arrow*/<I> is modeled or satisfied, if and only if I models or satisfies input_iterator respectively, and either I is a pointer type or requires(I i){ i.operator->();} is true.
   std::ranges::filter_view::iterator::operator++
|  | (1) | (since C++20) | 
|  | (2) | (since C++20) | 
|  | (3) | (since C++20) | 
current_ = ranges::find_if(std::move(++current_), ranges::end(parent_->base_),
 std::ref(*parent_->pred_));
 return *this;.
   ++*this;.
   auto tmp = *this; ++*this; return tmp;.
   std::ranges::filter_view::iterator::operator--
|  | (1) | (since C++20) | 
|  | (2) | (since C++20) | 
auto tmp = *this; --*this; return tmp;.
   Non-member functions
| (C++20)
        | compares the underlying iterators (function) | 
| (C++20)
        | casts the result of dereferencing the underlying iterator to its associated rvalue reference type (function) | 
| (C++20)
        | swaps the objects pointed to by two underlying iterators (function) | 
operator==(std::ranges::filter_view::iterator)
|  | (since C++20) | 
Equivalent to return x.current_ == y.current_;.
The != operator is synthesized from operator==.
This function is not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when std::ranges::filter_view::iterator is an associated class of the arguments.
iter_move(std::ranges::filter_view::iterator)
|  | (since C++20) | 
Equivalent to return ranges::iter_move(i.current_);.
This function is not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when std::ranges::filter_view::iterator is an associated class of the arguments.
iter_swap(std::ranges::filter_view::iterator)
|  | (since C++20) | 
Equivalent to ranges::iter_swap(x.current_, y.current_).
This function is not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when std::ranges::filter_view::iterator is an associated class of the arguments.
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior | 
|---|---|---|---|
| P2259R1 | C++20 | member type iterator_categorywas always defined | defined only if Vis aforward_range | 
| LWG 3533 | C++20 | the const&overload ofbasecopied the underlying iterator | returns a reference to it | 
| LWG 3593 | C++20 | the const&overload ofbasemight not be noexcept | made noexcept | 
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
 https://en.cppreference.com/w/cpp/ranges/filter_view/iterator