<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> <meta http-equiv="X-UA-Compatible" content="IE=9"/> <meta name="generator" content="Doxygen 1.8.13"/> <meta name="viewport" content="width=device-width, initial-scale=1"/> <title>libstdc++: __gnu_pbds::detail::trie_traits< Key, null_type, _ATraits, Node_Update, pat_trie_tag, _Alloc > Struct Template Reference</title> <link href="tabs.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="dynsections.js"></script> <link href="navtree.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="resize.js"></script> <script type="text/javascript" src="navtreedata.js"></script> <script type="text/javascript" src="navtree.js"></script> <script type="text/javascript"> $(document).ready(initResizable); </script> <link href="doxygen.css" rel="stylesheet" type="text/css" /> </head> <body> <div id="top"><!-- do not remove this div, it is closed by doxygen! --> <div id="titlearea"> <table cellspacing="0" cellpadding="0"> <tbody> <tr style="height: 56px;"> <td id="projectalign" style="padding-left: 0.5em;"> <div id="projectname">libstdc++ </div> </td> </tr> </tbody> </table> </div> <!-- end header part --> <!-- Generated by Doxygen 1.8.13 --> </div><!-- top --> <div id="side-nav" class="ui-resizable side-nav-resizable"> <div id="nav-tree"> <div id="nav-tree-contents"> <div id="nav-sync" class="sync"></div> </div> </div> <div id="splitbar" style="-moz-user-select:none;" class="ui-resizable-handle"> </div> </div> <script type="text/javascript"> $(document).ready(function(){initNavTree('a10625.html','');}); </script> <div id="doc-content"> <div class="header"> <div class="summary"> <a href="#pub-types">Public Types</a> | <a href="a10622.html">List of all members</a> </div> <div class="headertitle"> <div class="title">__gnu_pbds::detail::trie_traits< Key, null_type, _ATraits, Node_Update, pat_trie_tag, _Alloc > Struct Template Reference<div class="ingroups"><a class="el" href="a01410.html">Extensions</a> » <a class="el" href="a01475.html">Policy-Based Data Structures</a> » <a class="el" href="a01479.html">Traits</a></div></div> </div> </div><!--header--> <div class="contents"> <table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a> Public Types</h2></td></tr> <tr class="memitem:a5355de8d93b9db66c7da33dc034c838b"><td class="memItemLeft" align="right" valign="top"><a id="a5355de8d93b9db66c7da33dc034c838b"></a> typedef _ATraits </td><td class="memItemRight" valign="bottom"><b>access_traits</b></td></tr> <tr class="separator:a5355de8d93b9db66c7da33dc034c838b"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a66eda60d2e4bd21f7ced297138f7d8ec"><td class="memItemLeft" align="right" valign="top"><a id="a66eda60d2e4bd21f7ced297138f7d8ec"></a> typedef <a class="el" href="a10601.html">base_type::_CIter</a>< <a class="el" href="a10577.html">node</a>, <a class="el" href="a10585.html">leaf</a>, <a class="el" href="a10581.html">head</a>, <a class="el" href="a10589.html">inode</a>, true > </td><td class="memItemRight" valign="bottom"><b>const_iterator</b></td></tr> <tr class="separator:a66eda60d2e4bd21f7ced297138f7d8ec"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a469cdde3c2acbb752485967f5c618d0a"><td class="memItemLeft" align="right" valign="top"><a id="a469cdde3c2acbb752485967f5c618d0a"></a> typedef <a class="el" href="a10601.html">base_type::_CIter</a>< <a class="el" href="a10577.html">node</a>, <a class="el" href="a10585.html">leaf</a>, <a class="el" href="a10581.html">head</a>, <a class="el" href="a10589.html">inode</a>, false > </td><td class="memItemRight" valign="bottom"><b>const_reverse_iterator</b></td></tr> <tr class="separator:a469cdde3c2acbb752485967f5c618d0a"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:ab17845761ef4f376c1f7c1afbc67dc7f"><td class="memItemLeft" align="right" valign="top"><a id="ab17845761ef4f376c1f7c1afbc67dc7f"></a> typedef <a class="el" href="a10581.html">base_type::_Head</a>< <a class="el" href="a10625.html#a2ae24123cf94f809e6baf7cb21b97b3d">synth_access_traits</a>, <a class="el" href="a10569.html">metadata</a> > </td><td class="memItemRight" valign="bottom"><b>head</b></td></tr> <tr class="separator:ab17845761ef4f376c1f7c1afbc67dc7f"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:ad8dcf673dd01104fc8d3163b8423f429"><td class="memItemLeft" align="right" valign="top"><a id="ad8dcf673dd01104fc8d3163b8423f429"></a> typedef <a class="el" href="a10589.html">base_type::_Inode</a>< <a class="el" href="a10625.html#a2ae24123cf94f809e6baf7cb21b97b3d">synth_access_traits</a>, <a class="el" href="a10569.html">metadata</a> > </td><td class="memItemRight" valign="bottom"><b>inode</b></td></tr> <tr class="separator:ad8dcf673dd01104fc8d3163b8423f429"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:af593fd755666ddb62d8e0503c91fc09a"><td class="memItemLeft" align="right" valign="top"><a id="af593fd755666ddb62d8e0503c91fc09a"></a> typedef <a class="el" href="a10601.html">const_iterator</a> </td><td class="memItemRight" valign="bottom"><b>iterator</b></td></tr> <tr class="separator:af593fd755666ddb62d8e0503c91fc09a"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a6746456caa3744575a19bc44c20038a2"><td class="memItemLeft" align="right" valign="top"><a id="a6746456caa3744575a19bc44c20038a2"></a> typedef <a class="el" href="a10585.html">base_type::_Leaf</a>< <a class="el" href="a10625.html#a2ae24123cf94f809e6baf7cb21b97b3d">synth_access_traits</a>, <a class="el" href="a10569.html">metadata</a> > </td><td class="memItemRight" valign="bottom"><b>leaf</b></td></tr> <tr class="separator:a6746456caa3744575a19bc44c20038a2"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:af966dab6de6eb940705f6620ae9238aa"><td class="memItemLeft" align="right" valign="top"><a id="af966dab6de6eb940705f6620ae9238aa"></a> typedef <a class="el" href="a10569.html">base_type::_Metadata</a>< metadata_type, _Alloc > </td><td class="memItemRight" valign="bottom"><b>metadata</b></td></tr> <tr class="separator:af966dab6de6eb940705f6620ae9238aa"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:af33bb2111e77ca75cf0f4e502a0b911a"><td class="memItemLeft" align="right" valign="top"><a id="af33bb2111e77ca75cf0f4e502a0b911a"></a> typedef <a class="el" href="a10737.html">trie_node_metadata_dispatch</a>< Key, <a class="el" href="a09953.html">null_type</a>, _ATraits, Node_Update, _Alloc >::type </td><td class="memItemRight" valign="bottom"><b>metadata_type</b></td></tr> <tr class="separator:af33bb2111e77ca75cf0f4e502a0b911a"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:abf377633d118a17a0b459bde80919663"><td class="memItemLeft" align="right" valign="top"><a id="abf377633d118a17a0b459bde80919663"></a> typedef <a class="el" href="a10577.html">base_type::_Node_base</a>< <a class="el" href="a10625.html#a2ae24123cf94f809e6baf7cb21b97b3d">synth_access_traits</a>, <a class="el" href="a10569.html">metadata</a> > </td><td class="memItemRight" valign="bottom"><b>node</b></td></tr> <tr class="separator:abf377633d118a17a0b459bde80919663"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a6b9b24aec02d5b81b47bdad843750d4f"><td class="memItemLeft" align="right" valign="top">typedef <a class="el" href="a10609.html">base_type::_Node_citer</a>< <a class="el" href="a10577.html">node</a>, <a class="el" href="a10585.html">leaf</a>, <a class="el" href="a10581.html">head</a>, <a class="el" href="a10589.html">inode</a>, <a class="el" href="a10601.html">const_iterator</a>, <a class="el" href="a10601.html">iterator</a>, _Alloc > </td><td class="memItemRight" valign="bottom"><a class="el" href="a10625.html#a6b9b24aec02d5b81b47bdad843750d4f">node_const_iterator</a></td></tr> <tr class="separator:a6b9b24aec02d5b81b47bdad843750d4f"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:adc74cd4a0c9df21ce75835d83dba91c0"><td class="memItemLeft" align="right" valign="top"><a id="adc74cd4a0c9df21ce75835d83dba91c0"></a> typedef <a class="el" href="a10625.html#a6b9b24aec02d5b81b47bdad843750d4f">node_const_iterator</a> </td><td class="memItemRight" valign="bottom"><b>node_iterator</b></td></tr> <tr class="separator:adc74cd4a0c9df21ce75835d83dba91c0"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a19326cc52a16fcfc9afe45cdfbb100bd"><td class="memItemLeft" align="right" valign="top">typedef Node_Update< <a class="el" href="a10625.html#a6b9b24aec02d5b81b47bdad843750d4f">node_const_iterator</a>, <a class="el" href="a10609.html">node_iterator</a>, _ATraits, _Alloc > </td><td class="memItemRight" valign="bottom"><a class="el" href="a10625.html#a19326cc52a16fcfc9afe45cdfbb100bd">node_update</a></td></tr> <tr class="separator:a19326cc52a16fcfc9afe45cdfbb100bd"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:af3a4c0935a453a9dbb824bfd5f3c2402"><td class="memItemLeft" align="right" valign="top"><a id="af3a4c0935a453a9dbb824bfd5f3c2402"></a> typedef <a class="el" href="a09957.html">null_node_update</a>< <a class="el" href="a10625.html#a6b9b24aec02d5b81b47bdad843750d4f">node_const_iterator</a>, <a class="el" href="a10625.html#a6b9b24aec02d5b81b47bdad843750d4f">node_const_iterator</a>, _ATraits, _Alloc > * </td><td class="memItemRight" valign="bottom"><b>null_node_update_pointer</b></td></tr> <tr class="separator:af3a4c0935a453a9dbb824bfd5f3c2402"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a19eb30010b2063e6416a5dea1a3f0fde"><td class="memItemLeft" align="right" valign="top"><a id="a19eb30010b2063e6416a5dea1a3f0fde"></a> typedef <a class="el" href="a10601.html">const_reverse_iterator</a> </td><td class="memItemRight" valign="bottom"><b>reverse_iterator</b></td></tr> <tr class="separator:a19eb30010b2063e6416a5dea1a3f0fde"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a2ae24123cf94f809e6baf7cb21b97b3d"><td class="memItemLeft" align="right" valign="top">typedef <a class="el" href="a10617.html">__gnu_pbds::detail::synth_access_traits</a>< <a class="el" href="a10225.html">type_traits</a>, true, access_traits > </td><td class="memItemRight" valign="bottom"><a class="el" href="a10625.html#a2ae24123cf94f809e6baf7cb21b97b3d">synth_access_traits</a></td></tr> <tr class="separator:a2ae24123cf94f809e6baf7cb21b97b3d"><td class="memSeparator" colspan="2"> </td></tr> </table> <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> <div class="textblock"><h3>template<typename Key, typename _ATraits, template< typename Node_CItr, typename Node_Itr, typename Cmp_Fn_, typename _Alloc_ > class Node_Update, typename _Alloc><br /> struct __gnu_pbds::detail::trie_traits< Key, null_type, _ATraits, Node_Update, pat_trie_tag, _Alloc ></h3> <p>Specialization. </p> <p class="definition">Definition at line <a class="el" href="a15391_source.html#l00109">109</a> of file <a class="el" href="a15391_source.html">pat_trie_/traits.hpp</a>.</p> </div><h2 class="groupheader">Member Typedef Documentation</h2> <a id="a6b9b24aec02d5b81b47bdad843750d4f"></a> <h2 class="memtitle"><span class="permalink"><a href="#a6b9b24aec02d5b81b47bdad843750d4f">◆ </a></span>node_const_iterator</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename Key , typename _ATraits , template< typename Node_CItr, typename Node_Itr, typename Cmp_Fn_, typename _Alloc_ > class Node_Update, typename _Alloc > </div> <table class="memname"> <tr> <td class="memname">typedef <a class="el" href="a10609.html">base_type::_Node_citer</a><<a class="el" href="a10577.html">node</a>, <a class="el" href="a10585.html">leaf</a>, <a class="el" href="a10581.html">head</a>, <a class="el" href="a10589.html">inode</a>, <a class="el" href="a10601.html">const_iterator</a>, <a class="el" href="a10601.html">iterator</a>, _Alloc> <a class="el" href="a10329.html">__gnu_pbds::detail::trie_traits</a>< Key, <a class="el" href="a09953.html">null_type</a>, _ATraits, Node_Update, <a class="el" href="a09921.html">pat_trie_tag</a>, _Alloc >::<a class="el" href="a10625.html#a6b9b24aec02d5b81b47bdad843750d4f">node_const_iterator</a></td> </tr> </table> </div><div class="memdoc"> <p>This is an iterator to an iterator: it iterates over nodes, and de-referencing it returns one of the tree's iterators. </p> <p class="definition">Definition at line <a class="el" href="a15391_source.html#l00135">135</a> of file <a class="el" href="a15391_source.html">pat_trie_/traits.hpp</a>.</p> </div> </div> <a id="a19326cc52a16fcfc9afe45cdfbb100bd"></a> <h2 class="memtitle"><span class="permalink"><a href="#a19326cc52a16fcfc9afe45cdfbb100bd">◆ </a></span>node_update</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename Key , typename _ATraits , template< typename Node_CItr, typename Node_Itr, typename Cmp_Fn_, typename _Alloc_ > class Node_Update, typename _Alloc > </div> <table class="memname"> <tr> <td class="memname">typedef Node_Update<<a class="el" href="a10625.html#a6b9b24aec02d5b81b47bdad843750d4f">node_const_iterator</a>, <a class="el" href="a10609.html">node_iterator</a>, _ATraits, _Alloc> <a class="el" href="a10329.html">__gnu_pbds::detail::trie_traits</a>< Key, <a class="el" href="a09953.html">null_type</a>, _ATraits, Node_Update, <a class="el" href="a09921.html">pat_trie_tag</a>, _Alloc >::<a class="el" href="a10625.html#a19326cc52a16fcfc9afe45cdfbb100bd">node_update</a></td> </tr> </table> </div><div class="memdoc"> <p>Type for node update. </p> <p class="definition">Definition at line <a class="el" href="a15391_source.html#l00140">140</a> of file <a class="el" href="a15391_source.html">pat_trie_/traits.hpp</a>.</p> </div> </div> <a id="a2ae24123cf94f809e6baf7cb21b97b3d"></a> <h2 class="memtitle"><span class="permalink"><a href="#a2ae24123cf94f809e6baf7cb21b97b3d">◆ </a></span>synth_access_traits</h2> <div class="memitem"> <div class="memproto"> <div class="memtemplate"> template<typename Key , typename _ATraits , template< typename Node_CItr, typename Node_Itr, typename Cmp_Fn_, typename _Alloc_ > class Node_Update, typename _Alloc > </div> <table class="memname"> <tr> <td class="memname">typedef <a class="el" href="a10617.html">__gnu_pbds::detail::synth_access_traits</a><<a class="el" href="a10225.html">type_traits</a>, true, access_traits> <a class="el" href="a10329.html">__gnu_pbds::detail::trie_traits</a>< Key, <a class="el" href="a09953.html">null_type</a>, _ATraits, Node_Update, <a class="el" href="a09921.html">pat_trie_tag</a>, _Alloc >::<a class="el" href="a10625.html#a2ae24123cf94f809e6baf7cb21b97b3d">synth_access_traits</a></td> </tr> </table> </div><div class="memdoc"> <p>Type for synthesized traits. </p> <p class="definition">Definition at line <a class="el" href="a15391_source.html#l00121">121</a> of file <a class="el" href="a15391_source.html">pat_trie_/traits.hpp</a>.</p> </div> </div> <hr/>The documentation for this struct was generated from the following file:<ul> <li><a class="el" href="a15391_source.html">pat_trie_/traits.hpp</a></li> </ul> </div><!-- contents --> </div><!-- doc-content --> <!-- start footer part --> <div id="nav-path" class="navpath"><!-- id is needed for treeview function! --> <ul> <li class="navelem"><a class="el" href="a01535.html">__gnu_pbds</a></li><li class="navelem"><b>detail</b></li><li class="navelem"><a class="el" href="a10625.html">trie_traits< Key, null_type, _ATraits, Node_Update, pat_trie_tag, _Alloc ></a></li> <li class="footer">Generated by <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.13 </li> </ul> </div> </body> </html>