DIWNE::FilteredNodeIterator
#include "DIWNE/Core/diwne_iterators.h"
Inherits from DIWNE::FilteredNodeIteratorImpl< FilteredNodeIterator< Node >, Node, false >, DIWNE::BidirectionalNodeIterator< Iterator, NodeType, IsConst >, DIWNE::ForwardNodeIterator< Iterator, NodeType, IsConst >, DIWNE::ForwardIteratorBase< Iterator, NodeType, IsConst >
Public Types
Name | |
---|---|
using typename Super::shared_pointer | shared_pointer |
Protected Types
Name | |
---|---|
using FilteredNodeIteratorImpl< FilteredNodeIterator< NodeType >, NodeType, false > | Super |
Public Functions
Name | |
---|---|
FilteredNodeIterator() | |
FilteredNodeIterator(typename Super::Predicate predicate, typename Super::Container nodes, std::size_t idx) |
Additional inherited members
Protected Types inherited from DIWNE::FilteredNodeIteratorImpl< FilteredNodeIterator< Node >, Node, false >
Name | |
---|---|
using bool(*)(const Node *) | Predicate |
Public Functions inherited from DIWNE::FilteredNodeIteratorImpl< FilteredNodeIterator< Node >, Node, false >
Name | |
---|---|
FilteredNodeIteratorImpl() | |
FilteredNodeIteratorImpl(Predicate predicate, typename Super::Container nodes, std::size_t idx) | |
virtual void | back()<br>Move the iterator to the previous position. |
void | next() |
bool | valid() const |
Protected Attributes inherited from DIWNE::FilteredNodeIteratorImpl< FilteredNodeIterator< Node >, Node, false >
Name | |
---|---|
Predicate | _predicate |
Public Types inherited from DIWNE::BidirectionalNodeIterator< Iterator, NodeType, IsConst >
Name | |
---|---|
using std::bidirectional_iterator_tag | iterator_category |
Public Functions inherited from DIWNE::BidirectionalNodeIterator< Iterator, NodeType, IsConst >
Name | |
---|---|
BidirectionalNodeIterator() | |
BidirectionalNodeIterator(Super::Container nodes, std::size_t idx) | |
virtual void | back()<br>Move the iterator to the previous position. |
Iterator & | operator--() |
Iterator | operator--(int ) |
bool | valid() const |
Public Types inherited from DIWNE::ForwardNodeIterator< Iterator, NodeType, IsConst >
Name | |
---|---|
using const NodeList * | Container |
Public Functions inherited from DIWNE::ForwardNodeIterator< Iterator, NodeType, IsConst >
Name | |
---|---|
ForwardNodeIterator() | |
ForwardNodeIterator(Container nodes, std::size_t idx) | |
reference | dereference() const |
bool | equals(const Iterator & b) const<br>Determines whether this iterator is pointing to the same element as another one (used by the == operator) |
void | next()<br>Advance the iterator. |
pointer | ptr() const |
shared_pointer | sharedPtr() const |
bool | valid() const<br>Check whether the iterator is pointing at a valid element (eg. not the end of a container) |
Protected Attributes inherited from DIWNE::ForwardNodeIterator< Iterator, NodeType, IsConst >
Name | |
---|---|
std::size_t | _idx <br>Current node index // TODO: Should probably be an int. |
Container | _nodes <br>Reference to the node list. |
Public Types inherited from DIWNE::ForwardIteratorBase< Iterator, NodeType, IsConst >
Name | |
---|---|
using std::ptrdiff_t | difference_type |
using std::forward_iterator_tag | iterator_category |
using typename std::conditional< IsConst, const Value *, Value * >::type | pointer |
using typename std::conditional< IsConst, const Value &, Value & >::type | reference |
using typename std::conditional< IsConst, const Value, Value >::type | value_type |
Public Functions inherited from DIWNE::ForwardIteratorBase< Iterator, NodeType, IsConst >
Name | |
---|---|
reference | operator*() |
Iterator & | operator++() |
Iterator | operator++(int ) |
pointer | operator->() |
Protected Functions inherited from DIWNE::ForwardIteratorBase< Iterator, NodeType, IsConst >
Name | |
---|---|
ForwardIteratorBase() | |
virtual | ~ForwardIteratorBase() =default |
reference | dereference() const<br>Return a reference to the current element (reference to a value type, not a pointer). |
bool | equals(const Iterator & b) const<br>Determines whether this iterator is pointing to the same element as another one (used by the == operator) |
void | next()<br>Advance the iterator. |
pointer | ptr() const<br>Return a raw pointer to the current element. |
Iterator * | self()<br>CRTP self pointer (pointer to the derived type) |
const Iterator * | self() const<br>CRTP const self pointer. |
std::shared_ptr< Value > | sharedPtr() const<br>Return the owning pointer to the current element. Creates a new shared pointer object. |
bool | valid() const<br>Check whether the iterator is pointing at a valid element (eg. not the end of a container) |
Friends inherited from DIWNE::ForwardIteratorBase< Iterator, NodeType, IsConst >
Name | |
---|---|
bool | operator!=(const Iterator & a, const Iterator & b) |
bool | operator==(const Iterator & a, const Iterator & b) |
Detailed Description
template <typename NodeType =Node>
class DIWNE::FilteredNodeIterator;
template <typename NodeType =Node>
class DIWNE::FilteredNodeIterator;
Public Types Documentation
using shared_pointer
using DIWNE::FilteredNodeIterator< NodeType >::shared_pointer = typename Super::shared_pointer;
using DIWNE::FilteredNodeIterator< NodeType >::shared_pointer = typename Super::shared_pointer;
Protected Types Documentation
using Super
using DIWNE::FilteredNodeIterator< NodeType >::Super = FilteredNodeIteratorImpl<FilteredNodeIterator<NodeType>, NodeType, false>;
using DIWNE::FilteredNodeIterator< NodeType >::Super = FilteredNodeIteratorImpl<FilteredNodeIterator<NodeType>, NodeType, false>;
Public Functions Documentation
function FilteredNodeIterator
inline FilteredNodeIterator()
inline FilteredNodeIterator()
function FilteredNodeIterator
inline FilteredNodeIterator(
typename Super::Predicate predicate,
typename Super::Container nodes,
std::size_t idx
)
inline FilteredNodeIterator(
typename Super::Predicate predicate,
typename Super::Container nodes,
std::size_t idx
)
Updated on 2025-05-31 at 12:55:31 +0000