3Depict
|
Base class for iterators, only pointers stored, no traversal logic. More...
#include <tree.hh>
Public Types | |
typedef T | value_type |
typedef T * | pointer |
typedef T & | reference |
typedef size_t | size_type |
typedef ptrdiff_t | difference_type |
typedef std::bidirectional_iterator_tag | iterator_category |
Public Member Functions | |
iterator_base () | |
iterator_base (tree_node *) | |
T & | operator* () const |
T * | operator-> () const |
void | skip_children () |
When called, the next increment/decrement skips children of this node. More... | |
void | skip_children (bool skip) |
unsigned int | number_of_children () const |
Number of children of the node pointed to by the iterator. More... | |
sibling_iterator | begin () const |
sibling_iterator | end () const |
Public Attributes | |
tree_node * | node |
Protected Attributes | |
bool | skip_current_children_ |
Base class for iterators, only pointers stored, no traversal logic.
typedef ptrdiff_t tree< T, tree_node_allocator >::iterator_base::difference_type |
typedef std::bidirectional_iterator_tag tree< T, tree_node_allocator >::iterator_base::iterator_category |
typedef T* tree< T, tree_node_allocator >::iterator_base::pointer |
typedef T& tree< T, tree_node_allocator >::iterator_base::reference |
typedef size_t tree< T, tree_node_allocator >::iterator_base::size_type |
typedef T tree< T, tree_node_allocator >::iterator_base::value_type |
tree< T, tree_node_allocator >::iterator_base::iterator_base | ( | ) |
tree< T, tree_node_allocator >::iterator_base::iterator_base | ( | tree_node * | tn | ) |
tree< T, tree_node_allocator >::sibling_iterator tree< T, tree_node_allocator >::iterator_base::begin | ( | ) | const |
References tree< T, tree_node_allocator >::iterator_base::end(), tree_node_< T >::first_child, tree< T, tree_node_allocator >::iterator_base::node, and tree< T, tree_node_allocator >::sibling_iterator::parent_.
Referenced by FilterTree::getAccumulatedPropagationMaps(), tree< T, tree_node_allocator >::breadth_first_queued_iterator::operator++(), and FilterTree::respliceFilter().
tree< T, tree_node_allocator >::sibling_iterator tree< T, tree_node_allocator >::iterator_base::end | ( | ) | const |
References tree< T, tree_node_allocator >::iterator_base::node, and tree< T, tree_node_allocator >::sibling_iterator::parent_.
Referenced by tree< T, tree_node_allocator >::iterator_base::begin(), FilterTree::getAccumulatedPropagationMaps(), tree< T, tree_node_allocator >::breadth_first_queued_iterator::operator++(), and FilterTree::respliceFilter().
unsigned int tree< T, tree_node_allocator >::iterator_base::number_of_children | ( | ) | const |
Number of children of the node pointed to by the iterator.
References tree_node_< T >::first_child, tree_node_< T >::last_child, tree_node_< T >::next_sibling, and tree< T, tree_node_allocator >::iterator_base::node.
T & tree< T, tree_node_allocator >::iterator_base::operator* | ( | ) | const |
References tree_node_< T >::data, and tree< T, tree_node_allocator >::iterator_base::node.
T * tree< T, tree_node_allocator >::iterator_base::operator-> | ( | ) | const |
References tree_node_< T >::data, and tree< T, tree_node_allocator >::iterator_base::node.
void tree< T, tree_node_allocator >::iterator_base::skip_children | ( | ) |
When called, the next increment/decrement skips children of this node.
References tree< T, tree_node_allocator >::iterator_base::skip_current_children_.
Referenced by tree< T, tree_node_allocator >::post_order_iterator::post_order_iterator(), and tree< T, tree_node_allocator >::pre_order_iterator::pre_order_iterator().
void tree< T, tree_node_allocator >::iterator_base::skip_children | ( | bool | skip | ) |
tree_node* tree< T, tree_node_allocator >::iterator_base::node |
Referenced by tree< T, tree_node_allocator >::iterator_base::begin(), tree< Filter *>::begin_fixed(), tree< T, tree_node_allocator >::post_order_iterator::descend_all(), tree< T, tree_node_allocator >::iterator_base::end(), tree< T, tree_node_allocator >::leaf_iterator::leaf_iterator(), tree< T, tree_node_allocator >::iterator_base::number_of_children(), tree< T, tree_node_allocator >::pre_order_iterator::operator!=(), tree< T, tree_node_allocator >::post_order_iterator::operator!=(), tree< T, tree_node_allocator >::breadth_first_queued_iterator::operator!=(), tree< T, tree_node_allocator >::fixed_depth_iterator::operator!=(), tree< T, tree_node_allocator >::sibling_iterator::operator!=(), tree< T, tree_node_allocator >::leaf_iterator::operator!=(), tree< T, tree_node_allocator >::iterator_base_less::operator()(), tree< T, tree_node_allocator >::iterator_base::operator*(), tree< T, tree_node_allocator >::pre_order_iterator::operator++(), tree< T, tree_node_allocator >::post_order_iterator::operator++(), tree< T, tree_node_allocator >::breadth_first_queued_iterator::operator++(), tree< T, tree_node_allocator >::fixed_depth_iterator::operator++(), tree< T, tree_node_allocator >::sibling_iterator::operator++(), tree< T, tree_node_allocator >::leaf_iterator::operator++(), tree< T, tree_node_allocator >::pre_order_iterator::operator--(), tree< T, tree_node_allocator >::post_order_iterator::operator--(), tree< T, tree_node_allocator >::fixed_depth_iterator::operator--(), tree< T, tree_node_allocator >::sibling_iterator::operator--(), tree< T, tree_node_allocator >::leaf_iterator::operator--(), tree< T, tree_node_allocator >::iterator_base::operator->(), tree< T, tree_node_allocator >::pre_order_iterator::operator==(), tree< T, tree_node_allocator >::post_order_iterator::operator==(), tree< T, tree_node_allocator >::breadth_first_queued_iterator::operator==(), tree< T, tree_node_allocator >::fixed_depth_iterator::operator==(), tree< T, tree_node_allocator >::sibling_iterator::operator==(), tree< T, tree_node_allocator >::leaf_iterator::operator==(), tree< T, tree_node_allocator >::post_order_iterator::post_order_iterator(), tree< T, tree_node_allocator >::pre_order_iterator::pre_order_iterator(), and tree< T, tree_node_allocator >::sibling_iterator::sibling_iterator().
|
protected |