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

Public Types

typedef value_type const_reference
 
typedef trivial_iterator_difference_type difference_type
 
typedef trivial_iterator_tag iterator_category
 
typedef rebind_traits< _Alloc, metadata_type >::const_reference metadata_const_reference
 
typedef Node::metadata_type metadata_type
 
typedef value_type reference
 
typedef _Alloc::size_type size_type
 
typedef _CIterator value_type
 

Public Member Functions

 _Node_citer (node_pointer p_nd=0, a_const_pointer p_traits=0)
 
_Node_citer get_child (size_type i) const
 
metadata_const_reference get_metadata () const
 
size_type num_children () const
 
bool operator!= (const _Node_citer &other) const
 
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 Node::a_const_iterator a_const_iterator
 
typedef Node::a_const_pointer a_const_pointer
 
typedef rebind_traits< _Alloc, Inode >::const_pointer inode_const_pointer
 
typedef rebind_traits< _Alloc, Inode >::pointer inode_pointer
 
typedef rebind_traits< _Alloc, Leaf >::const_pointer leaf_const_pointer
 
typedef rebind_traits< _Alloc, Leaf >::pointer leaf_pointer
 
typedef rebind_traits< _Alloc, Node >::pointer node_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_citer< Node, Leaf, Head, Inode, _CIterator, Iterator, _Alloc >

Node const iterator.

Definition at line 810 of file pat_trie_base.hpp.

Member Typedef Documentation

◆ metadata_const_reference

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

Const metadata reference type.

Definition at line 862 of file pat_trie_base.hpp.

◆ metadata_type

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

Metadata type.

Definition at line 859 of file pat_trie_base.hpp.

Member Function Documentation

◆ get_child()

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

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

Definition at line 902 of file pat_trie_base.hpp.

◆ get_metadata()

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
inline

Metadata access.

Definition at line 885 of file pat_trie_base.hpp.

◆ num_children()

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
inline

Returns the number of children in the corresponding node.

Definition at line 890 of file pat_trie_base.hpp.

◆ operator!=()

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
inline

Compares content (negatively) to a different iterator object.

Definition at line 918 of file pat_trie_base.hpp.

◆ operator*()

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

Const access; returns the __const iterator* associated with the current leaf.

Definition at line 877 of file pat_trie_base.hpp.

◆ operator==()

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
inline

Compares content to a different iterator object.

Definition at line 913 of file pat_trie_base.hpp.

◆ valid_prefix()

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
inline

Subtree valid prefix.

Definition at line 871 of file pat_trie_base.hpp.


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