libstdc++
__gnu_pbds::detail::pat_trie_base::_Node_iter< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc > Class Template Reference
Inheritance diagram for __gnu_pbds::detail::pat_trie_base::_Node_iter< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >:
[legend]

Public Types

typedef _Alloc::template rebind< metadata_type__rebind_m
 
typedef __rebind_m::other __rebind_ma
 
typedef value_type const_reference
 
typedef trivial_iterator_difference_type difference_type
 
typedef trivial_iterator_tag iterator_category
 
typedef __rebind_ma::const_reference metadata_const_reference
 
typedef Node::metadata_type metadata_type
 
typedef value_type reference
 
typedef base_type::size_type size_type
 
typedef Iterator value_type
 

Public Member Functions

 _Node_iter (node_pointer p_nd=0, a_const_pointer p_traits=0)
 
_Node_iter get_child (size_type i) const
 
metadata_const_reference get_metadata () const
 
size_type num_children () const
 
bool operator!= (const _Node_citer &other) const
 
reference operator* () const
 
bool operator== (const _Node_citer &other) const
 
std::pair< a_const_iterator, a_const_iterator > valid_prefix () const
 

Public Attributes

node_pointer m_p_nd
 
a_const_pointer m_p_traits
 

Protected Types

typedef _Alloc::template rebind< Inode > __rebind_in
 
typedef _Alloc::template rebind< Leaf > __rebind_l
 
typedef Node::a_const_iterator a_const_iterator
 
typedef __rebind_in::other::const_pointer inode_const_pointer
 
typedef __rebind_l::other::const_pointer leaf_const_pointer
 
typedef __rebind_l::other::pointer leaf_pointer
 

Detailed Description

template<typename Node, typename Leaf, typename Head, typename Inode, typename _CIterator, typename Iterator, typename _Alloc>
class __gnu_pbds::detail::pat_trie_base::_Node_iter< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >

Node iterator.

Definition at line 943 of file pat_trie_base.hpp.

Member Typedef Documentation

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
typedef _Alloc::template rebind<metadata_type> __gnu_pbds::detail::pat_trie_base::_Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::__rebind_m
inherited

Const metadata reference type.

Definition at line 869 of file pat_trie_base.hpp.

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
typedef Node::metadata_type __gnu_pbds::detail::pat_trie_base::_Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::metadata_type
inherited

Metadata type.

Definition at line 866 of file pat_trie_base.hpp.

Member Function Documentation

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
_Node_iter __gnu_pbds::detail::pat_trie_base::_Node_iter< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::get_child ( size_type  i) const
inline

Returns a node __iterator to the corresponding node's i-th child.

Definition at line 976 of file pat_trie_base.hpp.

References std::advance(), std::begin(), std::distance(), std::end(), and std::make_pair().

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
metadata_const_reference __gnu_pbds::detail::pat_trie_base::_Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::get_metadata ( ) const
inlineinherited

Metadata access.

Definition at line 894 of file pat_trie_base.hpp.

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
size_type __gnu_pbds::detail::pat_trie_base::_Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::num_children ( ) const
inlineinherited

Returns the number of children in the corresponding node.

Definition at line 899 of file pat_trie_base.hpp.

References std::distance().

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
bool __gnu_pbds::detail::pat_trie_base::_Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::operator!= ( const _Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc > &  other) const
inlineinherited

Compares content (negatively) to a different iterator object.

Definition at line 927 of file pat_trie_base.hpp.

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
reference __gnu_pbds::detail::pat_trie_base::_Node_iter< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::operator* ( ) const
inline

Access; returns the iterator* associated with the current leaf.

Definition at line 968 of file pat_trie_base.hpp.

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
bool __gnu_pbds::detail::pat_trie_base::_Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::operator== ( const _Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc > &  other) const
inlineinherited

Compares content to a different iterator object.

Definition at line 922 of file pat_trie_base.hpp.

template<typename Node , typename Leaf , typename Head , typename Inode , typename _CIterator , typename Iterator , typename _Alloc >
std::pair<a_const_iterator, a_const_iterator> __gnu_pbds::detail::pat_trie_base::_Node_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >::valid_prefix ( ) const
inlineinherited

Subtree valid prefix.

Definition at line 880 of file pat_trie_base.hpp.

References std::make_pair().


The documentation for this class was generated from the following file: