Sophie

Sophie

distrib > Fedora > 18 > x86_64 > by-pkgid > ae3ac0f3c84b68877416000d08e53ca8 > files > 244

libicu-doc-49.1.1-12.fc18.noarch.rpm

<!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.3.1"/>
<title>ICU 49.1.1: StringTrieBuilder::Node Class 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="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 style="padding-left: 0.5em;">
   <div id="projectname">ICU 49.1.1
   &#160;<span id="projectnumber">49.1.1</span>
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.3.1 -->
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
      <li class="current"><a href="annotated.html"><span>Data&#160;Structures</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="annotated.html"><span>Data&#160;Structures</span></a></li>
      <li><a href="classes.html"><span>Data&#160;Structure&#160;Index</span></a></li>
      <li><a href="hierarchy.html"><span>Class&#160;Hierarchy</span></a></li>
      <li><a href="functions.html"><span>Data&#160;Fields</span></a></li>
    </ul>
  </div>
<div id="nav-path" class="navpath">
  <ul>
<li class="navelem"><a class="el" href="classStringTrieBuilder.html">StringTrieBuilder</a></li><li class="navelem"><a class="el" href="classStringTrieBuilder_1_1Node.html">Node</a></li>  </ul>
</div>
</div><!-- top -->
<div class="header">
  <div class="summary">
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="#pub-static-methods">Static Public Member Functions</a> &#124;
<a href="#pro-attribs">Protected Attributes</a>  </div>
  <div class="headertitle">
<div class="title">StringTrieBuilder::Node Class Reference<span class="mlabels"><span class="mlabel">abstract</span></span></div>  </div>
</div><!--header-->
<div class="contents">

<p><code>#include &lt;<a class="el" href="stringtriebuilder_8h_source.html">stringtriebuilder.h</a>&gt;</code></p>
<div class="dynheader">
Inheritance diagram for StringTrieBuilder::Node:</div>
<div class="dyncontent">
 <div class="center">
  <img src="classStringTrieBuilder_1_1Node.png" usemap="#StringTrieBuilder::Node_map" alt=""/>
  <map id="StringTrieBuilder::Node_map" name="StringTrieBuilder::Node_map">
<area href="classUObject.html" title="UObject is the common ICU &quot;boilerplate&quot; class." alt="UObject" shape="rect" coords="381,56,625,80"/>
<area href="classUMemory.html" title="UMemory is the common ICU base class." alt="UMemory" shape="rect" coords="381,0,625,24"/>
<area href="classStringTrieBuilder_1_1BranchNode.html" alt="StringTrieBuilder::BranchNode" shape="rect" coords="127,168,371,192"/>
<area href="classStringTrieBuilder_1_1FinalValueNode.html" alt="StringTrieBuilder::FinalValueNode" shape="rect" coords="381,168,625,192"/>
<area href="classStringTrieBuilder_1_1ValueNode.html" alt="StringTrieBuilder::ValueNode" shape="rect" coords="762,168,1006,192"/>
<area href="classStringTrieBuilder_1_1ListBranchNode.html" alt="StringTrieBuilder::ListBranchNode" shape="rect" coords="0,224,244,248"/>
<area href="classStringTrieBuilder_1_1SplitBranchNode.html" alt="StringTrieBuilder::SplitBranchNode" shape="rect" coords="254,224,498,248"/>
<area href="classStringTrieBuilder_1_1BranchHeadNode.html" alt="StringTrieBuilder::BranchHeadNode" shape="rect" coords="508,224,752,248"/>
<area href="classStringTrieBuilder_1_1IntermediateValueNode.html" alt="StringTrieBuilder::IntermediateValueNode" shape="rect" coords="762,224,1006,248"/>
<area href="classStringTrieBuilder_1_1LinearMatchNode.html" alt="StringTrieBuilder::LinearMatchNode" shape="rect" coords="1016,224,1260,248"/>
</map>
 </div></div>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr class="memitem:adccd346893ef1b72e5847f988bdc885f"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="adccd346893ef1b72e5847f988bdc885f"></a>
&#160;</td><td class="memItemRight" valign="bottom"><b>Node</b> (int32_t initialHash)</td></tr>
<tr class="separator:adccd346893ef1b72e5847f988bdc885f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad039a9ade764d8b128c2f8e75254f2ec"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ad039a9ade764d8b128c2f8e75254f2ec"></a>
int32_t&#160;</td><td class="memItemRight" valign="bottom"><b>hashCode</b> () const </td></tr>
<tr class="separator:ad039a9ade764d8b128c2f8e75254f2ec"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1797222a8ea26494b314733a140c38fe"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a1797222a8ea26494b314733a140c38fe"></a>
virtual <a class="el" href="umachine_8h.html#a349ef00011f20ccd1d3b424445681aa5">UBool</a>&#160;</td><td class="memItemRight" valign="bottom"><b>operator==</b> (const <a class="el" href="classStringTrieBuilder_1_1Node.html">Node</a> &amp;other) const </td></tr>
<tr class="separator:a1797222a8ea26494b314733a140c38fe"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa6a49f2817ebeeb4d256fce177f1a27a"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa6a49f2817ebeeb4d256fce177f1a27a"></a>
<a class="el" href="umachine_8h.html#a349ef00011f20ccd1d3b424445681aa5">UBool</a>&#160;</td><td class="memItemRight" valign="bottom"><b>operator!=</b> (const <a class="el" href="classStringTrieBuilder_1_1Node.html">Node</a> &amp;other) const </td></tr>
<tr class="separator:aa6a49f2817ebeeb4d256fce177f1a27a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af78a4a35580b5b6790bb36aaf3d5dcb4"><td class="memItemLeft" align="right" valign="top">virtual int32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classStringTrieBuilder_1_1Node.html#af78a4a35580b5b6790bb36aaf3d5dcb4">markRightEdgesFirst</a> (int32_t edgeNumber)</td></tr>
<tr class="memdesc:af78a4a35580b5b6790bb36aaf3d5dcb4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Traverses the <a class="el" href="classStringTrieBuilder_1_1Node.html">Node</a> graph and numbers branch edges, with rightmost edges first.  <a href="#af78a4a35580b5b6790bb36aaf3d5dcb4">More...</a><br/></td></tr>
<tr class="separator:af78a4a35580b5b6790bb36aaf3d5dcb4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa2be870c3196c2d3a26747fdd68f8650"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa2be870c3196c2d3a26747fdd68f8650"></a>
virtual void&#160;</td><td class="memItemRight" valign="bottom"><b>write</b> (<a class="el" href="classStringTrieBuilder.html">StringTrieBuilder</a> &amp;builder)=0</td></tr>
<tr class="separator:aa2be870c3196c2d3a26747fdd68f8650"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aab15b0acdcc1ec21fed9f704f0fa791e"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aab15b0acdcc1ec21fed9f704f0fa791e"></a>
void&#160;</td><td class="memItemRight" valign="bottom"><b>writeUnlessInsideRightEdge</b> (int32_t firstRight, int32_t lastRight, <a class="el" href="classStringTrieBuilder.html">StringTrieBuilder</a> &amp;builder)</td></tr>
<tr class="separator:aab15b0acdcc1ec21fed9f704f0fa791e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab4a16694fb6383f096c6c3bd0f6681e5"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ab4a16694fb6383f096c6c3bd0f6681e5"></a>
int32_t&#160;</td><td class="memItemRight" valign="bottom"><b>getOffset</b> () const </td></tr>
<tr class="separator:ab4a16694fb6383f096c6c3bd0f6681e5"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_classUObject"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_classUObject')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="classUObject.html">UObject</a></td></tr>
<tr class="memitem:ace22cf29a90641ef43350deae5bedb85 inherit pub_methods_classUObject"><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classUObject.html#ace22cf29a90641ef43350deae5bedb85">~UObject</a> ()</td></tr>
<tr class="memdesc:ace22cf29a90641ef43350deae5bedb85 inherit pub_methods_classUObject"><td class="mdescLeft">&#160;</td><td class="mdescRight">Destructor.  <a href="#ace22cf29a90641ef43350deae5bedb85">More...</a><br/></td></tr>
<tr class="separator:ace22cf29a90641ef43350deae5bedb85 inherit pub_methods_classUObject"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
Static Public Member Functions</h2></td></tr>
<tr class="memitem:a3859b781ac5ae8239f4daa74e0e46989"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a3859b781ac5ae8239f4daa74e0e46989"></a>
static int32_t&#160;</td><td class="memItemRight" valign="bottom"><b>hashCode</b> (const <a class="el" href="classStringTrieBuilder_1_1Node.html">Node</a> *node)</td></tr>
<tr class="separator:a3859b781ac5ae8239f4daa74e0e46989"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-attribs"></a>
Protected Attributes</h2></td></tr>
<tr class="memitem:aa1d3d4154d0cd9018148022d151179fb"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa1d3d4154d0cd9018148022d151179fb"></a>
int32_t&#160;</td><td class="memItemRight" valign="bottom"><b>hash</b></td></tr>
<tr class="separator:aa1d3d4154d0cd9018148022d151179fb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a366e2c3b5e1e93fea0dfa683c8b0f063"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a366e2c3b5e1e93fea0dfa683c8b0f063"></a>
int32_t&#160;</td><td class="memItemRight" valign="bottom"><b>offset</b></td></tr>
<tr class="separator:a366e2c3b5e1e93fea0dfa683c8b0f063"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><dl class="internal"><dt><b><a class="el" href="internal.html#_internal000122">Internal:</a></b></dt><dd>Do not use. This API is for internal use only. </dd></dl>

<p>Definition at line <a class="el" href="stringtriebuilder_8h_source.html#l00182">182</a> of file <a class="el" href="stringtriebuilder_8h_source.html">stringtriebuilder.h</a>.</p>
</div><h2 class="groupheader">Member Function Documentation</h2>
<a class="anchor" id="af78a4a35580b5b6790bb36aaf3d5dcb4"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">virtual int32_t StringTrieBuilder::Node::markRightEdgesFirst </td>
          <td>(</td>
          <td class="paramtype">int32_t&#160;</td>
          <td class="paramname"><em>edgeNumber</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Traverses the <a class="el" href="classStringTrieBuilder_1_1Node.html">Node</a> graph and numbers branch edges, with rightmost edges first. </p>
<p>This is to avoid writing a duplicate node twice.</p>
<p>Branch nodes in this trie data structure are not symmetric. Most branch edges "jump" to other nodes but the rightmost branch edges just continue without a jump. Therefore, write() must write the rightmost branch edge last (trie units are written backwards), and must write it at that point even if it is a duplicate of a node previously written elsewhere.</p>
<p>This function visits and marks right branch edges first. Edges are numbered with increasingly negative values because we share the offset field which gets positive values when nodes are written. A branch edge also remembers the first number for any of its edges.</p>
<p>When a further-left branch edge has a number in the range of the rightmost edge's numbers, then it will be written as part of the required right edge and we can avoid writing it first.</p>
<p>After root.markRightEdgesFirst(-1) the offsets of all nodes are negative edge numbers.</p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">edgeNumber</td><td>The first edge number for this node and its sub-nodes. </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>An edge number that is at least the maximum-negative of the input edge number and the numbers of this node and all of its sub-nodes. </dd></dl>

<p>Reimplemented in <a class="el" href="classStringTrieBuilder_1_1BranchHeadNode.html#addd8d30c2a635558d6f61a09c22b7fa0">StringTrieBuilder::BranchHeadNode</a>, <a class="el" href="classStringTrieBuilder_1_1SplitBranchNode.html#ab50502af618b9c48d0021c979c542225">StringTrieBuilder::SplitBranchNode</a>, <a class="el" href="classStringTrieBuilder_1_1ListBranchNode.html#aadb843d80c7f0587e961b68539c91fb1">StringTrieBuilder::ListBranchNode</a>, <a class="el" href="classStringTrieBuilder_1_1LinearMatchNode.html#a7822a1fb7a78782fe5ae8309d14b9fe2">StringTrieBuilder::LinearMatchNode</a>, and <a class="el" href="classStringTrieBuilder_1_1IntermediateValueNode.html#a3223e369a9b334d636924ae4e44ba6f9">StringTrieBuilder::IntermediateValueNode</a>.</p>

</div>
</div>
<hr/>The documentation for this class was generated from the following file:<ul>
<li><a class="el" href="stringtriebuilder_8h_source.html">stringtriebuilder.h</a></li>
</ul>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.3.1
</small></address>
</body>
</html>