Current File : //opt/RZruby/share/doc/ruby/html/d4/d71/st_8c_source.html
<!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.5"/>
<title>Ruby: st.c Source File</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">Ruby
   &#160;<span id="projectnumber">1.9.3p551(2014-11-13revision48407)</span>
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.5 -->
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="../../index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="../../modules.html"><span>Modules</span></a></li>
      <li><a href="../../annotated.html"><span>Data&#160;Structures</span></a></li>
      <li class="current"><a href="../../files.html"><span>Files</span></a></li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="../../files.html"><span>File&#160;List</span></a></li>
      <li><a href="../../globals.html"><span>Globals</span></a></li>
    </ul>
  </div>
</div><!-- top -->
<div class="header">
  <div class="headertitle">
<div class="title">st.c</div>  </div>
</div><!--header-->
<div class="contents">
<a href="../../d4/d71/st_8c.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;<span class="comment">/* This is a public domain general purpose hash table package written by Peter Moore @ UCB. */</span></div>
<div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;</div>
<div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;<span class="comment">/* static       char    sccsid[] = &quot;@(#) st.c 5.1 89/12/14 Crucible&quot;; */</span></div>
<div class="line"><a name="l00004"></a><span class="lineno">    4</span>&#160;</div>
<div class="line"><a name="l00005"></a><span class="lineno">    5</span>&#160;<span class="preprocessor">#ifdef NOT_RUBY</span></div>
<div class="line"><a name="l00006"></a><span class="lineno">    6</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &quot;<a class="code" href="../../d6/d87/regint_8h.html">regint.h</a>&quot;</span></div>
<div class="line"><a name="l00007"></a><span class="lineno">    7</span>&#160;<span class="preprocessor">#include &quot;st.h&quot;</span></div>
<div class="line"><a name="l00008"></a><span class="lineno">    8</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l00009"></a><span class="lineno">    9</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &quot;<a class="code" href="../../de/de6/ruby_2ruby_8h.html">ruby/ruby.h</a>&quot;</span></div>
<div class="line"><a name="l00010"></a><span class="lineno">   10</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00011"></a><span class="lineno">   11</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;<span class="preprocessor">#include &lt;stdio.h&gt;</span></div>
<div class="line"><a name="l00013"></a><span class="lineno">   13</span>&#160;<span class="preprocessor">#ifdef HAVE_STDLIB_H</span></div>
<div class="line"><a name="l00014"></a><span class="lineno">   14</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &lt;stdlib.h&gt;</span></div>
<div class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00016"></a><span class="lineno">   16</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &lt;string.h&gt;</span></div>
<div class="line"><a name="l00017"></a><span class="lineno">   17</span>&#160;</div>
<div class="line"><a name="l00018"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4bafc81982b39c3f3fa20e5f7b3dbbf5">   18</a></span>&#160;<span class="keyword">typedef</span> <span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>;</div>
<div class="line"><a name="l00019"></a><span class="lineno">   19</span>&#160;</div>
<div class="line"><a name="l00020"></a><span class="lineno"><a class="line" href="../../df/dfb/structst__table__entry.html">   20</a></span>&#160;<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> {</div>
<div class="line"><a name="l00021"></a><span class="lineno"><a class="line" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">   21</a></span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a>;</div>
<div class="line"><a name="l00022"></a><span class="lineno"><a class="line" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">   22</a></span>&#160;    <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div>
<div class="line"><a name="l00023"></a><span class="lineno"><a class="line" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">   23</a></span>&#160;    <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>;</div>
<div class="line"><a name="l00024"></a><span class="lineno"><a class="line" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">   24</a></span>&#160;    <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div>
<div class="line"><a name="l00025"></a><span class="lineno"><a class="line" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">   25</a></span>&#160;    <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>, *<a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div>
<div class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;};</div>
<div class="line"><a name="l00027"></a><span class="lineno">   27</span>&#160;</div>
<div class="line"><a name="l00028"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4f884be75490db2c92e409a0209fdbcb">   28</a></span>&#160;<span class="preprocessor">#define ST_DEFAULT_MAX_DENSITY 5</span></div>
<div class="line"><a name="l00029"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a311df13f4d458054df7d87ca22782ab2">   29</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define ST_DEFAULT_INIT_TABLE_SIZE 11</span></div>
<div class="line"><a name="l00030"></a><span class="lineno">   30</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00031"></a><span class="lineno">   31</span>&#160;    <span class="comment">/*</span></div>
<div class="line"><a name="l00032"></a><span class="lineno">   32</span>&#160;<span class="comment">     * DEFAULT_MAX_DENSITY is the default for the largest we allow the</span></div>
<div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;<span class="comment">     * average number of items per bin before increasing the number of</span></div>
<div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;<span class="comment">     * bins</span></div>
<div class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span class="comment">     *</span></div>
<div class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;<span class="comment">     * DEFAULT_INIT_TABLE_SIZE is the default for the number of bins</span></div>
<div class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;<span class="comment">     * allocated initially</span></div>
<div class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;<span class="comment">     *</span></div>
<div class="line"><a name="l00039"></a><span class="lineno">   39</span>&#160;<span class="comment">     */</span></div>
<div class="line"><a name="l00040"></a><span class="lineno">   40</span>&#160;</div>
<div class="line"><a name="l00041"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab3e563ba13f240493c3b964db47c91d9">   41</a></span>&#160;<span class="keyword">static</span> <span class="keyword">const</span> <span class="keyword">struct </span><a class="code" href="../../d6/d34/structst__hash__type.html">st_hash_type</a> <a class="code" href="../../d4/d71/st_8c.html#ab3e563ba13f240493c3b964db47c91d9">type_numhash</a> = {</div>
<div class="line"><a name="l00042"></a><span class="lineno">   42</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#a2839ae91d54936af83392d0df9f97488">st_numcmp</a>,</div>
<div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#a50249b52a70e7a4aa8ca8582c380cd26">st_numhash</a>,</div>
<div class="line"><a name="l00044"></a><span class="lineno">   44</span>&#160;};</div>
<div class="line"><a name="l00045"></a><span class="lineno">   45</span>&#160;</div>
<div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;<span class="comment">/* extern int strcmp(const char *, const char *); */</span></div>
<div class="line"><a name="l00047"></a><span class="lineno">   47</span>&#160;<span class="keyword">static</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7">strhash</a>(<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>);</div>
<div class="line"><a name="l00048"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#acfaf774315212a7f26b139e77e62f75d">   48</a></span>&#160;<span class="keyword">static</span> <span class="keyword">const</span> <span class="keyword">struct </span><a class="code" href="../../d6/d34/structst__hash__type.html">st_hash_type</a> <a class="code" href="../../d4/d71/st_8c.html#acfaf774315212a7f26b139e77e62f75d">type_strhash</a> = {</div>
<div class="line"><a name="l00049"></a><span class="lineno">   49</span>&#160;    strcmp,</div>
<div class="line"><a name="l00050"></a><span class="lineno">   50</span>&#160;    <a class="code" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7">strhash</a>,</div>
<div class="line"><a name="l00051"></a><span class="lineno">   51</span>&#160;};</div>
<div class="line"><a name="l00052"></a><span class="lineno">   52</span>&#160;</div>
<div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;<span class="keyword">static</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48">strcasehash</a>(<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>);</div>
<div class="line"><a name="l00054"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a91069e070d6e0fbc1ff1145127c29742">   54</a></span>&#160;<span class="keyword">static</span> <span class="keyword">const</span> <span class="keyword">struct </span><a class="code" href="../../d6/d34/structst__hash__type.html">st_hash_type</a> <a class="code" href="../../d4/d71/st_8c.html#a91069e070d6e0fbc1ff1145127c29742">type_strcasehash</a> = {</div>
<div class="line"><a name="l00055"></a><span class="lineno">   55</span>&#160;    <a class="code" href="../../de/de6/ruby_2ruby_8h.html#aa34004564b66661c5c2f6d396e567e93">st_strcasecmp</a>,</div>
<div class="line"><a name="l00056"></a><span class="lineno">   56</span>&#160;    <a class="code" href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48">strcasehash</a>,</div>
<div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;};</div>
<div class="line"><a name="l00058"></a><span class="lineno">   58</span>&#160;</div>
<div class="line"><a name="l00059"></a><span class="lineno">   59</span>&#160;<span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="../../d4/d71/st_8c.html#ae79a2e19d2287b6ac8d9a82f5c423a1c">rehash</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *);</div>
<div class="line"><a name="l00060"></a><span class="lineno">   60</span>&#160;</div>
<div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;<span class="preprocessor">#ifdef RUBY</span></div>
<div class="line"><a name="l00062"></a><span class="lineno">   62</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define malloc xmalloc</span></div>
<div class="line"><a name="l00063"></a><span class="lineno">   63</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define calloc xcalloc</span></div>
<div class="line"><a name="l00064"></a><span class="lineno">   64</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define free(x) xfree(x)</span></div>
<div class="line"><a name="l00065"></a><span class="lineno">   65</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00066"></a><span class="lineno">   66</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00067"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4ac8fee05a285361c33a2b0d9c2d555c">   67</a></span>&#160;<span class="preprocessor">#define numberof(array) (int)(sizeof(array) / sizeof((array)[0]))</span></div>
<div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00069"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a385b96996caa48e6349681cf8036322f">   69</a></span>&#160;<span class="preprocessor">#define alloc(type) (type*)malloc((size_t)sizeof(type))</span></div>
<div class="line"><a name="l00070"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a94c395161bf80ffa3b1d224ad3542f11">   70</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define Calloc(n,s) (char*)calloc((n),(s))</span></div>
<div class="line"><a name="l00071"></a><span class="lineno">   71</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00072"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867">   72</a></span>&#160;<span class="preprocessor">#define EQUAL(table,x,y) ((x)==(y) || (*(table)-&gt;type-&gt;compare)((x),(y)) == 0)</span></div>
<div class="line"><a name="l00073"></a><span class="lineno">   73</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00074"></a><span class="lineno">   74</span>&#160;<span class="comment">/* remove cast to unsigned int in the future */</span></div>
<div class="line"><a name="l00075"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">   75</a></span>&#160;<span class="preprocessor">#define do_hash(key,table) (unsigned int)(st_index_t)(*(table)-&gt;type-&gt;hash)((key))</span></div>
<div class="line"><a name="l00076"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a2e66e2285d7393eca0aea2eac98b8ded">   76</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define do_hash_bin(key,table) (do_hash((key), (table))%(table)-&gt;num_bins)</span></div>
<div class="line"><a name="l00077"></a><span class="lineno">   77</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00078"></a><span class="lineno">   78</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00079"></a><span class="lineno">   79</span>&#160;<span class="comment"> * MINSIZE is the minimum size of a dictionary.</span></div>
<div class="line"><a name="l00080"></a><span class="lineno">   80</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l00081"></a><span class="lineno">   81</span>&#160;</div>
<div class="line"><a name="l00082"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a76ace81cc961cbcdba26190bcd706326">   82</a></span>&#160;<span class="preprocessor">#define MINSIZE 8</span></div>
<div class="line"><a name="l00083"></a><span class="lineno">   83</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00085"></a><span class="lineno">   85</span>&#160;<span class="comment">Table of prime numbers 2^n+a, 2&lt;=n&lt;=30.</span></div>
<div class="line"><a name="l00086"></a><span class="lineno">   86</span>&#160;<span class="comment">*/</span></div>
<div class="line"><a name="l00087"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#afa0b3f5a7c236c57525153e59dd3c608">   87</a></span>&#160;<span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="../../d4/d71/st_8c.html#afa0b3f5a7c236c57525153e59dd3c608">primes</a>[] = {</div>
<div class="line"><a name="l00088"></a><span class="lineno">   88</span>&#160;        8 + 3,</div>
<div class="line"><a name="l00089"></a><span class="lineno">   89</span>&#160;        16 + 3,</div>
<div class="line"><a name="l00090"></a><span class="lineno">   90</span>&#160;        32 + 5,</div>
<div class="line"><a name="l00091"></a><span class="lineno">   91</span>&#160;        64 + 3,</div>
<div class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;        128 + 3,</div>
<div class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;        256 + 27,</div>
<div class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;        512 + 9,</div>
<div class="line"><a name="l00095"></a><span class="lineno">   95</span>&#160;        1024 + 9,</div>
<div class="line"><a name="l00096"></a><span class="lineno">   96</span>&#160;        2048 + 5,</div>
<div class="line"><a name="l00097"></a><span class="lineno">   97</span>&#160;        4096 + 3,</div>
<div class="line"><a name="l00098"></a><span class="lineno">   98</span>&#160;        8192 + 27,</div>
<div class="line"><a name="l00099"></a><span class="lineno">   99</span>&#160;        16384 + 43,</div>
<div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;        32768 + 3,</div>
<div class="line"><a name="l00101"></a><span class="lineno">  101</span>&#160;        65536 + 45,</div>
<div class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;        131072 + 29,</div>
<div class="line"><a name="l00103"></a><span class="lineno">  103</span>&#160;        262144 + 3,</div>
<div class="line"><a name="l00104"></a><span class="lineno">  104</span>&#160;        524288 + 21,</div>
<div class="line"><a name="l00105"></a><span class="lineno">  105</span>&#160;        1048576 + 7,</div>
<div class="line"><a name="l00106"></a><span class="lineno">  106</span>&#160;        2097152 + 17,</div>
<div class="line"><a name="l00107"></a><span class="lineno">  107</span>&#160;        4194304 + 15,</div>
<div class="line"><a name="l00108"></a><span class="lineno">  108</span>&#160;        8388608 + 9,</div>
<div class="line"><a name="l00109"></a><span class="lineno">  109</span>&#160;        16777216 + 43,</div>
<div class="line"><a name="l00110"></a><span class="lineno">  110</span>&#160;        33554432 + 35,</div>
<div class="line"><a name="l00111"></a><span class="lineno">  111</span>&#160;        67108864 + 15,</div>
<div class="line"><a name="l00112"></a><span class="lineno">  112</span>&#160;        134217728 + 29,</div>
<div class="line"><a name="l00113"></a><span class="lineno">  113</span>&#160;        268435456 + 3,</div>
<div class="line"><a name="l00114"></a><span class="lineno">  114</span>&#160;        536870912 + 11,</div>
<div class="line"><a name="l00115"></a><span class="lineno">  115</span>&#160;        1073741824 + 85,</div>
<div class="line"><a name="l00116"></a><span class="lineno">  116</span>&#160;        0</div>
<div class="line"><a name="l00117"></a><span class="lineno">  117</span>&#160;};</div>
<div class="line"><a name="l00118"></a><span class="lineno">  118</span>&#160;</div>
<div class="line"><a name="l00119"></a><span class="lineno">  119</span>&#160;<span class="keyword">static</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l00120"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a">  120</a></span>&#160;<a class="code" href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a">new_size</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>)</div>
<div class="line"><a name="l00121"></a><span class="lineno">  121</span>&#160;{</div>
<div class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;    <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00123"></a><span class="lineno">  123</span>&#160;</div>
<div class="line"><a name="l00124"></a><span class="lineno">  124</span>&#160;<span class="preprocessor">#if 0</span></div>
<div class="line"><a name="l00125"></a><span class="lineno">  125</span>&#160;<span class="preprocessor"></span>    <span class="keywordflow">for</span> (i=3; i&lt;31; i++) {</div>
<div class="line"><a name="l00126"></a><span class="lineno">  126</span>&#160;        <span class="keywordflow">if</span> ((1&lt;&lt;i) &gt; size) <span class="keywordflow">return</span> 1&lt;&lt;<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00127"></a><span class="lineno">  127</span>&#160;    }</div>
<div class="line"><a name="l00128"></a><span class="lineno">  128</span>&#160;    <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l00129"></a><span class="lineno">  129</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l00130"></a><span class="lineno">  130</span>&#160;<span class="preprocessor"></span>    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> newsize;</div>
<div class="line"><a name="l00131"></a><span class="lineno">  131</span>&#160;</div>
<div class="line"><a name="l00132"></a><span class="lineno">  132</span>&#160;    <span class="keywordflow">for</span> (i = 0, newsize = <a class="code" href="../../d4/d71/st_8c.html#a76ace81cc961cbcdba26190bcd706326">MINSIZE</a>; i &lt; <a class="code" href="../../d4/d71/st_8c.html#a4ac8fee05a285361c33a2b0d9c2d555c">numberof</a>(<a class="code" href="../../d4/d71/st_8c.html#afa0b3f5a7c236c57525153e59dd3c608">primes</a>); i++, newsize &lt;&lt;= 1) {</div>
<div class="line"><a name="l00133"></a><span class="lineno">  133</span>&#160;        <span class="keywordflow">if</span> (newsize &gt; size) <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#afa0b3f5a7c236c57525153e59dd3c608">primes</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>];</div>
<div class="line"><a name="l00134"></a><span class="lineno">  134</span>&#160;    }</div>
<div class="line"><a name="l00135"></a><span class="lineno">  135</span>&#160;    <span class="comment">/* Ran out of polynomials */</span></div>
<div class="line"><a name="l00136"></a><span class="lineno">  136</span>&#160;<span class="preprocessor">#ifndef NOT_RUBY</span></div>
<div class="line"><a name="l00137"></a><span class="lineno">  137</span>&#160;<span class="preprocessor"></span>    <a class="code" href="../../db/dcc/error_8c.html#a0f771a2840561f1838169b3d7d4616f3">rb_raise</a>(<a class="code" href="../../db/dcc/error_8c.html#a95ad3953d535707e2cf2b1d837f5e253">rb_eRuntimeError</a>, <span class="stringliteral">&quot;st_table too big&quot;</span>);</div>
<div class="line"><a name="l00138"></a><span class="lineno">  138</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00139"></a><span class="lineno">  139</span>&#160;<span class="preprocessor"></span>    <span class="keywordflow">return</span> -1;                  <span class="comment">/* should raise exception */</span></div>
<div class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;<span class="preprocessor"></span>}</div>
<div class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;</div>
<div class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;<span class="preprocessor">#ifdef HASH_LOG</span></div>
<div class="line"><a name="l00144"></a><span class="lineno">  144</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#ifdef HAVE_UNISTD_H</span></div>
<div class="line"><a name="l00145"></a><span class="lineno">  145</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#include &lt;unistd.h&gt;</span></div>
<div class="line"><a name="l00146"></a><span class="lineno">  146</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00147"></a><span class="lineno">  147</span>&#160;<span class="preprocessor"></span><span class="keyword">static</span> <span class="keyword">struct </span>{</div>
<div class="line"><a name="l00148"></a><span class="lineno">  148</span>&#160;    <span class="keywordtype">int</span> all, total, num, <a class="code" href="../../df/d77/ruby_8c.html#ad7a5c5f28ee70e62307d4f72cfe9dc9b">str</a>, strcase;</div>
<div class="line"><a name="l00149"></a><span class="lineno">  149</span>&#160;}  collision;</div>
<div class="line"><a name="l00150"></a><span class="lineno">  150</span>&#160;<span class="keyword">static</span> <span class="keywordtype">int</span> init_st = 0;</div>
<div class="line"><a name="l00151"></a><span class="lineno">  151</span>&#160;</div>
<div class="line"><a name="l00152"></a><span class="lineno">  152</span>&#160;<span class="keyword">static</span> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00153"></a><span class="lineno">  153</span>&#160;stat_col(<span class="keywordtype">void</span>)</div>
<div class="line"><a name="l00154"></a><span class="lineno">  154</span>&#160;{</div>
<div class="line"><a name="l00155"></a><span class="lineno">  155</span>&#160;    <span class="keywordtype">char</span> fname[10+<span class="keyword">sizeof</span>(<a class="code" href="../../d3/d15/name2ctype_8h.html#a86f2415763322050063a5502f87c9422">long</a>)*3];</div>
<div class="line"><a name="l00156"></a><span class="lineno">  156</span>&#160;    <a class="code" href="../../db/ddf/struct____s_f_i_l_e.html">FILE</a> *f = fopen((<a class="code" href="../../d7/d72/subst_8h.html#aa367b75c5aed883fef5befbdf04835a4">snprintf</a>(fname, <span class="keyword">sizeof</span>(fname), <span class="stringliteral">&quot;/tmp/col%ld&quot;</span>, (<span class="keywordtype">long</span>)getpid()), fname), <span class="stringliteral">&quot;w&quot;</span>);</div>
<div class="line"><a name="l00157"></a><span class="lineno">  157</span>&#160;    fprintf(f, <span class="stringliteral">&quot;collision: %d / %d (%6.2f)\n&quot;</span>, collision.all, collision.total,</div>
<div class="line"><a name="l00158"></a><span class="lineno">  158</span>&#160;            ((<span class="keywordtype">double</span>)collision.all / (collision.total)) * 100);</div>
<div class="line"><a name="l00159"></a><span class="lineno">  159</span>&#160;    fprintf(f, <span class="stringliteral">&quot;num: %d, str: %d, strcase: %d\n&quot;</span>, collision.num, collision.str, collision.strcase);</div>
<div class="line"><a name="l00160"></a><span class="lineno">  160</span>&#160;    fclose(f);</div>
<div class="line"><a name="l00161"></a><span class="lineno">  161</span>&#160;}</div>
<div class="line"><a name="l00162"></a><span class="lineno">  162</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00163"></a><span class="lineno">  163</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00164"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a5425f87cd69b75aba5ccbbb1c9a0a36a">  164</a></span>&#160;<span class="preprocessor">#define MAX_PACKED_NUMHASH (ST_DEFAULT_INIT_TABLE_SIZE/2)</span></div>
<div class="line"><a name="l00165"></a><span class="lineno">  165</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00166"></a><span class="lineno">  166</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00167"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aa5f47e0af563e177e8b559073f454625">  167</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a>(<span class="keyword">const</span> <span class="keyword">struct</span> <a class="code" href="../../d6/d34/structst__hash__type.html">st_hash_type</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a>, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>)</div>
<div class="line"><a name="l00168"></a><span class="lineno">  168</span>&#160;{</div>
<div class="line"><a name="l00169"></a><span class="lineno">  169</span>&#160;    <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d9/dee/tkutil_8c.html#ab758f7e37948b530e3b9542b69437065">tbl</a>;</div>
<div class="line"><a name="l00170"></a><span class="lineno">  170</span>&#160;</div>
<div class="line"><a name="l00171"></a><span class="lineno">  171</span>&#160;<span class="preprocessor">#ifdef HASH_LOG</span></div>
<div class="line"><a name="l00172"></a><span class="lineno">  172</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># if HASH_LOG+0 &lt; 0</span></div>
<div class="line"><a name="l00173"></a><span class="lineno">  173</span>&#160;<span class="preprocessor"></span>    {</div>
<div class="line"><a name="l00174"></a><span class="lineno">  174</span>&#160;        <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="../../de/d07/bigdecimal_8c.html#a5aed264da6cfdc8d553b69a2508c5334">e</a> = <a class="code" href="../../de/d32/dir_8c.html#aee28fd8a0e40b6d958f7d20348e45368">getenv</a>(<span class="stringliteral">&quot;ST_HASH_LOG&quot;</span>);</div>
<div class="line"><a name="l00175"></a><span class="lineno">  175</span>&#160;        <span class="keywordflow">if</span> (!e || !*e) init_st = 1;</div>
<div class="line"><a name="l00176"></a><span class="lineno">  176</span>&#160;    }</div>
<div class="line"><a name="l00177"></a><span class="lineno">  177</span>&#160;<span class="preprocessor"># endif</span></div>
<div class="line"><a name="l00178"></a><span class="lineno">  178</span>&#160;<span class="preprocessor"></span>    <span class="keywordflow">if</span> (init_st == 0) {</div>
<div class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;        init_st = 1;</div>
<div class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;        atexit(stat_col);</div>
<div class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;    }</div>
<div class="line"><a name="l00182"></a><span class="lineno">  182</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00183"></a><span class="lineno">  183</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00184"></a><span class="lineno">  184</span>&#160;    size = <a class="code" href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a">new_size</a>(size);      <span class="comment">/* round up to prime number */</span></div>
<div class="line"><a name="l00185"></a><span class="lineno">  185</span>&#160;</div>
<div class="line"><a name="l00186"></a><span class="lineno">  186</span>&#160;    tbl = <a class="code" href="../../d4/d71/st_8c.html#a385b96996caa48e6349681cf8036322f">alloc</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>);</div>
<div class="line"><a name="l00187"></a><span class="lineno">  187</span>&#160;    tbl-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af56241399d8c6ebedbea58467e9efa61">type</a> = <a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a>;</div>
<div class="line"><a name="l00188"></a><span class="lineno">  188</span>&#160;    tbl-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = 0;</div>
<div class="line"><a name="l00189"></a><span class="lineno">  189</span>&#160;    tbl-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a> = type == &amp;type_numhash &amp;&amp; size/2 &lt;= <a class="code" href="../../d4/d71/st_8c.html#a5425f87cd69b75aba5ccbbb1c9a0a36a">MAX_PACKED_NUMHASH</a>;</div>
<div class="line"><a name="l00190"></a><span class="lineno">  190</span>&#160;    tbl-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a> = <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>;</div>
<div class="line"><a name="l00191"></a><span class="lineno">  191</span>&#160;    tbl-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> = (<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> **)<a class="code" href="../../d4/d71/st_8c.html#a94c395161bf80ffa3b1d224ad3542f11">Calloc</a>(size, <span class="keyword">sizeof</span>(<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*));</div>
<div class="line"><a name="l00192"></a><span class="lineno">  192</span>&#160;    tbl-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a> = 0;</div>
<div class="line"><a name="l00193"></a><span class="lineno">  193</span>&#160;    tbl-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = 0;</div>
<div class="line"><a name="l00194"></a><span class="lineno">  194</span>&#160;</div>
<div class="line"><a name="l00195"></a><span class="lineno">  195</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d9/dee/tkutil_8c.html#ab758f7e37948b530e3b9542b69437065">tbl</a>;</div>
<div class="line"><a name="l00196"></a><span class="lineno">  196</span>&#160;}</div>
<div class="line"><a name="l00197"></a><span class="lineno">  197</span>&#160;</div>
<div class="line"><a name="l00198"></a><span class="lineno">  198</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00199"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a9b0fdfc1b68819f2d666f74187f90b4a">  199</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#adbb0bc2c9aa9b562682b49d3149b8ea3">st_init_table</a>(<span class="keyword">const</span> <span class="keyword">struct</span> <a class="code" href="../../d6/d34/structst__hash__type.html">st_hash_type</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a>)</div>
<div class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;{</div>
<div class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a>(type, 0);</div>
<div class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;}</div>
<div class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;</div>
<div class="line"><a name="l00204"></a><span class="lineno">  204</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00205"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a955c6e936b9681649ab9ffa4aa741949">  205</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a6de11f24647b8c2938badf820e79a976">st_init_numtable</a>(<span class="keywordtype">void</span>)</div>
<div class="line"><a name="l00206"></a><span class="lineno">  206</span>&#160;{</div>
<div class="line"><a name="l00207"></a><span class="lineno">  207</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#adbb0bc2c9aa9b562682b49d3149b8ea3">st_init_table</a>(&amp;type_numhash);</div>
<div class="line"><a name="l00208"></a><span class="lineno">  208</span>&#160;}</div>
<div class="line"><a name="l00209"></a><span class="lineno">  209</span>&#160;</div>
<div class="line"><a name="l00210"></a><span class="lineno">  210</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00211"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a8a0fa825221e5025911fd93c6c30f3dd">  211</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a265827f28bd0539bc25cc4459fc83690">st_init_numtable_with_size</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>)</div>
<div class="line"><a name="l00212"></a><span class="lineno">  212</span>&#160;{</div>
<div class="line"><a name="l00213"></a><span class="lineno">  213</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a>(&amp;type_numhash, size);</div>
<div class="line"><a name="l00214"></a><span class="lineno">  214</span>&#160;}</div>
<div class="line"><a name="l00215"></a><span class="lineno">  215</span>&#160;</div>
<div class="line"><a name="l00216"></a><span class="lineno">  216</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00217"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aaca0d6a6f8e07dd6ad3265872d7b1f81">  217</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#ae3540c476ad141816fa6f6bf6a30e7df">st_init_strtable</a>(<span class="keywordtype">void</span>)</div>
<div class="line"><a name="l00218"></a><span class="lineno">  218</span>&#160;{</div>
<div class="line"><a name="l00219"></a><span class="lineno">  219</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#adbb0bc2c9aa9b562682b49d3149b8ea3">st_init_table</a>(&amp;type_strhash);</div>
<div class="line"><a name="l00220"></a><span class="lineno">  220</span>&#160;}</div>
<div class="line"><a name="l00221"></a><span class="lineno">  221</span>&#160;</div>
<div class="line"><a name="l00222"></a><span class="lineno">  222</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00223"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a92f0cb21ae7d4d53e0f57efcd158d80f">  223</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a698052a584b1c7daa968cd5d16a0a2d0">st_init_strtable_with_size</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>)</div>
<div class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;{</div>
<div class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a>(&amp;type_strhash, size);</div>
<div class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;}</div>
<div class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;</div>
<div class="line"><a name="l00228"></a><span class="lineno">  228</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00229"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a60f14cceadd837db51e110881258944a">  229</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a60f14cceadd837db51e110881258944a">st_init_strcasetable</a>(<span class="keywordtype">void</span>)</div>
<div class="line"><a name="l00230"></a><span class="lineno">  230</span>&#160;{</div>
<div class="line"><a name="l00231"></a><span class="lineno">  231</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#adbb0bc2c9aa9b562682b49d3149b8ea3">st_init_table</a>(&amp;type_strcasehash);</div>
<div class="line"><a name="l00232"></a><span class="lineno">  232</span>&#160;}</div>
<div class="line"><a name="l00233"></a><span class="lineno">  233</span>&#160;</div>
<div class="line"><a name="l00234"></a><span class="lineno">  234</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00235"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4c12b0bc4cb64bc0ebc40a3536e0198a">  235</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a8650831f7c601411625cb369422ee6d4">st_init_strcasetable_with_size</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>)</div>
<div class="line"><a name="l00236"></a><span class="lineno">  236</span>&#160;{</div>
<div class="line"><a name="l00237"></a><span class="lineno">  237</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a>(&amp;type_strcasehash, size);</div>
<div class="line"><a name="l00238"></a><span class="lineno">  238</span>&#160;}</div>
<div class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;</div>
<div class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00241"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a9b0256b6986265c09661636af78fcb74">  241</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#ad6324e2f86dbf2243270fd24aac5367f">st_clear</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>)</div>
<div class="line"><a name="l00242"></a><span class="lineno">  242</span>&#160;{</div>
<div class="line"><a name="l00243"></a><span class="lineno">  243</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>, *next;</div>
<div class="line"><a name="l00244"></a><span class="lineno">  244</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00245"></a><span class="lineno">  245</span>&#160;</div>
<div class="line"><a name="l00246"></a><span class="lineno">  246</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00247"></a><span class="lineno">  247</span>&#160;        table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = 0;</div>
<div class="line"><a name="l00248"></a><span class="lineno">  248</span>&#160;        <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00249"></a><span class="lineno">  249</span>&#160;    }</div>
<div class="line"><a name="l00250"></a><span class="lineno">  250</span>&#160;</div>
<div class="line"><a name="l00251"></a><span class="lineno">  251</span>&#160;    <span class="keywordflow">for</span>(i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>; i++) {</div>
<div class="line"><a name="l00252"></a><span class="lineno">  252</span>&#160;        ptr = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>];</div>
<div class="line"><a name="l00253"></a><span class="lineno">  253</span>&#160;        table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>] = 0;</div>
<div class="line"><a name="l00254"></a><span class="lineno">  254</span>&#160;        <span class="keywordflow">while</span> (ptr != 0) {</div>
<div class="line"><a name="l00255"></a><span class="lineno">  255</span>&#160;            next = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div>
<div class="line"><a name="l00256"></a><span class="lineno">  256</span>&#160;            <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(ptr);</div>
<div class="line"><a name="l00257"></a><span class="lineno">  257</span>&#160;            ptr = next;</div>
<div class="line"><a name="l00258"></a><span class="lineno">  258</span>&#160;        }</div>
<div class="line"><a name="l00259"></a><span class="lineno">  259</span>&#160;    }</div>
<div class="line"><a name="l00260"></a><span class="lineno">  260</span>&#160;    table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = 0;</div>
<div class="line"><a name="l00261"></a><span class="lineno">  261</span>&#160;    table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a> = 0;</div>
<div class="line"><a name="l00262"></a><span class="lineno">  262</span>&#160;    table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = 0;</div>
<div class="line"><a name="l00263"></a><span class="lineno">  263</span>&#160;}</div>
<div class="line"><a name="l00264"></a><span class="lineno">  264</span>&#160;</div>
<div class="line"><a name="l00265"></a><span class="lineno">  265</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00266"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a93394fd99c5fa4fbcce2be9717abee45">  266</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#ae0adede5868e71009c620a32a7b9d61e">st_free_table</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>)</div>
<div class="line"><a name="l00267"></a><span class="lineno">  267</span>&#160;{</div>
<div class="line"><a name="l00268"></a><span class="lineno">  268</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ad6324e2f86dbf2243270fd24aac5367f">st_clear</a>(table);</div>
<div class="line"><a name="l00269"></a><span class="lineno">  269</span>&#160;    <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>);</div>
<div class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;    <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(table);</div>
<div class="line"><a name="l00271"></a><span class="lineno">  271</span>&#160;}</div>
<div class="line"><a name="l00272"></a><span class="lineno">  272</span>&#160;</div>
<div class="line"><a name="l00273"></a><span class="lineno">  273</span>&#160;<span class="keywordtype">size_t</span></div>
<div class="line"><a name="l00274"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a9c7d882a34165813cbf64b5fd68b8570">  274</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a1d0d955fb1f39486c18162f222deb82b">st_memsize</a>(<span class="keyword">const</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>)</div>
<div class="line"><a name="l00275"></a><span class="lineno">  275</span>&#160;{</div>
<div class="line"><a name="l00276"></a><span class="lineno">  276</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00277"></a><span class="lineno">  277</span>&#160;        <span class="keywordflow">return</span> table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a> * <span class="keyword">sizeof</span> (<span class="keywordtype">void</span> *) + <span class="keyword">sizeof</span>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>);</div>
<div class="line"><a name="l00278"></a><span class="lineno">  278</span>&#160;    }</div>
<div class="line"><a name="l00279"></a><span class="lineno">  279</span>&#160;    <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;        <span class="keywordflow">return</span> table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> * <span class="keyword">sizeof</span>(<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>) + table-&gt;num_bins * <span class="keyword">sizeof</span> (<span class="keywordtype">void</span> *) + <span class="keyword">sizeof</span>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>);</div>
<div class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;    }</div>
<div class="line"><a name="l00282"></a><span class="lineno">  282</span>&#160;}</div>
<div class="line"><a name="l00283"></a><span class="lineno">  283</span>&#160;</div>
<div class="line"><a name="l00284"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a349734f8cc08a7685ec22c76d31d0d87">  284</a></span>&#160;<span class="preprocessor">#define PTR_NOT_EQUAL(table, ptr, hash_val, key) \</span></div>
<div class="line"><a name="l00285"></a><span class="lineno">  285</span>&#160;<span class="preprocessor">((ptr) != 0 &amp;&amp; ((ptr)-&gt;hash != (hash_val) || !EQUAL((table), (key), (ptr)-&gt;key)))</span></div>
<div class="line"><a name="l00286"></a><span class="lineno">  286</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00287"></a><span class="lineno">  287</span>&#160;<span class="preprocessor">#ifdef HASH_LOG</span></div>
<div class="line"><a name="l00288"></a><span class="lineno">  288</span>&#160;<span class="preprocessor"></span><span class="keyword">static</span> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00289"></a><span class="lineno">  289</span>&#160;count_collision(<span class="keyword">const</span> <span class="keyword">struct</span> <a class="code" href="../../d6/d34/structst__hash__type.html">st_hash_type</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a>)</div>
<div class="line"><a name="l00290"></a><span class="lineno">  290</span>&#160;{</div>
<div class="line"><a name="l00291"></a><span class="lineno">  291</span>&#160;    collision.all++;</div>
<div class="line"><a name="l00292"></a><span class="lineno">  292</span>&#160;    <span class="keywordflow">if</span> (type == &amp;type_numhash) {</div>
<div class="line"><a name="l00293"></a><span class="lineno">  293</span>&#160;        collision.num++;</div>
<div class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;    }</div>
<div class="line"><a name="l00295"></a><span class="lineno">  295</span>&#160;    <span class="keywordflow">else</span> <span class="keywordflow">if</span> (type == &amp;type_strhash) {</div>
<div class="line"><a name="l00296"></a><span class="lineno">  296</span>&#160;        collision.strcase++;</div>
<div class="line"><a name="l00297"></a><span class="lineno">  297</span>&#160;    }</div>
<div class="line"><a name="l00298"></a><span class="lineno">  298</span>&#160;    <span class="keywordflow">else</span> <span class="keywordflow">if</span> (type == &amp;type_strcasehash) {</div>
<div class="line"><a name="l00299"></a><span class="lineno">  299</span>&#160;        collision.str++;</div>
<div class="line"><a name="l00300"></a><span class="lineno">  300</span>&#160;    }</div>
<div class="line"><a name="l00301"></a><span class="lineno">  301</span>&#160;}</div>
<div class="line"><a name="l00302"></a><span class="lineno">  302</span>&#160;<span class="preprocessor">#define COLLISION (collision_check ? count_collision(table-&gt;type) : (void)0)</span></div>
<div class="line"><a name="l00303"></a><span class="lineno">  303</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define FOUND_ENTRY (collision_check ? collision.total++ : (void)0)</span></div>
<div class="line"><a name="l00304"></a><span class="lineno">  304</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l00305"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aafd826a123a41fd03a9c88842387a821">  305</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define COLLISION</span></div>
<div class="line"><a name="l00306"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a3b3d5a648505e3a2db3d4d4504b13c0e">  306</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define FOUND_ENTRY</span></div>
<div class="line"><a name="l00307"></a><span class="lineno">  307</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00308"></a><span class="lineno">  308</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00309"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">  309</a></span>&#160;<span class="preprocessor">#define FIND_ENTRY(table, ptr, hash_val, bin_pos) do {\</span></div>
<div class="line"><a name="l00310"></a><span class="lineno">  310</span>&#160;<span class="preprocessor">    (bin_pos) = (hash_val)%(table)-&gt;num_bins;\</span></div>
<div class="line"><a name="l00311"></a><span class="lineno">  311</span>&#160;<span class="preprocessor">    (ptr) = (table)-&gt;bins[(bin_pos)];\</span></div>
<div class="line"><a name="l00312"></a><span class="lineno">  312</span>&#160;<span class="preprocessor">    FOUND_ENTRY;\</span></div>
<div class="line"><a name="l00313"></a><span class="lineno">  313</span>&#160;<span class="preprocessor">    if (PTR_NOT_EQUAL((table), (ptr), (hash_val), key)) {\</span></div>
<div class="line"><a name="l00314"></a><span class="lineno">  314</span>&#160;<span class="preprocessor">        COLLISION;\</span></div>
<div class="line"><a name="l00315"></a><span class="lineno">  315</span>&#160;<span class="preprocessor">        while (PTR_NOT_EQUAL((table), (ptr)-&gt;next, (hash_val), key)) {\</span></div>
<div class="line"><a name="l00316"></a><span class="lineno">  316</span>&#160;<span class="preprocessor">            (ptr) = (ptr)-&gt;next;\</span></div>
<div class="line"><a name="l00317"></a><span class="lineno">  317</span>&#160;<span class="preprocessor">        }\</span></div>
<div class="line"><a name="l00318"></a><span class="lineno">  318</span>&#160;<span class="preprocessor">        (ptr) = (ptr)-&gt;next;\</span></div>
<div class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;<span class="preprocessor">    }\</span></div>
<div class="line"><a name="l00320"></a><span class="lineno">  320</span>&#160;<span class="preprocessor">} while (0)</span></div>
<div class="line"><a name="l00321"></a><span class="lineno">  321</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00322"></a><span class="lineno">  322</span>&#160;<span class="preprocessor">#define collision_check 0</span></div>
<div class="line"><a name="l00323"></a><span class="lineno">  323</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00324"></a><span class="lineno">  324</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00325"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#af526fb7d918a9a5ceadadc087e79aa1c">  325</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a8032e662c4b4ee0ded05bbe3f15d5c45">st_lookup</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>, <span class="keyword">register</span> <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#aecdd94a9fd50703da3e57eaf5ccb9809">value</a>)</div>
<div class="line"><a name="l00326"></a><span class="lineno">  326</span>&#160;{</div>
<div class="line"><a name="l00327"></a><span class="lineno">  327</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, bin_pos;</div>
<div class="line"><a name="l00328"></a><span class="lineno">  328</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00329"></a><span class="lineno">  329</span>&#160;</div>
<div class="line"><a name="l00330"></a><span class="lineno">  330</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00331"></a><span class="lineno">  331</span>&#160;        <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00332"></a><span class="lineno">  332</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; i++) {</div>
<div class="line"><a name="l00333"></a><span class="lineno">  333</span>&#160;            <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] == key) {</div>
<div class="line"><a name="l00334"></a><span class="lineno">  334</span>&#160;                <span class="keywordflow">if</span> (value !=0) *value = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1];</div>
<div class="line"><a name="l00335"></a><span class="lineno">  335</span>&#160;                <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00336"></a><span class="lineno">  336</span>&#160;            }</div>
<div class="line"><a name="l00337"></a><span class="lineno">  337</span>&#160;        }</div>
<div class="line"><a name="l00338"></a><span class="lineno">  338</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00339"></a><span class="lineno">  339</span>&#160;    }</div>
<div class="line"><a name="l00340"></a><span class="lineno">  340</span>&#160;</div>
<div class="line"><a name="l00341"></a><span class="lineno">  341</span>&#160;    hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(key, table);</div>
<div class="line"><a name="l00342"></a><span class="lineno">  342</span>&#160;    <a class="code" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">FIND_ENTRY</a>(table, ptr, hash_val, bin_pos);</div>
<div class="line"><a name="l00343"></a><span class="lineno">  343</span>&#160;</div>
<div class="line"><a name="l00344"></a><span class="lineno">  344</span>&#160;    <span class="keywordflow">if</span> (ptr == 0) {</div>
<div class="line"><a name="l00345"></a><span class="lineno">  345</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00346"></a><span class="lineno">  346</span>&#160;    }</div>
<div class="line"><a name="l00347"></a><span class="lineno">  347</span>&#160;    <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00348"></a><span class="lineno">  348</span>&#160;        <span class="keywordflow">if</span> (value != 0)  *value = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>;</div>
<div class="line"><a name="l00349"></a><span class="lineno">  349</span>&#160;        <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00350"></a><span class="lineno">  350</span>&#160;    }</div>
<div class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;}</div>
<div class="line"><a name="l00352"></a><span class="lineno">  352</span>&#160;</div>
<div class="line"><a name="l00353"></a><span class="lineno">  353</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00354"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae666ef5798c3d30a0533bd91054ec1f3">  354</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a67fcf8f213cf0367f1923b2ae72b868d">st_get_key</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>, <span class="keyword">register</span> <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#ae6cf673d09a03d1dfd71928b32d95161">result</a>)</div>
<div class="line"><a name="l00355"></a><span class="lineno">  355</span>&#160;{</div>
<div class="line"><a name="l00356"></a><span class="lineno">  356</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, bin_pos;</div>
<div class="line"><a name="l00357"></a><span class="lineno">  357</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00358"></a><span class="lineno">  358</span>&#160;</div>
<div class="line"><a name="l00359"></a><span class="lineno">  359</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00360"></a><span class="lineno">  360</span>&#160;        <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00361"></a><span class="lineno">  361</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; i++) {</div>
<div class="line"><a name="l00362"></a><span class="lineno">  362</span>&#160;            <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] == key) {</div>
<div class="line"><a name="l00363"></a><span class="lineno">  363</span>&#160;                <span class="keywordflow">if</span> (result !=0) *result = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2];</div>
<div class="line"><a name="l00364"></a><span class="lineno">  364</span>&#160;                <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00365"></a><span class="lineno">  365</span>&#160;            }</div>
<div class="line"><a name="l00366"></a><span class="lineno">  366</span>&#160;        }</div>
<div class="line"><a name="l00367"></a><span class="lineno">  367</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00368"></a><span class="lineno">  368</span>&#160;    }</div>
<div class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;</div>
<div class="line"><a name="l00370"></a><span class="lineno">  370</span>&#160;    hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(key, table);</div>
<div class="line"><a name="l00371"></a><span class="lineno">  371</span>&#160;    <a class="code" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">FIND_ENTRY</a>(table, ptr, hash_val, bin_pos);</div>
<div class="line"><a name="l00372"></a><span class="lineno">  372</span>&#160;</div>
<div class="line"><a name="l00373"></a><span class="lineno">  373</span>&#160;    <span class="keywordflow">if</span> (ptr == 0) {</div>
<div class="line"><a name="l00374"></a><span class="lineno">  374</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00375"></a><span class="lineno">  375</span>&#160;    }</div>
<div class="line"><a name="l00376"></a><span class="lineno">  376</span>&#160;    <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00377"></a><span class="lineno">  377</span>&#160;        <span class="keywordflow">if</span> (result != 0)  *result = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div>
<div class="line"><a name="l00378"></a><span class="lineno">  378</span>&#160;        <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00379"></a><span class="lineno">  379</span>&#160;    }</div>
<div class="line"><a name="l00380"></a><span class="lineno">  380</span>&#160;}</div>
<div class="line"><a name="l00381"></a><span class="lineno">  381</span>&#160;</div>
<div class="line"><a name="l00382"></a><span class="lineno">  382</span>&#160;<span class="preprocessor">#undef collision_check</span></div>
<div class="line"><a name="l00383"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae1c51589b76ef357bffa24d929c165e5">  383</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define collision_check 1</span></div>
<div class="line"><a name="l00384"></a><span class="lineno">  384</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00385"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aecc14cc0cf491182bee62e6d4db68334">  385</a></span>&#160;<span class="preprocessor">#define MORE_PACKABLE_P(table) \</span></div>
<div class="line"><a name="l00386"></a><span class="lineno">  386</span>&#160;<span class="preprocessor">    ((st_index_t)((table)-&gt;num_entries+1) * 2 &lt;= (table)-&gt;num_bins &amp;&amp; \</span></div>
<div class="line"><a name="l00387"></a><span class="lineno">  387</span>&#160;<span class="preprocessor">     (table)-&gt;num_entries+1 &lt;= MAX_PACKED_NUMHASH)</span></div>
<div class="line"><a name="l00388"></a><span class="lineno">  388</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00389"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a2adf90985f6ca4ecff6def2304d3d2dd">  389</a></span>&#160;<span class="preprocessor">#define ADD_DIRECT(table, key, value, hash_val, bin_pos)\</span></div>
<div class="line"><a name="l00390"></a><span class="lineno">  390</span>&#160;<span class="preprocessor">do {\</span></div>
<div class="line"><a name="l00391"></a><span class="lineno">  391</span>&#160;<span class="preprocessor">    st_table_entry *entry;\</span></div>
<div class="line"><a name="l00392"></a><span class="lineno">  392</span>&#160;<span class="preprocessor">    if ((table)-&gt;num_entries &gt; ST_DEFAULT_MAX_DENSITY * (table)-&gt;num_bins) {\</span></div>
<div class="line"><a name="l00393"></a><span class="lineno">  393</span>&#160;<span class="preprocessor">        rehash(table);\</span></div>
<div class="line"><a name="l00394"></a><span class="lineno">  394</span>&#160;<span class="preprocessor">        (bin_pos) = (hash_val) % (table)-&gt;num_bins;\</span></div>
<div class="line"><a name="l00395"></a><span class="lineno">  395</span>&#160;<span class="preprocessor">    }\</span></div>
<div class="line"><a name="l00396"></a><span class="lineno">  396</span>&#160;<span class="preprocessor">    \</span></div>
<div class="line"><a name="l00397"></a><span class="lineno">  397</span>&#160;<span class="preprocessor">    entry = alloc(st_table_entry);\</span></div>
<div class="line"><a name="l00398"></a><span class="lineno">  398</span>&#160;<span class="preprocessor">    \</span></div>
<div class="line"><a name="l00399"></a><span class="lineno">  399</span>&#160;<span class="preprocessor">    entry-&gt;hash = (hash_val);\</span></div>
<div class="line"><a name="l00400"></a><span class="lineno">  400</span>&#160;<span class="preprocessor">    entry-&gt;key = (key);\</span></div>
<div class="line"><a name="l00401"></a><span class="lineno">  401</span>&#160;<span class="preprocessor">    entry-&gt;record = (value);\</span></div>
<div class="line"><a name="l00402"></a><span class="lineno">  402</span>&#160;<span class="preprocessor">    entry-&gt;next = (table)-&gt;bins[(bin_pos)];\</span></div>
<div class="line"><a name="l00403"></a><span class="lineno">  403</span>&#160;<span class="preprocessor">    if ((table)-&gt;head != 0) {\</span></div>
<div class="line"><a name="l00404"></a><span class="lineno">  404</span>&#160;<span class="preprocessor">        entry-&gt;fore = 0;\</span></div>
<div class="line"><a name="l00405"></a><span class="lineno">  405</span>&#160;<span class="preprocessor">        (entry-&gt;back = (table)-&gt;tail)-&gt;fore = entry;\</span></div>
<div class="line"><a name="l00406"></a><span class="lineno">  406</span>&#160;<span class="preprocessor">        (table)-&gt;tail = entry;\</span></div>
<div class="line"><a name="l00407"></a><span class="lineno">  407</span>&#160;<span class="preprocessor">    }\</span></div>
<div class="line"><a name="l00408"></a><span class="lineno">  408</span>&#160;<span class="preprocessor">    else {\</span></div>
<div class="line"><a name="l00409"></a><span class="lineno">  409</span>&#160;<span class="preprocessor">        (table)-&gt;head = (table)-&gt;tail = entry;\</span></div>
<div class="line"><a name="l00410"></a><span class="lineno">  410</span>&#160;<span class="preprocessor">        entry-&gt;fore = entry-&gt;back = 0;\</span></div>
<div class="line"><a name="l00411"></a><span class="lineno">  411</span>&#160;<span class="preprocessor">    }\</span></div>
<div class="line"><a name="l00412"></a><span class="lineno">  412</span>&#160;<span class="preprocessor">    (table)-&gt;bins[(bin_pos)] = entry;\</span></div>
<div class="line"><a name="l00413"></a><span class="lineno">  413</span>&#160;<span class="preprocessor">    (table)-&gt;num_entries++;\</span></div>
<div class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;<span class="preprocessor">} while (0)</span></div>
<div class="line"><a name="l00415"></a><span class="lineno">  415</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00416"></a><span class="lineno">  416</span>&#160;<span class="keyword">static</span> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00417"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#abd2051b6b857de0a4b8aec12043fe005">  417</a></span>&#160;<a class="code" href="../../d4/d71/st_8c.html#abd2051b6b857de0a4b8aec12043fe005">unpack_entries</a>(<span class="keyword">register</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>)</div>
<div class="line"><a name="l00418"></a><span class="lineno">  418</span>&#160;{</div>
<div class="line"><a name="l00419"></a><span class="lineno">  419</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00420"></a><span class="lineno">  420</span>&#160;    <span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *packed_bins[<a class="code" href="../../d4/d71/st_8c.html#a5425f87cd69b75aba5ccbbb1c9a0a36a">MAX_PACKED_NUMHASH</a>*2];</div>
<div class="line"><a name="l00421"></a><span class="lineno">  421</span>&#160;    <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> tmp_table = *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>;</div>
<div class="line"><a name="l00422"></a><span class="lineno">  422</span>&#160;</div>
<div class="line"><a name="l00423"></a><span class="lineno">  423</span>&#160;    <a class="code" href="../../d5/d9d/tcltklib_8c.html#a7aa3ca79548709bc580aa259ad1fd2d2">memcpy</a>(packed_bins, table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, <span class="keyword">sizeof</span>(<span class="keyword">struct</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *) * table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>*2);</div>
<div class="line"><a name="l00424"></a><span class="lineno">  424</span>&#160;    table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> = packed_bins;</div>
<div class="line"><a name="l00425"></a><span class="lineno">  425</span>&#160;    tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a> = 0;</div>
<div class="line"><a name="l00426"></a><span class="lineno">  426</span>&#160;    tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = 0;</div>
<div class="line"><a name="l00427"></a><span class="lineno">  427</span>&#160;    <a class="code" href="../../de/d07/bigdecimal_8c.html#ae676aee4547572d937505cfb336c18d5">memset</a>(tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, 0, <span class="keyword">sizeof</span>(<span class="keyword">struct</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *) * tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div>
<div class="line"><a name="l00428"></a><span class="lineno">  428</span>&#160;    <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; i++) {</div>
<div class="line"><a name="l00429"></a><span class="lineno">  429</span>&#160;        <a class="code" href="../../d6/d87/regint_8h.html#ab6920d7d3a34f3d179d1f35806e1965f">st_insert</a>(&amp;tmp_table, (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)packed_bins[i*2], (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)packed_bins[i*2+1]);</div>
<div class="line"><a name="l00430"></a><span class="lineno">  430</span>&#160;    }</div>
<div class="line"><a name="l00431"></a><span class="lineno">  431</span>&#160;    *table = tmp_table;</div>
<div class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;}</div>
<div class="line"><a name="l00433"></a><span class="lineno">  433</span>&#160;</div>
<div class="line"><a name="l00434"></a><span class="lineno">  434</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00435"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a068ebca65df8733df9e368b4d6dd82ca">  435</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#ab6920d7d3a34f3d179d1f35806e1965f">st_insert</a>(<span class="keyword">register</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>, <span class="keyword">register</span> <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d5/d9d/tcltklib_8c.html#aecdd94a9fd50703da3e57eaf5ccb9809">value</a>)</div>
<div class="line"><a name="l00436"></a><span class="lineno">  436</span>&#160;{</div>
<div class="line"><a name="l00437"></a><span class="lineno">  437</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, bin_pos;</div>
<div class="line"><a name="l00438"></a><span class="lineno">  438</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00439"></a><span class="lineno">  439</span>&#160;</div>
<div class="line"><a name="l00440"></a><span class="lineno">  440</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00441"></a><span class="lineno">  441</span>&#160;        <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00442"></a><span class="lineno">  442</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; i++) {</div>
<div class="line"><a name="l00443"></a><span class="lineno">  443</span>&#160;            <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] == key) {</div>
<div class="line"><a name="l00444"></a><span class="lineno">  444</span>&#160;                table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1] = (<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*)value;</div>
<div class="line"><a name="l00445"></a><span class="lineno">  445</span>&#160;                <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00446"></a><span class="lineno">  446</span>&#160;            }</div>
<div class="line"><a name="l00447"></a><span class="lineno">  447</span>&#160;        }</div>
<div class="line"><a name="l00448"></a><span class="lineno">  448</span>&#160;        <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#aecc14cc0cf491182bee62e6d4db68334">MORE_PACKABLE_P</a>(table)) {</div>
<div class="line"><a name="l00449"></a><span class="lineno">  449</span>&#160;            i = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>++;</div>
<div class="line"><a name="l00450"></a><span class="lineno">  450</span>&#160;            table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] = (<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*)key;</div>
<div class="line"><a name="l00451"></a><span class="lineno">  451</span>&#160;            table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1] = (<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*)value;</div>
<div class="line"><a name="l00452"></a><span class="lineno">  452</span>&#160;            <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00453"></a><span class="lineno">  453</span>&#160;        }</div>
<div class="line"><a name="l00454"></a><span class="lineno">  454</span>&#160;        <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00455"></a><span class="lineno">  455</span>&#160;            <a class="code" href="../../d4/d71/st_8c.html#abd2051b6b857de0a4b8aec12043fe005">unpack_entries</a>(table);</div>
<div class="line"><a name="l00456"></a><span class="lineno">  456</span>&#160;        }</div>
<div class="line"><a name="l00457"></a><span class="lineno">  457</span>&#160;    }</div>
<div class="line"><a name="l00458"></a><span class="lineno">  458</span>&#160;</div>
<div class="line"><a name="l00459"></a><span class="lineno">  459</span>&#160;    hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(key, table);</div>
<div class="line"><a name="l00460"></a><span class="lineno">  460</span>&#160;    <a class="code" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">FIND_ENTRY</a>(table, ptr, hash_val, bin_pos);</div>
<div class="line"><a name="l00461"></a><span class="lineno">  461</span>&#160;</div>
<div class="line"><a name="l00462"></a><span class="lineno">  462</span>&#160;    <span class="keywordflow">if</span> (ptr == 0) {</div>
<div class="line"><a name="l00463"></a><span class="lineno">  463</span>&#160;        <a class="code" href="../../d4/d71/st_8c.html#a2adf90985f6ca4ecff6def2304d3d2dd">ADD_DIRECT</a>(table, key, value, hash_val, bin_pos);</div>
<div class="line"><a name="l00464"></a><span class="lineno">  464</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00465"></a><span class="lineno">  465</span>&#160;    }</div>
<div class="line"><a name="l00466"></a><span class="lineno">  466</span>&#160;    <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00467"></a><span class="lineno">  467</span>&#160;        ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a> = <a class="code" href="../../d5/d9d/tcltklib_8c.html#aecdd94a9fd50703da3e57eaf5ccb9809">value</a>;</div>
<div class="line"><a name="l00468"></a><span class="lineno">  468</span>&#160;        <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00469"></a><span class="lineno">  469</span>&#160;    }</div>
<div class="line"><a name="l00470"></a><span class="lineno">  470</span>&#160;}</div>
<div class="line"><a name="l00471"></a><span class="lineno">  471</span>&#160;</div>
<div class="line"><a name="l00472"></a><span class="lineno">  472</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00473"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1000e3d262482cebe00e98bf21696749">  473</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a6978e6fe886b41a3c781a50760eb7d70">st_insert2</a>(<span class="keyword">register</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a>, <span class="keyword">register</span> <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d5/d9d/tcltklib_8c.html#aecdd94a9fd50703da3e57eaf5ccb9809">value</a>,</div>
<div class="line"><a name="l00474"></a><span class="lineno">  474</span>&#160;           <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> (*<a class="code" href="../../dc/dd1/ossl__ssl_8c.html#a33775ffa49b921f1647bfac2850c6298">func</a>)(<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>))</div>
<div class="line"><a name="l00475"></a><span class="lineno">  475</span>&#160;{</div>
<div class="line"><a name="l00476"></a><span class="lineno">  476</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, bin_pos;</div>
<div class="line"><a name="l00477"></a><span class="lineno">  477</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00478"></a><span class="lineno">  478</span>&#160;</div>
<div class="line"><a name="l00479"></a><span class="lineno">  479</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00480"></a><span class="lineno">  480</span>&#160;        <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00481"></a><span class="lineno">  481</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; i++) {</div>
<div class="line"><a name="l00482"></a><span class="lineno">  482</span>&#160;            <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] == key) {</div>
<div class="line"><a name="l00483"></a><span class="lineno">  483</span>&#160;                table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1] = (<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*)value;</div>
<div class="line"><a name="l00484"></a><span class="lineno">  484</span>&#160;                <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00485"></a><span class="lineno">  485</span>&#160;            }</div>
<div class="line"><a name="l00486"></a><span class="lineno">  486</span>&#160;        }</div>
<div class="line"><a name="l00487"></a><span class="lineno">  487</span>&#160;        <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#aecc14cc0cf491182bee62e6d4db68334">MORE_PACKABLE_P</a>(table)) {</div>
<div class="line"><a name="l00488"></a><span class="lineno">  488</span>&#160;            i = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>++;</div>
<div class="line"><a name="l00489"></a><span class="lineno">  489</span>&#160;            table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] = (<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*)key;</div>
<div class="line"><a name="l00490"></a><span class="lineno">  490</span>&#160;            table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1] = (<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*)value;</div>
<div class="line"><a name="l00491"></a><span class="lineno">  491</span>&#160;            <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00492"></a><span class="lineno">  492</span>&#160;        }</div>
<div class="line"><a name="l00493"></a><span class="lineno">  493</span>&#160;        <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00494"></a><span class="lineno">  494</span>&#160;            <a class="code" href="../../d4/d71/st_8c.html#abd2051b6b857de0a4b8aec12043fe005">unpack_entries</a>(table);</div>
<div class="line"><a name="l00495"></a><span class="lineno">  495</span>&#160;        }</div>
<div class="line"><a name="l00496"></a><span class="lineno">  496</span>&#160;    }</div>
<div class="line"><a name="l00497"></a><span class="lineno">  497</span>&#160;</div>
<div class="line"><a name="l00498"></a><span class="lineno">  498</span>&#160;    hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(key, table);</div>
<div class="line"><a name="l00499"></a><span class="lineno">  499</span>&#160;    <a class="code" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">FIND_ENTRY</a>(table, ptr, hash_val, bin_pos);</div>
<div class="line"><a name="l00500"></a><span class="lineno">  500</span>&#160;</div>
<div class="line"><a name="l00501"></a><span class="lineno">  501</span>&#160;    <span class="keywordflow">if</span> (ptr == 0) {</div>
<div class="line"><a name="l00502"></a><span class="lineno">  502</span>&#160;        key = (*func)(<a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>);</div>
<div class="line"><a name="l00503"></a><span class="lineno">  503</span>&#160;        <a class="code" href="../../d4/d71/st_8c.html#a2adf90985f6ca4ecff6def2304d3d2dd">ADD_DIRECT</a>(table, key, value, hash_val, bin_pos);</div>
<div class="line"><a name="l00504"></a><span class="lineno">  504</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00505"></a><span class="lineno">  505</span>&#160;    }</div>
<div class="line"><a name="l00506"></a><span class="lineno">  506</span>&#160;    <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00507"></a><span class="lineno">  507</span>&#160;        ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a> = <a class="code" href="../../d5/d9d/tcltklib_8c.html#aecdd94a9fd50703da3e57eaf5ccb9809">value</a>;</div>
<div class="line"><a name="l00508"></a><span class="lineno">  508</span>&#160;        <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00509"></a><span class="lineno">  509</span>&#160;    }</div>
<div class="line"><a name="l00510"></a><span class="lineno">  510</span>&#160;}</div>
<div class="line"><a name="l00511"></a><span class="lineno">  511</span>&#160;</div>
<div class="line"><a name="l00512"></a><span class="lineno">  512</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00513"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a6c727f5a38e3e21fea2d0b8468813d87">  513</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a98c731e7988ea9e138c2deac3ad4a3f1">st_add_direct</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> key, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> value)</div>
<div class="line"><a name="l00514"></a><span class="lineno">  514</span>&#160;{</div>
<div class="line"><a name="l00515"></a><span class="lineno">  515</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, bin_pos;</div>
<div class="line"><a name="l00516"></a><span class="lineno">  516</span>&#160;</div>
<div class="line"><a name="l00517"></a><span class="lineno">  517</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00518"></a><span class="lineno">  518</span>&#160;        <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00519"></a><span class="lineno">  519</span>&#160;        <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#aecc14cc0cf491182bee62e6d4db68334">MORE_PACKABLE_P</a>(table)) {</div>
<div class="line"><a name="l00520"></a><span class="lineno">  520</span>&#160;            i = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>++;</div>
<div class="line"><a name="l00521"></a><span class="lineno">  521</span>&#160;            table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] = (<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*)key;</div>
<div class="line"><a name="l00522"></a><span class="lineno">  522</span>&#160;            table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1] = (<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*)value;</div>
<div class="line"><a name="l00523"></a><span class="lineno">  523</span>&#160;            <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00524"></a><span class="lineno">  524</span>&#160;        }</div>
<div class="line"><a name="l00525"></a><span class="lineno">  525</span>&#160;        <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00526"></a><span class="lineno">  526</span>&#160;            <a class="code" href="../../d4/d71/st_8c.html#abd2051b6b857de0a4b8aec12043fe005">unpack_entries</a>(table);</div>
<div class="line"><a name="l00527"></a><span class="lineno">  527</span>&#160;        }</div>
<div class="line"><a name="l00528"></a><span class="lineno">  528</span>&#160;    }</div>
<div class="line"><a name="l00529"></a><span class="lineno">  529</span>&#160;</div>
<div class="line"><a name="l00530"></a><span class="lineno">  530</span>&#160;    hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(key, table);</div>
<div class="line"><a name="l00531"></a><span class="lineno">  531</span>&#160;    bin_pos = hash_val % table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>;</div>
<div class="line"><a name="l00532"></a><span class="lineno">  532</span>&#160;    <a class="code" href="../../d4/d71/st_8c.html#a2adf90985f6ca4ecff6def2304d3d2dd">ADD_DIRECT</a>(table, key, value, hash_val, bin_pos);</div>
<div class="line"><a name="l00533"></a><span class="lineno">  533</span>&#160;}</div>
<div class="line"><a name="l00534"></a><span class="lineno">  534</span>&#160;</div>
<div class="line"><a name="l00535"></a><span class="lineno">  535</span>&#160;<span class="keyword">static</span> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00536"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a78898e934706b6d8fb8ffc7b598a0408">  536</a></span>&#160;<a class="code" href="../../d4/d71/st_8c.html#ae79a2e19d2287b6ac8d9a82f5c423a1c">rehash</a>(<span class="keyword">register</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table)</div>
<div class="line"><a name="l00537"></a><span class="lineno">  537</span>&#160;{</div>
<div class="line"><a name="l00538"></a><span class="lineno">  538</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>, **new_bins;</div>
<div class="line"><a name="l00539"></a><span class="lineno">  539</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>, new_num_bins, hash_val;</div>
<div class="line"><a name="l00540"></a><span class="lineno">  540</span>&#160;</div>
<div class="line"><a name="l00541"></a><span class="lineno">  541</span>&#160;    new_num_bins = <a class="code" href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a">new_size</a>(table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>+1);</div>
<div class="line"><a name="l00542"></a><span class="lineno">  542</span>&#160;    new_bins = (<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>**)</div>
<div class="line"><a name="l00543"></a><span class="lineno">  543</span>&#160;        <a class="code" href="../../d8/db0/defines_8h.html#a40740062faf2d95d4935112447c464ef">xrealloc</a>(table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, new_num_bins * <span class="keyword">sizeof</span>(<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*));</div>
<div class="line"><a name="l00544"></a><span class="lineno">  544</span>&#160;    <span class="keywordflow">for</span> (i = 0; i &lt; new_num_bins; ++<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>) new_bins[i] = 0;</div>
<div class="line"><a name="l00545"></a><span class="lineno">  545</span>&#160;    table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a> = new_num_bins;</div>
<div class="line"><a name="l00546"></a><span class="lineno">  546</span>&#160;    table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> = new_bins;</div>
<div class="line"><a name="l00547"></a><span class="lineno">  547</span>&#160;</div>
<div class="line"><a name="l00548"></a><span class="lineno">  548</span>&#160;    <span class="keywordflow">if</span> ((ptr = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>) != 0) {</div>
<div class="line"><a name="l00549"></a><span class="lineno">  549</span>&#160;        <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00550"></a><span class="lineno">  550</span>&#160;            hash_val = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % new_num_bins;</div>
<div class="line"><a name="l00551"></a><span class="lineno">  551</span>&#160;            ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a> = new_bins[hash_val];</div>
<div class="line"><a name="l00552"></a><span class="lineno">  552</span>&#160;            new_bins[hash_val] = <a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00553"></a><span class="lineno">  553</span>&#160;        } <span class="keywordflow">while</span> ((ptr = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>) != 0);</div>
<div class="line"><a name="l00554"></a><span class="lineno">  554</span>&#160;    }</div>
<div class="line"><a name="l00555"></a><span class="lineno">  555</span>&#160;}</div>
<div class="line"><a name="l00556"></a><span class="lineno">  556</span>&#160;</div>
<div class="line"><a name="l00557"></a><span class="lineno">  557</span>&#160;<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div>
<div class="line"><a name="l00558"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1fe53fe235ae6db0c7abe49413785363">  558</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a0cf4ec3779291117380260d7c3579d6c">st_copy</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *old_table)</div>
<div class="line"><a name="l00559"></a><span class="lineno">  559</span>&#160;{</div>
<div class="line"><a name="l00560"></a><span class="lineno">  560</span>&#160;    <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *new_table;</div>
<div class="line"><a name="l00561"></a><span class="lineno">  561</span>&#160;    <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>, *entry, *prev, **tail;</div>
<div class="line"><a name="l00562"></a><span class="lineno">  562</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> num_bins = old_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>;</div>
<div class="line"><a name="l00563"></a><span class="lineno">  563</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div>
<div class="line"><a name="l00564"></a><span class="lineno">  564</span>&#160;</div>
<div class="line"><a name="l00565"></a><span class="lineno">  565</span>&#160;    new_table = <a class="code" href="../../d4/d71/st_8c.html#a385b96996caa48e6349681cf8036322f">alloc</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a>);</div>
<div class="line"><a name="l00566"></a><span class="lineno">  566</span>&#160;    <span class="keywordflow">if</span> (new_table == 0) {</div>
<div class="line"><a name="l00567"></a><span class="lineno">  567</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00568"></a><span class="lineno">  568</span>&#160;    }</div>
<div class="line"><a name="l00569"></a><span class="lineno">  569</span>&#160;</div>
<div class="line"><a name="l00570"></a><span class="lineno">  570</span>&#160;    *new_table = *old_table;</div>
<div class="line"><a name="l00571"></a><span class="lineno">  571</span>&#160;    new_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> = (<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>**)</div>
<div class="line"><a name="l00572"></a><span class="lineno">  572</span>&#160;        <a class="code" href="../../d4/d71/st_8c.html#a94c395161bf80ffa3b1d224ad3542f11">Calloc</a>((<span class="keywordtype">unsigned</span>)num_bins, <span class="keyword">sizeof</span>(<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*));</div>
<div class="line"><a name="l00573"></a><span class="lineno">  573</span>&#160;</div>
<div class="line"><a name="l00574"></a><span class="lineno">  574</span>&#160;    <span class="keywordflow">if</span> (new_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> == 0) {</div>
<div class="line"><a name="l00575"></a><span class="lineno">  575</span>&#160;        <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(new_table);</div>
<div class="line"><a name="l00576"></a><span class="lineno">  576</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00577"></a><span class="lineno">  577</span>&#160;    }</div>
<div class="line"><a name="l00578"></a><span class="lineno">  578</span>&#160;</div>
<div class="line"><a name="l00579"></a><span class="lineno">  579</span>&#160;    <span class="keywordflow">if</span> (old_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00580"></a><span class="lineno">  580</span>&#160;        <a class="code" href="../../d5/d9d/tcltklib_8c.html#a7aa3ca79548709bc580aa259ad1fd2d2">memcpy</a>(new_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, old_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, <span class="keyword">sizeof</span>(<span class="keyword">struct</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *) * old_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div>
<div class="line"><a name="l00581"></a><span class="lineno">  581</span>&#160;        <span class="keywordflow">return</span> new_table;</div>
<div class="line"><a name="l00582"></a><span class="lineno">  582</span>&#160;    }</div>
<div class="line"><a name="l00583"></a><span class="lineno">  583</span>&#160;</div>
<div class="line"><a name="l00584"></a><span class="lineno">  584</span>&#160;    <span class="keywordflow">if</span> ((ptr = old_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>) != 0) {</div>
<div class="line"><a name="l00585"></a><span class="lineno">  585</span>&#160;        prev = 0;</div>
<div class="line"><a name="l00586"></a><span class="lineno">  586</span>&#160;        tail = &amp;new_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>;</div>
<div class="line"><a name="l00587"></a><span class="lineno">  587</span>&#160;        <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00588"></a><span class="lineno">  588</span>&#160;            entry = <a class="code" href="../../d4/d71/st_8c.html#a385b96996caa48e6349681cf8036322f">alloc</a>(<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>);</div>
<div class="line"><a name="l00589"></a><span class="lineno">  589</span>&#160;            <span class="keywordflow">if</span> (entry == 0) {</div>
<div class="line"><a name="l00590"></a><span class="lineno">  590</span>&#160;                <a class="code" href="../../d6/d87/regint_8h.html#ae0adede5868e71009c620a32a7b9d61e">st_free_table</a>(new_table);</div>
<div class="line"><a name="l00591"></a><span class="lineno">  591</span>&#160;                <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00592"></a><span class="lineno">  592</span>&#160;            }</div>
<div class="line"><a name="l00593"></a><span class="lineno">  593</span>&#160;            *entry = *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00594"></a><span class="lineno">  594</span>&#160;            hash_val = entry-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % num_bins;</div>
<div class="line"><a name="l00595"></a><span class="lineno">  595</span>&#160;            entry-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a> = new_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val];</div>
<div class="line"><a name="l00596"></a><span class="lineno">  596</span>&#160;            new_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val] = entry;</div>
<div class="line"><a name="l00597"></a><span class="lineno">  597</span>&#160;            entry-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a> = prev;</div>
<div class="line"><a name="l00598"></a><span class="lineno">  598</span>&#160;            *tail = prev = entry;</div>
<div class="line"><a name="l00599"></a><span class="lineno">  599</span>&#160;            tail = &amp;entry-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div>
<div class="line"><a name="l00600"></a><span class="lineno">  600</span>&#160;        } <span class="keywordflow">while</span> ((ptr = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>) != 0);</div>
<div class="line"><a name="l00601"></a><span class="lineno">  601</span>&#160;        new_table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = prev;</div>
<div class="line"><a name="l00602"></a><span class="lineno">  602</span>&#160;    }</div>
<div class="line"><a name="l00603"></a><span class="lineno">  603</span>&#160;</div>
<div class="line"><a name="l00604"></a><span class="lineno">  604</span>&#160;    <span class="keywordflow">return</span> new_table;</div>
<div class="line"><a name="l00605"></a><span class="lineno">  605</span>&#160;}</div>
<div class="line"><a name="l00606"></a><span class="lineno">  606</span>&#160;</div>
<div class="line"><a name="l00607"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#afbf658274f1e8229ce3efad9b1eb11d3">  607</a></span>&#160;<span class="preprocessor">#define REMOVE_ENTRY(table, ptr) do                                     \</span></div>
<div class="line"><a name="l00608"></a><span class="lineno">  608</span>&#160;<span class="preprocessor">    {                                                                   \</span></div>
<div class="line"><a name="l00609"></a><span class="lineno">  609</span>&#160;<span class="preprocessor">        if ((ptr)-&gt;fore == 0 &amp;&amp; (ptr)-&gt;back == 0) {                     \</span></div>
<div class="line"><a name="l00610"></a><span class="lineno">  610</span>&#160;<span class="preprocessor">            (table)-&gt;head = 0;                                          \</span></div>
<div class="line"><a name="l00611"></a><span class="lineno">  611</span>&#160;<span class="preprocessor">            (table)-&gt;tail = 0;                                          \</span></div>
<div class="line"><a name="l00612"></a><span class="lineno">  612</span>&#160;<span class="preprocessor">        }                                                               \</span></div>
<div class="line"><a name="l00613"></a><span class="lineno">  613</span>&#160;<span class="preprocessor">        else {                                                          \</span></div>
<div class="line"><a name="l00614"></a><span class="lineno">  614</span>&#160;<span class="preprocessor">            st_table_entry *fore = (ptr)-&gt;fore, *back = (ptr)-&gt;back;    \</span></div>
<div class="line"><a name="l00615"></a><span class="lineno">  615</span>&#160;<span class="preprocessor">            if (fore) fore-&gt;back = back;                                \</span></div>
<div class="line"><a name="l00616"></a><span class="lineno">  616</span>&#160;<span class="preprocessor">            if (back) back-&gt;fore = fore;                                \</span></div>
<div class="line"><a name="l00617"></a><span class="lineno">  617</span>&#160;<span class="preprocessor">            if ((ptr) == (table)-&gt;head) (table)-&gt;head = fore;           \</span></div>
<div class="line"><a name="l00618"></a><span class="lineno">  618</span>&#160;<span class="preprocessor">            if ((ptr) == (table)-&gt;tail) (table)-&gt;tail = back;           \</span></div>
<div class="line"><a name="l00619"></a><span class="lineno">  619</span>&#160;<span class="preprocessor">        }                                                               \</span></div>
<div class="line"><a name="l00620"></a><span class="lineno">  620</span>&#160;<span class="preprocessor">        (table)-&gt;num_entries--;                                         \</span></div>
<div class="line"><a name="l00621"></a><span class="lineno">  621</span>&#160;<span class="preprocessor">    } while (0)</span></div>
<div class="line"><a name="l00622"></a><span class="lineno">  622</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00623"></a><span class="lineno">  623</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00624"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a376a6db1416fd2edb1ce72ad624ff109">  624</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#aa77af2b7839fb6d01facdc86fdd69544">st_delete</a>(<span class="keyword">register</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <span class="keyword">register</span> <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> *key, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> *value)</div>
<div class="line"><a name="l00625"></a><span class="lineno">  625</span>&#160;{</div>
<div class="line"><a name="l00626"></a><span class="lineno">  626</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div>
<div class="line"><a name="l00627"></a><span class="lineno">  627</span>&#160;    <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> **prev;</div>
<div class="line"><a name="l00628"></a><span class="lineno">  628</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00629"></a><span class="lineno">  629</span>&#160;</div>
<div class="line"><a name="l00630"></a><span class="lineno">  630</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00631"></a><span class="lineno">  631</span>&#160;        <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00632"></a><span class="lineno">  632</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; i++) {</div>
<div class="line"><a name="l00633"></a><span class="lineno">  633</span>&#160;            <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] == *key) {</div>
<div class="line"><a name="l00634"></a><span class="lineno">  634</span>&#160;                <span class="keywordflow">if</span> (value != 0) *value = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1];</div>
<div class="line"><a name="l00635"></a><span class="lineno">  635</span>&#160;                table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div>
<div class="line"><a name="l00636"></a><span class="lineno">  636</span>&#160;                <a class="code" href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a>(&amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2], &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[(i+1)*2],</div>
<div class="line"><a name="l00637"></a><span class="lineno">  637</span>&#160;                        <span class="keyword">sizeof</span>(<span class="keyword">struct </span><a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*) * 2*(table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>-i));</div>
<div class="line"><a name="l00638"></a><span class="lineno">  638</span>&#160;                <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00639"></a><span class="lineno">  639</span>&#160;            }</div>
<div class="line"><a name="l00640"></a><span class="lineno">  640</span>&#160;        }</div>
<div class="line"><a name="l00641"></a><span class="lineno">  641</span>&#160;        <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00642"></a><span class="lineno">  642</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00643"></a><span class="lineno">  643</span>&#160;    }</div>
<div class="line"><a name="l00644"></a><span class="lineno">  644</span>&#160;</div>
<div class="line"><a name="l00645"></a><span class="lineno">  645</span>&#160;    hash_val = <a class="code" href="../../d4/d71/st_8c.html#a2e66e2285d7393eca0aea2eac98b8ded">do_hash_bin</a>(*key, table);</div>
<div class="line"><a name="l00646"></a><span class="lineno">  646</span>&#160;</div>
<div class="line"><a name="l00647"></a><span class="lineno">  647</span>&#160;    <span class="keywordflow">for</span> (prev = &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val]; (ptr = *prev) != 0; prev = &amp;ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div>
<div class="line"><a name="l00648"></a><span class="lineno">  648</span>&#160;        <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867">EQUAL</a>(table, *key, ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>)) {</div>
<div class="line"><a name="l00649"></a><span class="lineno">  649</span>&#160;            *prev = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div>
<div class="line"><a name="l00650"></a><span class="lineno">  650</span>&#160;            <a class="code" href="../../d4/d71/st_8c.html#afbf658274f1e8229ce3efad9b1eb11d3">REMOVE_ENTRY</a>(table, ptr);</div>
<div class="line"><a name="l00651"></a><span class="lineno">  651</span>&#160;            <span class="keywordflow">if</span> (value != 0) *value = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>;</div>
<div class="line"><a name="l00652"></a><span class="lineno">  652</span>&#160;            *key = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div>
<div class="line"><a name="l00653"></a><span class="lineno">  653</span>&#160;            <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(ptr);</div>
<div class="line"><a name="l00654"></a><span class="lineno">  654</span>&#160;            <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00655"></a><span class="lineno">  655</span>&#160;        }</div>
<div class="line"><a name="l00656"></a><span class="lineno">  656</span>&#160;    }</div>
<div class="line"><a name="l00657"></a><span class="lineno">  657</span>&#160;</div>
<div class="line"><a name="l00658"></a><span class="lineno">  658</span>&#160;    <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00659"></a><span class="lineno">  659</span>&#160;    <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00660"></a><span class="lineno">  660</span>&#160;}</div>
<div class="line"><a name="l00661"></a><span class="lineno">  661</span>&#160;</div>
<div class="line"><a name="l00662"></a><span class="lineno">  662</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00663"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aaafeee841b664f0ea14b28e7e1b1a71a">  663</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a00eac09dbce81822a60fc5a7c42cd9ff">st_delete_safe</a>(<span class="keyword">register</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <span class="keyword">register</span> <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> *key, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> *value, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> never)</div>
<div class="line"><a name="l00664"></a><span class="lineno">  664</span>&#160;{</div>
<div class="line"><a name="l00665"></a><span class="lineno">  665</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div>
<div class="line"><a name="l00666"></a><span class="lineno">  666</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00667"></a><span class="lineno">  667</span>&#160;</div>
<div class="line"><a name="l00668"></a><span class="lineno">  668</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00669"></a><span class="lineno">  669</span>&#160;        <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00670"></a><span class="lineno">  670</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; i++) {</div>
<div class="line"><a name="l00671"></a><span class="lineno">  671</span>&#160;            <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] == *key) {</div>
<div class="line"><a name="l00672"></a><span class="lineno">  672</span>&#160;                <span class="keywordflow">if</span> (value != 0) *value = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1];</div>
<div class="line"><a name="l00673"></a><span class="lineno">  673</span>&#160;                table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] = (<span class="keywordtype">void</span> *)never;</div>
<div class="line"><a name="l00674"></a><span class="lineno">  674</span>&#160;                <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00675"></a><span class="lineno">  675</span>&#160;            }</div>
<div class="line"><a name="l00676"></a><span class="lineno">  676</span>&#160;        }</div>
<div class="line"><a name="l00677"></a><span class="lineno">  677</span>&#160;        <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00678"></a><span class="lineno">  678</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00679"></a><span class="lineno">  679</span>&#160;    }</div>
<div class="line"><a name="l00680"></a><span class="lineno">  680</span>&#160;</div>
<div class="line"><a name="l00681"></a><span class="lineno">  681</span>&#160;    hash_val = <a class="code" href="../../d4/d71/st_8c.html#a2e66e2285d7393eca0aea2eac98b8ded">do_hash_bin</a>(*key, table);</div>
<div class="line"><a name="l00682"></a><span class="lineno">  682</span>&#160;    ptr = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val];</div>
<div class="line"><a name="l00683"></a><span class="lineno">  683</span>&#160;</div>
<div class="line"><a name="l00684"></a><span class="lineno">  684</span>&#160;    <span class="keywordflow">for</span> (; ptr != 0; ptr = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div>
<div class="line"><a name="l00685"></a><span class="lineno">  685</span>&#160;        <span class="keywordflow">if</span> ((ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a> != never) &amp;&amp; <a class="code" href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867">EQUAL</a>(table, ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>, *key)) {</div>
<div class="line"><a name="l00686"></a><span class="lineno">  686</span>&#160;            <a class="code" href="../../d4/d71/st_8c.html#afbf658274f1e8229ce3efad9b1eb11d3">REMOVE_ENTRY</a>(table, ptr);</div>
<div class="line"><a name="l00687"></a><span class="lineno">  687</span>&#160;            *key = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div>
<div class="line"><a name="l00688"></a><span class="lineno">  688</span>&#160;            <span class="keywordflow">if</span> (value != 0) *value = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>;</div>
<div class="line"><a name="l00689"></a><span class="lineno">  689</span>&#160;            ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a> = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a> = never;</div>
<div class="line"><a name="l00690"></a><span class="lineno">  690</span>&#160;            <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00691"></a><span class="lineno">  691</span>&#160;        }</div>
<div class="line"><a name="l00692"></a><span class="lineno">  692</span>&#160;    }</div>
<div class="line"><a name="l00693"></a><span class="lineno">  693</span>&#160;</div>
<div class="line"><a name="l00694"></a><span class="lineno">  694</span>&#160;    <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00695"></a><span class="lineno">  695</span>&#160;    <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00696"></a><span class="lineno">  696</span>&#160;}</div>
<div class="line"><a name="l00697"></a><span class="lineno">  697</span>&#160;</div>
<div class="line"><a name="l00698"></a><span class="lineno">  698</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00699"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aa98339af92fd08445ea0683805843bd9">  699</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#aed6c9d02c64512b18cd464930cb866e1">st_shift</a>(<span class="keyword">register</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <span class="keyword">register</span> <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> *key, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> *value)</div>
<div class="line"><a name="l00700"></a><span class="lineno">  700</span>&#160;{</div>
<div class="line"><a name="l00701"></a><span class="lineno">  701</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div>
<div class="line"><a name="l00702"></a><span class="lineno">  702</span>&#160;    <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> **prev;</div>
<div class="line"><a name="l00703"></a><span class="lineno">  703</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00704"></a><span class="lineno">  704</span>&#160;</div>
<div class="line"><a name="l00705"></a><span class="lineno">  705</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> == 0) {</div>
<div class="line"><a name="l00706"></a><span class="lineno">  706</span>&#160;        <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00707"></a><span class="lineno">  707</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00708"></a><span class="lineno">  708</span>&#160;    }</div>
<div class="line"><a name="l00709"></a><span class="lineno">  709</span>&#160;</div>
<div class="line"><a name="l00710"></a><span class="lineno">  710</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00711"></a><span class="lineno">  711</span>&#160;        <span class="keywordflow">if</span> (value != 0) *value = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[1];</div>
<div class="line"><a name="l00712"></a><span class="lineno">  712</span>&#160;        *key = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[0];</div>
<div class="line"><a name="l00713"></a><span class="lineno">  713</span>&#160;        table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div>
<div class="line"><a name="l00714"></a><span class="lineno">  714</span>&#160;        <a class="code" href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a>(&amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[0], &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[2],</div>
<div class="line"><a name="l00715"></a><span class="lineno">  715</span>&#160;                <span class="keyword">sizeof</span>(<span class="keyword">struct</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*) * 2*table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>);</div>
<div class="line"><a name="l00716"></a><span class="lineno">  716</span>&#160;        <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00717"></a><span class="lineno">  717</span>&#160;    }</div>
<div class="line"><a name="l00718"></a><span class="lineno">  718</span>&#160;</div>
<div class="line"><a name="l00719"></a><span class="lineno">  719</span>&#160;    hash_val = <a class="code" href="../../d4/d71/st_8c.html#a2e66e2285d7393eca0aea2eac98b8ded">do_hash_bin</a>(table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>, table);</div>
<div class="line"><a name="l00720"></a><span class="lineno">  720</span>&#160;    prev = &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val];</div>
<div class="line"><a name="l00721"></a><span class="lineno">  721</span>&#160;    <span class="keywordflow">for</span> (;(ptr = *prev) != 0; prev = &amp;ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div>
<div class="line"><a name="l00722"></a><span class="lineno">  722</span>&#160;        <span class="keywordflow">if</span> (ptr == table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>) {</div>
<div class="line"><a name="l00723"></a><span class="lineno">  723</span>&#160;            *prev = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div>
<div class="line"><a name="l00724"></a><span class="lineno">  724</span>&#160;            <a class="code" href="../../d4/d71/st_8c.html#afbf658274f1e8229ce3efad9b1eb11d3">REMOVE_ENTRY</a>(table, ptr);</div>
<div class="line"><a name="l00725"></a><span class="lineno">  725</span>&#160;            <span class="keywordflow">if</span> (value != 0) *value = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>;</div>
<div class="line"><a name="l00726"></a><span class="lineno">  726</span>&#160;            *key = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div>
<div class="line"><a name="l00727"></a><span class="lineno">  727</span>&#160;            <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(ptr);</div>
<div class="line"><a name="l00728"></a><span class="lineno">  728</span>&#160;            <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00729"></a><span class="lineno">  729</span>&#160;        }</div>
<div class="line"><a name="l00730"></a><span class="lineno">  730</span>&#160;    }</div>
<div class="line"><a name="l00731"></a><span class="lineno">  731</span>&#160;</div>
<div class="line"><a name="l00732"></a><span class="lineno">  732</span>&#160;    <span class="comment">/* if hash is not consistent and need to be rehashed */</span></div>
<div class="line"><a name="l00733"></a><span class="lineno">  733</span>&#160;    <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00734"></a><span class="lineno">  734</span>&#160;    <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00735"></a><span class="lineno">  735</span>&#160;}</div>
<div class="line"><a name="l00736"></a><span class="lineno">  736</span>&#160;</div>
<div class="line"><a name="l00737"></a><span class="lineno">  737</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00738"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a3fde5a76b3fc28787b7350eaf790676b">  738</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a6477fd60857602de7863fc715badfd0d">st_cleanup_safe</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> never)</div>
<div class="line"><a name="l00739"></a><span class="lineno">  739</span>&#160;{</div>
<div class="line"><a name="l00740"></a><span class="lineno">  740</span>&#160;    <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>, **<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>, *tmp;</div>
<div class="line"><a name="l00741"></a><span class="lineno">  741</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00742"></a><span class="lineno">  742</span>&#160;</div>
<div class="line"><a name="l00743"></a><span class="lineno">  743</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00744"></a><span class="lineno">  744</span>&#160;        <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = 0, j = 0;</div>
<div class="line"><a name="l00745"></a><span class="lineno">  745</span>&#160;        <span class="keywordflow">while</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] != never) {</div>
<div class="line"><a name="l00746"></a><span class="lineno">  746</span>&#160;            <span class="keywordflow">if</span> (i++ == table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>) <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00747"></a><span class="lineno">  747</span>&#160;        }</div>
<div class="line"><a name="l00748"></a><span class="lineno">  748</span>&#160;        <span class="keywordflow">for</span> (j = i; ++i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>;) {</div>
<div class="line"><a name="l00749"></a><span class="lineno">  749</span>&#160;            <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2] == never) <span class="keywordflow">continue</span>;</div>
<div class="line"><a name="l00750"></a><span class="lineno">  750</span>&#160;            table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[j*2] = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2];</div>
<div class="line"><a name="l00751"></a><span class="lineno">  751</span>&#160;            table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[j*2+1] = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1];</div>
<div class="line"><a name="l00752"></a><span class="lineno">  752</span>&#160;            j++;</div>
<div class="line"><a name="l00753"></a><span class="lineno">  753</span>&#160;        }</div>
<div class="line"><a name="l00754"></a><span class="lineno">  754</span>&#160;        table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = j;</div>
<div class="line"><a name="l00755"></a><span class="lineno">  755</span>&#160;        <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00756"></a><span class="lineno">  756</span>&#160;    }</div>
<div class="line"><a name="l00757"></a><span class="lineno">  757</span>&#160;</div>
<div class="line"><a name="l00758"></a><span class="lineno">  758</span>&#160;    <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>; i++) {</div>
<div class="line"><a name="l00759"></a><span class="lineno">  759</span>&#160;        ptr = *(last = &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[<a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>]);</div>
<div class="line"><a name="l00760"></a><span class="lineno">  760</span>&#160;        <span class="keywordflow">while</span> (ptr != 0) {</div>
<div class="line"><a name="l00761"></a><span class="lineno">  761</span>&#160;            <span class="keywordflow">if</span> (ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a> == never) {</div>
<div class="line"><a name="l00762"></a><span class="lineno">  762</span>&#160;                tmp = <a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l00763"></a><span class="lineno">  763</span>&#160;                *last = ptr = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div>
<div class="line"><a name="l00764"></a><span class="lineno">  764</span>&#160;                <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(tmp);</div>
<div class="line"><a name="l00765"></a><span class="lineno">  765</span>&#160;            }</div>
<div class="line"><a name="l00766"></a><span class="lineno">  766</span>&#160;            <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00767"></a><span class="lineno">  767</span>&#160;                ptr = *(last = &amp;ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>);</div>
<div class="line"><a name="l00768"></a><span class="lineno">  768</span>&#160;            }</div>
<div class="line"><a name="l00769"></a><span class="lineno">  769</span>&#160;        }</div>
<div class="line"><a name="l00770"></a><span class="lineno">  770</span>&#160;    }</div>
<div class="line"><a name="l00771"></a><span class="lineno">  771</span>&#160;}</div>
<div class="line"><a name="l00772"></a><span class="lineno">  772</span>&#160;</div>
<div class="line"><a name="l00773"></a><span class="lineno">  773</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l00774"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#accc02c609f11fe0cad4061ff19f09b9a">  774</a></span>&#160;<a class="code" href="../../d6/d87/regint_8h.html#a4a2fef263bb8fa14faff2a3222a407dd">st_foreach</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <span class="keywordtype">int</span> (*<a class="code" href="../../dc/dd1/ossl__ssl_8c.html#a33775ffa49b921f1647bfac2850c6298">func</a>)(<a class="code" href="../../d8/db0/defines_8h.html#af4fd7cbafda9af704310f78516042dfb">ANYARGS</a>), <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>)</div>
<div class="line"><a name="l00775"></a><span class="lineno">  775</span>&#160;{</div>
<div class="line"><a name="l00776"></a><span class="lineno">  776</span>&#160;    <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>, **<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>, *tmp;</div>
<div class="line"><a name="l00777"></a><span class="lineno">  777</span>&#160;    <span class="keyword">enum</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1f">st_retval</a> <a class="code" href="../../d5/d9d/tcltklib_8c.html#ae3ed9756fe65ccdbec5dc78d6f3422dc">retval</a>;</div>
<div class="line"><a name="l00778"></a><span class="lineno">  778</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00779"></a><span class="lineno">  779</span>&#160;</div>
<div class="line"><a name="l00780"></a><span class="lineno">  780</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00781"></a><span class="lineno">  781</span>&#160;        <span class="keywordflow">for</span> (i = 0; i &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; i++) {</div>
<div class="line"><a name="l00782"></a><span class="lineno">  782</span>&#160;            <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> j;</div>
<div class="line"><a name="l00783"></a><span class="lineno">  783</span>&#160;            <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../d5/d11/ripper_8c.html#a68fefa607ad528d20b0ae5d69a346d46">val</a>;</div>
<div class="line"><a name="l00784"></a><span class="lineno">  784</span>&#160;            key = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2];</div>
<div class="line"><a name="l00785"></a><span class="lineno">  785</span>&#160;            val = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1];</div>
<div class="line"><a name="l00786"></a><span class="lineno">  786</span>&#160;            retval = (*func)(<a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../d5/d11/ripper_8c.html#a68fefa607ad528d20b0ae5d69a346d46">val</a>, <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>);</div>
<div class="line"><a name="l00787"></a><span class="lineno">  787</span>&#160;            <span class="keywordflow">if</span> (!table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00788"></a><span class="lineno">  788</span>&#160;                <a class="code" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">FIND_ENTRY</a>(table, ptr, key, i);</div>
<div class="line"><a name="l00789"></a><span class="lineno">  789</span>&#160;                <span class="keywordflow">if</span> (retval == <a class="code" href="../../d9/dee/tkutil_8c.html#ab3379c8db8c1bbea65e45f218b70e807">ST_CHECK</a>) {</div>
<div class="line"><a name="l00790"></a><span class="lineno">  790</span>&#160;                    <span class="keywordflow">if</span> (!ptr) <span class="keywordflow">goto</span> deleted;</div>
<div class="line"><a name="l00791"></a><span class="lineno">  791</span>&#160;                    <span class="keywordflow">goto</span> unpacked_continue;</div>
<div class="line"><a name="l00792"></a><span class="lineno">  792</span>&#160;                }</div>
<div class="line"><a name="l00793"></a><span class="lineno">  793</span>&#160;                <span class="keywordflow">goto</span> unpacked;</div>
<div class="line"><a name="l00794"></a><span class="lineno">  794</span>&#160;            }</div>
<div class="line"><a name="l00795"></a><span class="lineno">  795</span>&#160;            <span class="keywordflow">switch</span> (retval) {</div>
<div class="line"><a name="l00796"></a><span class="lineno">  796</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../d9/dee/tkutil_8c.html#ab3379c8db8c1bbea65e45f218b70e807">ST_CHECK</a>:    <span class="comment">/* check if hash is modified during iteration */</span></div>
<div class="line"><a name="l00797"></a><span class="lineno">  797</span>&#160;                <span class="keywordflow">for</span> (j = 0; j &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; j++) {</div>
<div class="line"><a name="l00798"></a><span class="lineno">  798</span>&#160;                    <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[j*2] == key)</div>
<div class="line"><a name="l00799"></a><span class="lineno">  799</span>&#160;                        <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00800"></a><span class="lineno">  800</span>&#160;                }</div>
<div class="line"><a name="l00801"></a><span class="lineno">  801</span>&#160;                <span class="keywordflow">if</span> (j == table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>) {</div>
<div class="line"><a name="l00802"></a><span class="lineno">  802</span>&#160;                    <span class="keywordflow">goto</span> deleted;</div>
<div class="line"><a name="l00803"></a><span class="lineno">  803</span>&#160;                }</div>
<div class="line"><a name="l00804"></a><span class="lineno">  804</span>&#160;                <span class="comment">/* fall through */</span></div>
<div class="line"><a name="l00805"></a><span class="lineno">  805</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../d9/dee/tkutil_8c.html#aa6e13b966bc7c446c09941d17bd42e05">ST_CONTINUE</a>:</div>
<div class="line"><a name="l00806"></a><span class="lineno">  806</span>&#160;                <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00807"></a><span class="lineno">  807</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa04b939c166d4baa471909eb224d5fed3">ST_STOP</a>:</div>
<div class="line"><a name="l00808"></a><span class="lineno">  808</span>&#160;                <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00809"></a><span class="lineno">  809</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa64ab176f8e8b9719bcd9b5297ccda9c7">ST_DELETE</a>:</div>
<div class="line"><a name="l00810"></a><span class="lineno">  810</span>&#160;                table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div>
<div class="line"><a name="l00811"></a><span class="lineno">  811</span>&#160;                <a class="code" href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a>(&amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2], &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[(i+1)*2],</div>
<div class="line"><a name="l00812"></a><span class="lineno">  812</span>&#160;                        <span class="keyword">sizeof</span>(<span class="keyword">struct</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*) * 2*(table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>-i));</div>
<div class="line"><a name="l00813"></a><span class="lineno">  813</span>&#160;                i--;</div>
<div class="line"><a name="l00814"></a><span class="lineno">  814</span>&#160;                <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00815"></a><span class="lineno">  815</span>&#160;            }</div>
<div class="line"><a name="l00816"></a><span class="lineno">  816</span>&#160;        }</div>
<div class="line"><a name="l00817"></a><span class="lineno">  817</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00818"></a><span class="lineno">  818</span>&#160;    }</div>
<div class="line"><a name="l00819"></a><span class="lineno">  819</span>&#160;    <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00820"></a><span class="lineno">  820</span>&#160;        ptr = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>;</div>
<div class="line"><a name="l00821"></a><span class="lineno">  821</span>&#160;    }</div>
<div class="line"><a name="l00822"></a><span class="lineno">  822</span>&#160;</div>
<div class="line"><a name="l00823"></a><span class="lineno">  823</span>&#160;    <span class="keywordflow">if</span> (ptr != 0) {</div>
<div class="line"><a name="l00824"></a><span class="lineno">  824</span>&#160;        <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00825"></a><span class="lineno">  825</span>&#160;            i = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>;</div>
<div class="line"><a name="l00826"></a><span class="lineno">  826</span>&#160;            retval = (*func)(ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>, ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>, <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>);</div>
<div class="line"><a name="l00827"></a><span class="lineno">  827</span>&#160;          unpacked:</div>
<div class="line"><a name="l00828"></a><span class="lineno">  828</span>&#160;            <span class="keywordflow">switch</span> (retval) {</div>
<div class="line"><a name="l00829"></a><span class="lineno">  829</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../d9/dee/tkutil_8c.html#ab3379c8db8c1bbea65e45f218b70e807">ST_CHECK</a>:    <span class="comment">/* check if hash is modified during iteration */</span></div>
<div class="line"><a name="l00830"></a><span class="lineno">  830</span>&#160;                <span class="keywordflow">for</span> (tmp = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i]; tmp != ptr; tmp = tmp-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div>
<div class="line"><a name="l00831"></a><span class="lineno">  831</span>&#160;                    <span class="keywordflow">if</span> (!tmp) {</div>
<div class="line"><a name="l00832"></a><span class="lineno">  832</span>&#160;                      deleted:</div>
<div class="line"><a name="l00833"></a><span class="lineno">  833</span>&#160;                        <span class="comment">/* call func with error notice */</span></div>
<div class="line"><a name="l00834"></a><span class="lineno">  834</span>&#160;                        retval = (*func)(0, 0, <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>, 1);</div>
<div class="line"><a name="l00835"></a><span class="lineno">  835</span>&#160;                        <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00836"></a><span class="lineno">  836</span>&#160;                    }</div>
<div class="line"><a name="l00837"></a><span class="lineno">  837</span>&#160;                }</div>
<div class="line"><a name="l00838"></a><span class="lineno">  838</span>&#160;                <span class="comment">/* fall through */</span></div>
<div class="line"><a name="l00839"></a><span class="lineno">  839</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../d9/dee/tkutil_8c.html#aa6e13b966bc7c446c09941d17bd42e05">ST_CONTINUE</a>:</div>
<div class="line"><a name="l00840"></a><span class="lineno">  840</span>&#160;              unpacked_continue:</div>
<div class="line"><a name="l00841"></a><span class="lineno">  841</span>&#160;                ptr = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div>
<div class="line"><a name="l00842"></a><span class="lineno">  842</span>&#160;                <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00843"></a><span class="lineno">  843</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa04b939c166d4baa471909eb224d5fed3">ST_STOP</a>:</div>
<div class="line"><a name="l00844"></a><span class="lineno">  844</span>&#160;                <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00845"></a><span class="lineno">  845</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa64ab176f8e8b9719bcd9b5297ccda9c7">ST_DELETE</a>:</div>
<div class="line"><a name="l00846"></a><span class="lineno">  846</span>&#160;                last = &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>];</div>
<div class="line"><a name="l00847"></a><span class="lineno">  847</span>&#160;                <span class="keywordflow">for</span> (; (tmp = *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>) != 0; last = &amp;tmp-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div>
<div class="line"><a name="l00848"></a><span class="lineno">  848</span>&#160;                    <span class="keywordflow">if</span> (ptr == tmp) {</div>
<div class="line"><a name="l00849"></a><span class="lineno">  849</span>&#160;                        tmp = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div>
<div class="line"><a name="l00850"></a><span class="lineno">  850</span>&#160;                        *last = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div>
<div class="line"><a name="l00851"></a><span class="lineno">  851</span>&#160;                        <a class="code" href="../../d4/d71/st_8c.html#afbf658274f1e8229ce3efad9b1eb11d3">REMOVE_ENTRY</a>(table, ptr);</div>
<div class="line"><a name="l00852"></a><span class="lineno">  852</span>&#160;                        <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(ptr);</div>
<div class="line"><a name="l00853"></a><span class="lineno">  853</span>&#160;                        <span class="keywordflow">if</span> (ptr == tmp) <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00854"></a><span class="lineno">  854</span>&#160;                        ptr = tmp;</div>
<div class="line"><a name="l00855"></a><span class="lineno">  855</span>&#160;                        <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00856"></a><span class="lineno">  856</span>&#160;                    }</div>
<div class="line"><a name="l00857"></a><span class="lineno">  857</span>&#160;                }</div>
<div class="line"><a name="l00858"></a><span class="lineno">  858</span>&#160;            }</div>
<div class="line"><a name="l00859"></a><span class="lineno">  859</span>&#160;        } <span class="keywordflow">while</span> (ptr &amp;&amp; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>);</div>
<div class="line"><a name="l00860"></a><span class="lineno">  860</span>&#160;    }</div>
<div class="line"><a name="l00861"></a><span class="lineno">  861</span>&#160;    <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00862"></a><span class="lineno">  862</span>&#160;}</div>
<div class="line"><a name="l00863"></a><span class="lineno">  863</span>&#160;</div>
<div class="line"><a name="l00864"></a><span class="lineno">  864</span>&#160;<span class="preprocessor">#if 0  </span><span class="comment">/* unused right now */</span><span class="preprocessor"></span></div>
<div class="line"><a name="l00865"></a><span class="lineno">  865</span>&#160;<span class="preprocessor"></span><span class="keywordtype">int</span></div>
<div class="line"><a name="l00866"></a><span class="lineno">  866</span>&#160;<a class="code" href="../../dd/d24/st_8h.html#ad7c52b70fe389bc967a1868c76a1e10c">st_reverse_foreach</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <span class="keywordtype">int</span> (*<a class="code" href="../../dc/dd1/ossl__ssl_8c.html#a33775ffa49b921f1647bfac2850c6298">func</a>)(<a class="code" href="../../d8/db0/defines_8h.html#af4fd7cbafda9af704310f78516042dfb">ANYARGS</a>), <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>)</div>
<div class="line"><a name="l00867"></a><span class="lineno">  867</span>&#160;{</div>
<div class="line"><a name="l00868"></a><span class="lineno">  868</span>&#160;    <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *<a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>, **<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>, *tmp;</div>
<div class="line"><a name="l00869"></a><span class="lineno">  869</span>&#160;    <span class="keyword">enum</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1f">st_retval</a> <a class="code" href="../../d5/d9d/tcltklib_8c.html#ae3ed9756fe65ccdbec5dc78d6f3422dc">retval</a>;</div>
<div class="line"><a name="l00870"></a><span class="lineno">  870</span>&#160;    <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l00871"></a><span class="lineno">  871</span>&#160;</div>
<div class="line"><a name="l00872"></a><span class="lineno">  872</span>&#160;    <span class="keywordflow">if</span> (table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div>
<div class="line"><a name="l00873"></a><span class="lineno">  873</span>&#160;        <span class="keywordflow">for</span> (i = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>-1; 0 &lt;= i; i--) {</div>
<div class="line"><a name="l00874"></a><span class="lineno">  874</span>&#160;            <span class="keywordtype">int</span> j;</div>
<div class="line"><a name="l00875"></a><span class="lineno">  875</span>&#160;            <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../d5/d11/ripper_8c.html#a68fefa607ad528d20b0ae5d69a346d46">val</a>;</div>
<div class="line"><a name="l00876"></a><span class="lineno">  876</span>&#160;            key = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2];</div>
<div class="line"><a name="l00877"></a><span class="lineno">  877</span>&#160;            val = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2+1];</div>
<div class="line"><a name="l00878"></a><span class="lineno">  878</span>&#160;            retval = (*func)(<a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>, <a class="code" href="../../d5/d11/ripper_8c.html#a68fefa607ad528d20b0ae5d69a346d46">val</a>, <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>);</div>
<div class="line"><a name="l00879"></a><span class="lineno">  879</span>&#160;            <span class="keywordflow">switch</span> (retval) {</div>
<div class="line"><a name="l00880"></a><span class="lineno">  880</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../d9/dee/tkutil_8c.html#ab3379c8db8c1bbea65e45f218b70e807">ST_CHECK</a>:    <span class="comment">/* check if hash is modified during iteration */</span></div>
<div class="line"><a name="l00881"></a><span class="lineno">  881</span>&#160;                <span class="keywordflow">for</span> (j = 0; j &lt; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>; j++) {</div>
<div class="line"><a name="l00882"></a><span class="lineno">  882</span>&#160;                    <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[j*2] == <a class="code" href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a>)</div>
<div class="line"><a name="l00883"></a><span class="lineno">  883</span>&#160;                        <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00884"></a><span class="lineno">  884</span>&#160;                }</div>
<div class="line"><a name="l00885"></a><span class="lineno">  885</span>&#160;                <span class="keywordflow">if</span> (j == table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>) {</div>
<div class="line"><a name="l00886"></a><span class="lineno">  886</span>&#160;                    <span class="comment">/* call func with error notice */</span></div>
<div class="line"><a name="l00887"></a><span class="lineno">  887</span>&#160;                    retval = (*func)(0, 0, <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>, 1);</div>
<div class="line"><a name="l00888"></a><span class="lineno">  888</span>&#160;                    <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00889"></a><span class="lineno">  889</span>&#160;                }</div>
<div class="line"><a name="l00890"></a><span class="lineno">  890</span>&#160;                <span class="comment">/* fall through */</span></div>
<div class="line"><a name="l00891"></a><span class="lineno">  891</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../d9/dee/tkutil_8c.html#aa6e13b966bc7c446c09941d17bd42e05">ST_CONTINUE</a>:</div>
<div class="line"><a name="l00892"></a><span class="lineno">  892</span>&#160;                <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00893"></a><span class="lineno">  893</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa04b939c166d4baa471909eb224d5fed3">ST_STOP</a>:</div>
<div class="line"><a name="l00894"></a><span class="lineno">  894</span>&#160;                <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00895"></a><span class="lineno">  895</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa64ab176f8e8b9719bcd9b5297ccda9c7">ST_DELETE</a>:</div>
<div class="line"><a name="l00896"></a><span class="lineno">  896</span>&#160;                table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div>
<div class="line"><a name="l00897"></a><span class="lineno">  897</span>&#160;                <a class="code" href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a>(&amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2], &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[(i+1)*2],</div>
<div class="line"><a name="l00898"></a><span class="lineno">  898</span>&#160;                        <span class="keyword">sizeof</span>(<span class="keyword">struct</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*) * 2*(table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>-i));</div>
<div class="line"><a name="l00899"></a><span class="lineno">  899</span>&#160;                <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00900"></a><span class="lineno">  900</span>&#160;            }</div>
<div class="line"><a name="l00901"></a><span class="lineno">  901</span>&#160;        }</div>
<div class="line"><a name="l00902"></a><span class="lineno">  902</span>&#160;        <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00903"></a><span class="lineno">  903</span>&#160;    }</div>
<div class="line"><a name="l00904"></a><span class="lineno">  904</span>&#160;</div>
<div class="line"><a name="l00905"></a><span class="lineno">  905</span>&#160;    <span class="keywordflow">if</span> ((ptr = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>) != 0) {</div>
<div class="line"><a name="l00906"></a><span class="lineno">  906</span>&#160;        ptr = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div>
<div class="line"><a name="l00907"></a><span class="lineno">  907</span>&#160;        <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00908"></a><span class="lineno">  908</span>&#160;            retval = (*func)(ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>, ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>, <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>, 0);</div>
<div class="line"><a name="l00909"></a><span class="lineno">  909</span>&#160;            <span class="keywordflow">switch</span> (retval) {</div>
<div class="line"><a name="l00910"></a><span class="lineno">  910</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../d9/dee/tkutil_8c.html#ab3379c8db8c1bbea65e45f218b70e807">ST_CHECK</a>:    <span class="comment">/* check if hash is modified during iteration */</span></div>
<div class="line"><a name="l00911"></a><span class="lineno">  911</span>&#160;                i = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>;</div>
<div class="line"><a name="l00912"></a><span class="lineno">  912</span>&#160;                <span class="keywordflow">for</span> (tmp = table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i]; tmp != ptr; tmp = tmp-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div>
<div class="line"><a name="l00913"></a><span class="lineno">  913</span>&#160;                    <span class="keywordflow">if</span> (!tmp) {</div>
<div class="line"><a name="l00914"></a><span class="lineno">  914</span>&#160;                        <span class="comment">/* call func with error notice */</span></div>
<div class="line"><a name="l00915"></a><span class="lineno">  915</span>&#160;                        retval = (*func)(0, 0, <a class="code" href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a>, 1);</div>
<div class="line"><a name="l00916"></a><span class="lineno">  916</span>&#160;                        <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00917"></a><span class="lineno">  917</span>&#160;                    }</div>
<div class="line"><a name="l00918"></a><span class="lineno">  918</span>&#160;                }</div>
<div class="line"><a name="l00919"></a><span class="lineno">  919</span>&#160;                <span class="comment">/* fall through */</span></div>
<div class="line"><a name="l00920"></a><span class="lineno">  920</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../d9/dee/tkutil_8c.html#aa6e13b966bc7c446c09941d17bd42e05">ST_CONTINUE</a>:</div>
<div class="line"><a name="l00921"></a><span class="lineno">  921</span>&#160;                ptr = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div>
<div class="line"><a name="l00922"></a><span class="lineno">  922</span>&#160;                <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00923"></a><span class="lineno">  923</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa04b939c166d4baa471909eb224d5fed3">ST_STOP</a>:</div>
<div class="line"><a name="l00924"></a><span class="lineno">  924</span>&#160;                <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00925"></a><span class="lineno">  925</span>&#160;              <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa64ab176f8e8b9719bcd9b5297ccda9c7">ST_DELETE</a>:</div>
<div class="line"><a name="l00926"></a><span class="lineno">  926</span>&#160;                last = &amp;table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>];</div>
<div class="line"><a name="l00927"></a><span class="lineno">  927</span>&#160;                <span class="keywordflow">for</span> (; (tmp = *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>) != 0; last = &amp;tmp-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div>
<div class="line"><a name="l00928"></a><span class="lineno">  928</span>&#160;                    <span class="keywordflow">if</span> (ptr == tmp) {</div>
<div class="line"><a name="l00929"></a><span class="lineno">  929</span>&#160;                        tmp = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div>
<div class="line"><a name="l00930"></a><span class="lineno">  930</span>&#160;                        *last = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div>
<div class="line"><a name="l00931"></a><span class="lineno">  931</span>&#160;                        <a class="code" href="../../d4/d71/st_8c.html#afbf658274f1e8229ce3efad9b1eb11d3">REMOVE_ENTRY</a>(table, ptr);</div>
<div class="line"><a name="l00932"></a><span class="lineno">  932</span>&#160;                        <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(ptr);</div>
<div class="line"><a name="l00933"></a><span class="lineno">  933</span>&#160;                        ptr = tmp;</div>
<div class="line"><a name="l00934"></a><span class="lineno">  934</span>&#160;                        <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00935"></a><span class="lineno">  935</span>&#160;                    }</div>
<div class="line"><a name="l00936"></a><span class="lineno">  936</span>&#160;                }</div>
<div class="line"><a name="l00937"></a><span class="lineno">  937</span>&#160;                ptr = ptr-&gt;<a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div>
<div class="line"><a name="l00938"></a><span class="lineno">  938</span>&#160;                <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(tmp);</div>
<div class="line"><a name="l00939"></a><span class="lineno">  939</span>&#160;                table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div>
<div class="line"><a name="l00940"></a><span class="lineno">  940</span>&#160;            }</div>
<div class="line"><a name="l00941"></a><span class="lineno">  941</span>&#160;        } <span class="keywordflow">while</span> (ptr &amp;&amp; table-&gt;<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>);</div>
<div class="line"><a name="l00942"></a><span class="lineno">  942</span>&#160;    }</div>
<div class="line"><a name="l00943"></a><span class="lineno">  943</span>&#160;    <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00944"></a><span class="lineno">  944</span>&#160;}</div>
<div class="line"><a name="l00945"></a><span class="lineno">  945</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00946"></a><span class="lineno">  946</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l00947"></a><span class="lineno">  947</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l00948"></a><span class="lineno">  948</span>&#160;<span class="comment"> * hash_32 - 32 bit Fowler/Noll/Vo FNV-1a hash code</span></div>
<div class="line"><a name="l00949"></a><span class="lineno">  949</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00950"></a><span class="lineno">  950</span>&#160;<span class="comment"> * @(#) $Hash32: Revision: 1.1 $</span></div>
<div class="line"><a name="l00951"></a><span class="lineno">  951</span>&#160;<span class="comment"> * @(#) $Hash32: Id: hash_32a.c,v 1.1 2003/10/03 20:38:53 chongo Exp $</span></div>
<div class="line"><a name="l00952"></a><span class="lineno">  952</span>&#160;<span class="comment"> * @(#) $Hash32: Source: /usr/local/src/cmd/fnv/RCS/hash_32a.c,v $</span></div>
<div class="line"><a name="l00953"></a><span class="lineno">  953</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00954"></a><span class="lineno">  954</span>&#160;<span class="comment"> ***</span></div>
<div class="line"><a name="l00955"></a><span class="lineno">  955</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00956"></a><span class="lineno">  956</span>&#160;<span class="comment"> * Fowler/Noll/Vo hash</span></div>
<div class="line"><a name="l00957"></a><span class="lineno">  957</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00958"></a><span class="lineno">  958</span>&#160;<span class="comment"> * The basis of this hash algorithm was taken from an idea sent</span></div>
<div class="line"><a name="l00959"></a><span class="lineno">  959</span>&#160;<span class="comment"> * as reviewer comments to the IEEE POSIX P1003.2 committee by:</span></div>
<div class="line"><a name="l00960"></a><span class="lineno">  960</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00961"></a><span class="lineno">  961</span>&#160;<span class="comment"> *      Phong Vo (http://www.research.att.com/info/kpv/)</span></div>
<div class="line"><a name="l00962"></a><span class="lineno">  962</span>&#160;<span class="comment"> *      Glenn Fowler (http://www.research.att.com/~gsf/)</span></div>
<div class="line"><a name="l00963"></a><span class="lineno">  963</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00964"></a><span class="lineno">  964</span>&#160;<span class="comment"> * In a subsequent ballot round:</span></div>
<div class="line"><a name="l00965"></a><span class="lineno">  965</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00966"></a><span class="lineno">  966</span>&#160;<span class="comment"> *      Landon Curt Noll (http://www.isthe.com/chongo/)</span></div>
<div class="line"><a name="l00967"></a><span class="lineno">  967</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00968"></a><span class="lineno">  968</span>&#160;<span class="comment"> * improved on their algorithm.  Some people tried this hash</span></div>
<div class="line"><a name="l00969"></a><span class="lineno">  969</span>&#160;<span class="comment"> * and found that it worked rather well.  In an EMail message</span></div>
<div class="line"><a name="l00970"></a><span class="lineno">  970</span>&#160;<span class="comment"> * to Landon, they named it the ``Fowler/Noll/Vo&#39;&#39; or FNV hash.</span></div>
<div class="line"><a name="l00971"></a><span class="lineno">  971</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00972"></a><span class="lineno">  972</span>&#160;<span class="comment"> * FNV hashes are designed to be fast while maintaining a low</span></div>
<div class="line"><a name="l00973"></a><span class="lineno">  973</span>&#160;<span class="comment"> * collision rate. The FNV speed allows one to quickly hash lots</span></div>
<div class="line"><a name="l00974"></a><span class="lineno">  974</span>&#160;<span class="comment"> * of data while maintaining a reasonable collision rate.  See:</span></div>
<div class="line"><a name="l00975"></a><span class="lineno">  975</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00976"></a><span class="lineno">  976</span>&#160;<span class="comment"> *      http://www.isthe.com/chongo/tech/comp/fnv/index.html</span></div>
<div class="line"><a name="l00977"></a><span class="lineno">  977</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00978"></a><span class="lineno">  978</span>&#160;<span class="comment"> * for more details as well as other forms of the FNV hash.</span></div>
<div class="line"><a name="l00979"></a><span class="lineno">  979</span>&#160;<span class="comment"> ***</span></div>
<div class="line"><a name="l00980"></a><span class="lineno">  980</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00981"></a><span class="lineno">  981</span>&#160;<span class="comment"> * To use the recommended 32 bit FNV-1a hash, pass FNV1_32A_INIT as the</span></div>
<div class="line"><a name="l00982"></a><span class="lineno">  982</span>&#160;<span class="comment"> * Fnv32_t hashval argument to fnv_32a_buf() or fnv_32a_str().</span></div>
<div class="line"><a name="l00983"></a><span class="lineno">  983</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00984"></a><span class="lineno">  984</span>&#160;<span class="comment"> ***</span></div>
<div class="line"><a name="l00985"></a><span class="lineno">  985</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00986"></a><span class="lineno">  986</span>&#160;<span class="comment"> * Please do not copyright this code.  This code is in the public domain.</span></div>
<div class="line"><a name="l00987"></a><span class="lineno">  987</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00988"></a><span class="lineno">  988</span>&#160;<span class="comment"> * LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,</span></div>
<div class="line"><a name="l00989"></a><span class="lineno">  989</span>&#160;<span class="comment"> * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO</span></div>
<div class="line"><a name="l00990"></a><span class="lineno">  990</span>&#160;<span class="comment"> * EVENT SHALL LANDON CURT NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR</span></div>
<div class="line"><a name="l00991"></a><span class="lineno">  991</span>&#160;<span class="comment"> * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF</span></div>
<div class="line"><a name="l00992"></a><span class="lineno">  992</span>&#160;<span class="comment"> * USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR</span></div>
<div class="line"><a name="l00993"></a><span class="lineno">  993</span>&#160;<span class="comment"> * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR</span></div>
<div class="line"><a name="l00994"></a><span class="lineno">  994</span>&#160;<span class="comment"> * PERFORMANCE OF THIS SOFTWARE.</span></div>
<div class="line"><a name="l00995"></a><span class="lineno">  995</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l00996"></a><span class="lineno">  996</span>&#160;<span class="comment"> * By:</span></div>
<div class="line"><a name="l00997"></a><span class="lineno">  997</span>&#160;<span class="comment"> *      chongo &lt;Landon Curt Noll&gt; /\oo/\</span></div>
<div class="line"><a name="l00998"></a><span class="lineno">  998</span>&#160;<span class="comment"> *      http://www.isthe.com/chongo/</span></div>
<div class="line"><a name="l00999"></a><span class="lineno">  999</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l01000"></a><span class="lineno"> 1000</span>&#160;<span class="comment"> * Share and Enjoy!     :-)</span></div>
<div class="line"><a name="l01001"></a><span class="lineno"> 1001</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l01002"></a><span class="lineno"> 1002</span>&#160;</div>
<div class="line"><a name="l01003"></a><span class="lineno"> 1003</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l01004"></a><span class="lineno"> 1004</span>&#160;<span class="comment"> * 32 bit FNV-1 and FNV-1a non-zero initial basis</span></div>
<div class="line"><a name="l01005"></a><span class="lineno"> 1005</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l01006"></a><span class="lineno"> 1006</span>&#160;<span class="comment"> * The FNV-1 initial basis is the FNV-0 hash of the following 32 octets:</span></div>
<div class="line"><a name="l01007"></a><span class="lineno"> 1007</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l01008"></a><span class="lineno"> 1008</span>&#160;<span class="comment"> *              chongo &lt;Landon Curt Noll&gt; /\../\</span></div>
<div class="line"><a name="l01009"></a><span class="lineno"> 1009</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l01010"></a><span class="lineno"> 1010</span>&#160;<span class="comment"> * NOTE: The \&#39;s above are not back-slashing escape characters.</span></div>
<div class="line"><a name="l01011"></a><span class="lineno"> 1011</span>&#160;<span class="comment"> * They are literal ASCII  backslash 0x5c characters.</span></div>
<div class="line"><a name="l01012"></a><span class="lineno"> 1012</span>&#160;<span class="comment"> *</span></div>
<div class="line"><a name="l01013"></a><span class="lineno"> 1013</span>&#160;<span class="comment"> * NOTE: The FNV-1a initial basis is the same value as FNV-1 by definition.</span></div>
<div class="line"><a name="l01014"></a><span class="lineno"> 1014</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l01015"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a40a142ccb9ca21d50ea9f6ed8589cc96"> 1015</a></span>&#160;<span class="preprocessor">#define FNV1_32A_INIT 0x811c9dc5</span></div>
<div class="line"><a name="l01016"></a><span class="lineno"> 1016</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01017"></a><span class="lineno"> 1017</span>&#160;<span class="comment">/*</span></div>
<div class="line"><a name="l01018"></a><span class="lineno"> 1018</span>&#160;<span class="comment"> * 32 bit magic FNV-1a prime</span></div>
<div class="line"><a name="l01019"></a><span class="lineno"> 1019</span>&#160;<span class="comment"> */</span></div>
<div class="line"><a name="l01020"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae13a6565bea334e9b6fb19033a392857"> 1020</a></span>&#160;<span class="preprocessor">#define FNV_32_PRIME 0x01000193</span></div>
<div class="line"><a name="l01021"></a><span class="lineno"> 1021</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01022"></a><span class="lineno"> 1022</span>&#160;<span class="preprocessor">#ifdef ST_USE_FNV1</span></div>
<div class="line"><a name="l01023"></a><span class="lineno"> 1023</span>&#160;<span class="preprocessor"></span><span class="keyword">static</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01024"></a><span class="lineno"> 1024</span>&#160;<a class="code" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7">strhash</a>(<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> arg)</div>
<div class="line"><a name="l01025"></a><span class="lineno"> 1025</span>&#160;{</div>
<div class="line"><a name="l01026"></a><span class="lineno"> 1026</span>&#160;    <span class="keyword">register</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *<span class="keywordtype">string</span> = (<span class="keyword">const</span> <span class="keywordtype">char</span> *)arg;</div>
<div class="line"><a name="l01027"></a><span class="lineno"> 1027</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d3/deb/lex_8c.html#afc4c7aea01574edcf6289eb0e999b889">hval</a> = <a class="code" href="../../d4/d71/st_8c.html#a40a142ccb9ca21d50ea9f6ed8589cc96">FNV1_32A_INIT</a>;</div>
<div class="line"><a name="l01028"></a><span class="lineno"> 1028</span>&#160;</div>
<div class="line"><a name="l01029"></a><span class="lineno"> 1029</span>&#160;    <span class="comment">/*</span></div>
<div class="line"><a name="l01030"></a><span class="lineno"> 1030</span>&#160;<span class="comment">     * FNV-1a hash each octet in the buffer</span></div>
<div class="line"><a name="l01031"></a><span class="lineno"> 1031</span>&#160;<span class="comment">     */</span></div>
<div class="line"><a name="l01032"></a><span class="lineno"> 1032</span>&#160;    <span class="keywordflow">while</span> (*<span class="keywordtype">string</span>) {</div>
<div class="line"><a name="l01033"></a><span class="lineno"> 1033</span>&#160;        <span class="comment">/* xor the bottom with the current octet */</span></div>
<div class="line"><a name="l01034"></a><span class="lineno"> 1034</span>&#160;        hval ^= (<span class="keywordtype">unsigned</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#accd5e629f58868c52137db996aaf8b83">int</a>)*<span class="keywordtype">string</span>++;</div>
<div class="line"><a name="l01035"></a><span class="lineno"> 1035</span>&#160;</div>
<div class="line"><a name="l01036"></a><span class="lineno"> 1036</span>&#160;        <span class="comment">/* multiply by the 32 bit FNV magic prime mod 2^32 */</span></div>
<div class="line"><a name="l01037"></a><span class="lineno"> 1037</span>&#160;        hval *= <a class="code" href="../../d4/d71/st_8c.html#ae13a6565bea334e9b6fb19033a392857">FNV_32_PRIME</a>;</div>
<div class="line"><a name="l01038"></a><span class="lineno"> 1038</span>&#160;    }</div>
<div class="line"><a name="l01039"></a><span class="lineno"> 1039</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d3/deb/lex_8c.html#afc4c7aea01574edcf6289eb0e999b889">hval</a>;</div>
<div class="line"><a name="l01040"></a><span class="lineno"> 1040</span>&#160;}</div>
<div class="line"><a name="l01041"></a><span class="lineno"> 1041</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l01042"></a><span class="lineno"> 1042</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01043"></a><span class="lineno"> 1043</span>&#160;<span class="preprocessor">#ifndef UNALIGNED_WORD_ACCESS</span></div>
<div class="line"><a name="l01044"></a><span class="lineno"> 1044</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># if defined(__i386) || defined(__i386__) || defined(_M_IX86) || \</span></div>
<div class="line"><a name="l01045"></a><span class="lineno"> 1045</span>&#160;<span class="preprocessor">     defined(__x86_64) || defined(__x86_64__) || defined(_M_AMD86) || \</span></div>
<div class="line"><a name="l01046"></a><span class="lineno"> 1046</span>&#160;<span class="preprocessor">     defined(__mc68020__)</span></div>
<div class="line"><a name="l01047"></a><span class="lineno"> 1047</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#   define UNALIGNED_WORD_ACCESS 1</span></div>
<div class="line"><a name="l01048"></a><span class="lineno"> 1048</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># endif</span></div>
<div class="line"><a name="l01049"></a><span class="lineno"> 1049</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01050"></a><span class="lineno"> 1050</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#ifndef UNALIGNED_WORD_ACCESS</span></div>
<div class="line"><a name="l01051"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a0383aadd3cd4f433220552852e96568e"> 1051</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor"># define UNALIGNED_WORD_ACCESS 0</span></div>
<div class="line"><a name="l01052"></a><span class="lineno"> 1052</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01053"></a><span class="lineno"> 1053</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01054"></a><span class="lineno"> 1054</span>&#160;<span class="comment">/* MurmurHash described in http://murmurhash.googlepages.com/ */</span></div>
<div class="line"><a name="l01055"></a><span class="lineno"> 1055</span>&#160;<span class="preprocessor">#ifndef MURMUR</span></div>
<div class="line"><a name="l01056"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aa92335ab2ca6139b94c65caee53d1627"> 1056</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define MURMUR 2</span></div>
<div class="line"><a name="l01057"></a><span class="lineno"> 1057</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01058"></a><span class="lineno"> 1058</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01059"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a923df315411e52498828f7cde38e5c87"> 1059</a></span>&#160;<span class="preprocessor">#define MurmurMagic_1 (st_index_t)0xc6a4a793</span></div>
<div class="line"><a name="l01060"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a99b9e759614d31ea6adc4b777aedd30e"> 1060</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define MurmurMagic_2 (st_index_t)0x5bd1e995</span></div>
<div class="line"><a name="l01061"></a><span class="lineno"> 1061</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01062"></a><span class="lineno"> 1062</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define MurmurMagic MurmurMagic_1</span></div>
<div class="line"><a name="l01063"></a><span class="lineno"> 1063</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#elif MURMUR == 2</span></div>
<div class="line"><a name="l01064"></a><span class="lineno"> 1064</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T &gt; 4</span></div>
<div class="line"><a name="l01065"></a><span class="lineno"> 1065</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define MurmurMagic ((MurmurMagic_1 &lt;&lt; 32) | MurmurMagic_2)</span></div>
<div class="line"><a name="l01066"></a><span class="lineno"> 1066</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01067"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd"> 1067</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define MurmurMagic MurmurMagic_2</span></div>
<div class="line"><a name="l01068"></a><span class="lineno"> 1068</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01069"></a><span class="lineno"> 1069</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01070"></a><span class="lineno"> 1070</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01071"></a><span class="lineno"> 1071</span>&#160;<span class="keyword">static</span> <span class="keyword">inline</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01072"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a6f8bc2a6eef7714715e56451ed32521c"> 1072</a></span>&#160;<a class="code" href="../../d4/d71/st_8c.html#a6f8bc2a6eef7714715e56451ed32521c">murmur</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> h, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> k, <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#a514f1b439f404f86f77090fa9edc96ce">r</a>)</div>
<div class="line"><a name="l01073"></a><span class="lineno"> 1073</span>&#160;{</div>
<div class="line"><a name="l01074"></a><span class="lineno"> 1074</span>&#160;    <span class="keyword">const</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#ae524ec6ce1980bec6f25676783609004">m</a> = <a class="code" href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd">MurmurMagic</a>;</div>
<div class="line"><a name="l01075"></a><span class="lineno"> 1075</span>&#160;<span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01076"></a><span class="lineno"> 1076</span>&#160;<span class="preprocessor"></span>    h += k;</div>
<div class="line"><a name="l01077"></a><span class="lineno"> 1077</span>&#160;    h *= <a class="code" href="../../de/d07/bigdecimal_8c.html#ae524ec6ce1980bec6f25676783609004">m</a>;</div>
<div class="line"><a name="l01078"></a><span class="lineno"> 1078</span>&#160;    h ^= h &gt;&gt; <a class="code" href="../../de/d07/bigdecimal_8c.html#a514f1b439f404f86f77090fa9edc96ce">r</a>;</div>
<div class="line"><a name="l01079"></a><span class="lineno"> 1079</span>&#160;<span class="preprocessor">#elif MURMUR == 2</span></div>
<div class="line"><a name="l01080"></a><span class="lineno"> 1080</span>&#160;<span class="preprocessor"></span>    k *= <a class="code" href="../../de/d07/bigdecimal_8c.html#ae524ec6ce1980bec6f25676783609004">m</a>;</div>
<div class="line"><a name="l01081"></a><span class="lineno"> 1081</span>&#160;    k ^= k &gt;&gt; <a class="code" href="../../de/d07/bigdecimal_8c.html#a514f1b439f404f86f77090fa9edc96ce">r</a>;</div>
<div class="line"><a name="l01082"></a><span class="lineno"> 1082</span>&#160;    k *= <a class="code" href="../../de/d07/bigdecimal_8c.html#ae524ec6ce1980bec6f25676783609004">m</a>;</div>
<div class="line"><a name="l01083"></a><span class="lineno"> 1083</span>&#160;</div>
<div class="line"><a name="l01084"></a><span class="lineno"> 1084</span>&#160;    h *= <a class="code" href="../../de/d07/bigdecimal_8c.html#ae524ec6ce1980bec6f25676783609004">m</a>;</div>
<div class="line"><a name="l01085"></a><span class="lineno"> 1085</span>&#160;    h ^= k;</div>
<div class="line"><a name="l01086"></a><span class="lineno"> 1086</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01087"></a><span class="lineno"> 1087</span>&#160;<span class="preprocessor"></span>    <span class="keywordflow">return</span> h;</div>
<div class="line"><a name="l01088"></a><span class="lineno"> 1088</span>&#160;}</div>
<div class="line"><a name="l01089"></a><span class="lineno"> 1089</span>&#160;</div>
<div class="line"><a name="l01090"></a><span class="lineno"> 1090</span>&#160;<span class="keyword">static</span> <span class="keyword">inline</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01091"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a7319d13cc614204b9b40b6c022d5f911"> 1091</a></span>&#160;<a class="code" href="../../d4/d71/st_8c.html#a7319d13cc614204b9b40b6c022d5f911">murmur_finish</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> h)</div>
<div class="line"><a name="l01092"></a><span class="lineno"> 1092</span>&#160;{</div>
<div class="line"><a name="l01093"></a><span class="lineno"> 1093</span>&#160;<span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01094"></a><span class="lineno"> 1094</span>&#160;<span class="preprocessor"></span>    h = <a class="code" href="../../d4/d71/st_8c.html#a6f8bc2a6eef7714715e56451ed32521c">murmur</a>(h, 0, 10);</div>
<div class="line"><a name="l01095"></a><span class="lineno"> 1095</span>&#160;    h = <a class="code" href="../../d4/d71/st_8c.html#a6f8bc2a6eef7714715e56451ed32521c">murmur</a>(h, 0, 17);</div>
<div class="line"><a name="l01096"></a><span class="lineno"> 1096</span>&#160;<span class="preprocessor">#elif MURMUR == 2</span></div>
<div class="line"><a name="l01097"></a><span class="lineno"> 1097</span>&#160;<span class="preprocessor"></span>    h ^= h &gt;&gt; 13;</div>
<div class="line"><a name="l01098"></a><span class="lineno"> 1098</span>&#160;    h *= <a class="code" href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd">MurmurMagic</a>;</div>
<div class="line"><a name="l01099"></a><span class="lineno"> 1099</span>&#160;    h ^= h &gt;&gt; 15;</div>
<div class="line"><a name="l01100"></a><span class="lineno"> 1100</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01101"></a><span class="lineno"> 1101</span>&#160;<span class="preprocessor"></span>    <span class="keywordflow">return</span> h;</div>
<div class="line"><a name="l01102"></a><span class="lineno"> 1102</span>&#160;}</div>
<div class="line"><a name="l01103"></a><span class="lineno"> 1103</span>&#160;</div>
<div class="line"><a name="l01104"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538"> 1104</a></span>&#160;<span class="preprocessor">#define murmur_step(h, k) murmur((h), (k), 16)</span></div>
<div class="line"><a name="l01105"></a><span class="lineno"> 1105</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01106"></a><span class="lineno"> 1106</span>&#160;<span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01107"></a><span class="lineno"> 1107</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define murmur1(h) murmur_step((h), 16)</span></div>
<div class="line"><a name="l01108"></a><span class="lineno"> 1108</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01109"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528"> 1109</a></span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define murmur1(h) murmur_step((h), 24)</span></div>
<div class="line"><a name="l01110"></a><span class="lineno"> 1110</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01111"></a><span class="lineno"> 1111</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01112"></a><span class="lineno"> 1112</span>&#160;<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01113"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a970b36e65b43e8fcccbea3e3397aeefa"> 1113</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a970b36e65b43e8fcccbea3e3397aeefa">st_hash</a>(<span class="keyword">const</span> <span class="keywordtype">void</span> *ptr, <span class="keywordtype">size_t</span> <a class="code" href="../../d3/d15/name2ctype_8h.html#aed1cc4dca5d94cb452f79691f54f7423">len</a>, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> h)</div>
<div class="line"><a name="l01114"></a><span class="lineno"> 1114</span>&#160;{</div>
<div class="line"><a name="l01115"></a><span class="lineno"> 1115</span>&#160;    <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="../../dd/dfb/yaml2byte_8c.html#a735984d41155bc1032e09bece8f8d66d">data</a> = <a class="code" href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a>;</div>
<div class="line"><a name="l01116"></a><span class="lineno"> 1116</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a> = 0;</div>
<div class="line"><a name="l01117"></a><span class="lineno"> 1117</span>&#160;</div>
<div class="line"><a name="l01118"></a><span class="lineno"> 1118</span>&#160;    h += 0xdeadbeef;</div>
<div class="line"><a name="l01119"></a><span class="lineno"> 1119</span>&#160;</div>
<div class="line"><a name="l01120"></a><span class="lineno"> 1120</span>&#160;<span class="preprocessor">#define data_at(n) (st_index_t)((unsigned char)data[(n)])</span></div>
<div class="line"><a name="l01121"></a><span class="lineno"> 1121</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define UNALIGNED_ADD_4 UNALIGNED_ADD(2); UNALIGNED_ADD(1); UNALIGNED_ADD(0)</span></div>
<div class="line"><a name="l01122"></a><span class="lineno"> 1122</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T &gt; 4</span></div>
<div class="line"><a name="l01123"></a><span class="lineno"> 1123</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define UNALIGNED_ADD_8 UNALIGNED_ADD(6); UNALIGNED_ADD(5); UNALIGNED_ADD(4); UNALIGNED_ADD(3); UNALIGNED_ADD_4</span></div>
<div class="line"><a name="l01124"></a><span class="lineno"> 1124</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T &gt; 8</span></div>
<div class="line"><a name="l01125"></a><span class="lineno"> 1125</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define UNALIGNED_ADD_16 UNALIGNED_ADD(14); UNALIGNED_ADD(13); UNALIGNED_ADD(12); UNALIGNED_ADD(11); \</span></div>
<div class="line"><a name="l01126"></a><span class="lineno"> 1126</span>&#160;<span class="preprocessor">    UNALIGNED_ADD(10); UNALIGNED_ADD(9); UNALIGNED_ADD(8); UNALIGNED_ADD(7); UNALIGNED_ADD_8</span></div>
<div class="line"><a name="l01127"></a><span class="lineno"> 1127</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define UNALIGNED_ADD_ALL UNALIGNED_ADD_16</span></div>
<div class="line"><a name="l01128"></a><span class="lineno"> 1128</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01129"></a><span class="lineno"> 1129</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define UNALIGNED_ADD_ALL UNALIGNED_ADD_8</span></div>
<div class="line"><a name="l01130"></a><span class="lineno"> 1130</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01131"></a><span class="lineno"> 1131</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#define UNALIGNED_ADD_ALL UNALIGNED_ADD_4</span></div>
<div class="line"><a name="l01132"></a><span class="lineno"> 1132</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01133"></a><span class="lineno"> 1133</span>&#160;<span class="preprocessor"></span>    <span class="keywordflow">if</span> (len &gt;= <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>)) {</div>
<div class="line"><a name="l01134"></a><span class="lineno"> 1134</span>&#160;<span class="preprocessor">#if !UNALIGNED_WORD_ACCESS</span></div>
<div class="line"><a name="l01135"></a><span class="lineno"> 1135</span>&#160;<span class="preprocessor"></span>        <span class="keywordtype">int</span> align = (<a class="code" href="../../de/d07/bigdecimal_8c.html#accd5e629f58868c52137db996aaf8b83">int</a>)((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)data % <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>));</div>
<div class="line"><a name="l01136"></a><span class="lineno"> 1136</span>&#160;        <span class="keywordflow">if</span> (align) {</div>
<div class="line"><a name="l01137"></a><span class="lineno"> 1137</span>&#160;            <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d5/de6/strlcat_8c.html#a4baaf26ccdc71244db2410e8d4938e6a">d</a> = 0;</div>
<div class="line"><a name="l01138"></a><span class="lineno"> 1138</span>&#160;            <span class="keywordtype">int</span> sl, sr, pack;</div>
<div class="line"><a name="l01139"></a><span class="lineno"> 1139</span>&#160;</div>
<div class="line"><a name="l01140"></a><span class="lineno"> 1140</span>&#160;            <span class="keywordflow">switch</span> (align) {</div>
<div class="line"><a name="l01141"></a><span class="lineno"> 1141</span>&#160;<span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01142"></a><span class="lineno"> 1142</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># define UNALIGNED_ADD(n) case SIZEOF_ST_INDEX_T - (n) - 1: \</span></div>
<div class="line"><a name="l01143"></a><span class="lineno"> 1143</span>&#160;<span class="preprocessor">                t |= data_at(n) &lt;&lt; CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 2)</span></div>
<div class="line"><a name="l01144"></a><span class="lineno"> 1144</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01145"></a><span class="lineno"> 1145</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># define UNALIGNED_ADD(n) case SIZEOF_ST_INDEX_T - (n) - 1:     \</span></div>
<div class="line"><a name="l01146"></a><span class="lineno"> 1146</span>&#160;<span class="preprocessor">                t |= data_at(n) &lt;&lt; CHAR_BIT*(n)</span></div>
<div class="line"><a name="l01147"></a><span class="lineno"> 1147</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01148"></a><span class="lineno"> 1148</span>&#160;<span class="preprocessor"></span>                <a class="code" href="../../d4/d71/st_8c.html#a58449b17c56fb078b9f006f8ab3c5314">UNALIGNED_ADD_ALL</a>;</div>
<div class="line"><a name="l01149"></a><span class="lineno"> 1149</span>&#160;<span class="preprocessor">#undef UNALIGNED_ADD</span></div>
<div class="line"><a name="l01150"></a><span class="lineno"> 1150</span>&#160;<span class="preprocessor"></span>            }</div>
<div class="line"><a name="l01151"></a><span class="lineno"> 1151</span>&#160;</div>
<div class="line"><a name="l01152"></a><span class="lineno"> 1152</span>&#160;<span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01153"></a><span class="lineno"> 1153</span>&#160;<span class="preprocessor"></span>            t &gt;&gt;= (<a class="code" href="../../de/de6/ruby_2ruby_8h.html#a308d9dd2c0028ddb184b455bbd7865de">CHAR_BIT</a> * align) - <a class="code" href="../../de/de6/ruby_2ruby_8h.html#a308d9dd2c0028ddb184b455bbd7865de">CHAR_BIT</a>;</div>
<div class="line"><a name="l01154"></a><span class="lineno"> 1154</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l01155"></a><span class="lineno"> 1155</span>&#160;<span class="preprocessor"></span>            t &lt;&lt;= (<a class="code" href="../../de/de6/ruby_2ruby_8h.html#a308d9dd2c0028ddb184b455bbd7865de">CHAR_BIT</a> * align);</div>
<div class="line"><a name="l01156"></a><span class="lineno"> 1156</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01157"></a><span class="lineno"> 1157</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01158"></a><span class="lineno"> 1158</span>&#160;            data += <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>)-align;</div>
<div class="line"><a name="l01159"></a><span class="lineno"> 1159</span>&#160;            len -= <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>)-align;</div>
<div class="line"><a name="l01160"></a><span class="lineno"> 1160</span>&#160;</div>
<div class="line"><a name="l01161"></a><span class="lineno"> 1161</span>&#160;            sl = <a class="code" href="../../de/de6/ruby_2ruby_8h.html#a308d9dd2c0028ddb184b455bbd7865de">CHAR_BIT</a> * (<a class="code" href="../../dd/d24/st_8h.html#aa9a4938f87639b4d9a1c921f8ace1faa">SIZEOF_ST_INDEX_T</a>-align);</div>
<div class="line"><a name="l01162"></a><span class="lineno"> 1162</span>&#160;            sr = <a class="code" href="../../de/de6/ruby_2ruby_8h.html#a308d9dd2c0028ddb184b455bbd7865de">CHAR_BIT</a> * align;</div>
<div class="line"><a name="l01163"></a><span class="lineno"> 1163</span>&#160;</div>
<div class="line"><a name="l01164"></a><span class="lineno"> 1164</span>&#160;            <span class="keywordflow">while</span> (len &gt;= <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>)) {</div>
<div class="line"><a name="l01165"></a><span class="lineno"> 1165</span>&#160;                d = *(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> *)data;</div>
<div class="line"><a name="l01166"></a><span class="lineno"> 1166</span>&#160;<span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01167"></a><span class="lineno"> 1167</span>&#160;<span class="preprocessor"></span>                t = (t &lt;&lt; sr) | (d &gt;&gt; sl);</div>
<div class="line"><a name="l01168"></a><span class="lineno"> 1168</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l01169"></a><span class="lineno"> 1169</span>&#160;<span class="preprocessor"></span>                t = (t &gt;&gt; sr) | (d &lt;&lt; sl);</div>
<div class="line"><a name="l01170"></a><span class="lineno"> 1170</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01171"></a><span class="lineno"> 1171</span>&#160;<span class="preprocessor"></span>                h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, t);</div>
<div class="line"><a name="l01172"></a><span class="lineno"> 1172</span>&#160;                t = <a class="code" href="../../d5/de6/strlcat_8c.html#a4baaf26ccdc71244db2410e8d4938e6a">d</a>;</div>
<div class="line"><a name="l01173"></a><span class="lineno"> 1173</span>&#160;                data += <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>);</div>
<div class="line"><a name="l01174"></a><span class="lineno"> 1174</span>&#160;                len -= <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>);</div>
<div class="line"><a name="l01175"></a><span class="lineno"> 1175</span>&#160;            }</div>
<div class="line"><a name="l01176"></a><span class="lineno"> 1176</span>&#160;</div>
<div class="line"><a name="l01177"></a><span class="lineno"> 1177</span>&#160;            pack = len &lt; (size_t)align ? (<span class="keywordtype">int</span>)len : align;</div>
<div class="line"><a name="l01178"></a><span class="lineno"> 1178</span>&#160;            d = 0;</div>
<div class="line"><a name="l01179"></a><span class="lineno"> 1179</span>&#160;            <span class="keywordflow">switch</span> (pack) {</div>
<div class="line"><a name="l01180"></a><span class="lineno"> 1180</span>&#160;<span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01181"></a><span class="lineno"> 1181</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># define UNALIGNED_ADD(n) case (n) + 1: \</span></div>
<div class="line"><a name="l01182"></a><span class="lineno"> 1182</span>&#160;<span class="preprocessor">                d |= data_at(n) &lt;&lt; CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 1)</span></div>
<div class="line"><a name="l01183"></a><span class="lineno"> 1183</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01184"></a><span class="lineno"> 1184</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># define UNALIGNED_ADD(n) case (n) + 1: \</span></div>
<div class="line"><a name="l01185"></a><span class="lineno"> 1185</span>&#160;<span class="preprocessor">                d |= data_at(n) &lt;&lt; CHAR_BIT*(n)</span></div>
<div class="line"><a name="l01186"></a><span class="lineno"> 1186</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01187"></a><span class="lineno"> 1187</span>&#160;<span class="preprocessor"></span>                <a class="code" href="../../d4/d71/st_8c.html#a58449b17c56fb078b9f006f8ab3c5314">UNALIGNED_ADD_ALL</a>;</div>
<div class="line"><a name="l01188"></a><span class="lineno"> 1188</span>&#160;<span class="preprocessor">#undef UNALIGNED_ADD</span></div>
<div class="line"><a name="l01189"></a><span class="lineno"> 1189</span>&#160;<span class="preprocessor"></span>            }</div>
<div class="line"><a name="l01190"></a><span class="lineno"> 1190</span>&#160;<span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01191"></a><span class="lineno"> 1191</span>&#160;<span class="preprocessor"></span>            t = (t &lt;&lt; sr) | (d &gt;&gt; sl);</div>
<div class="line"><a name="l01192"></a><span class="lineno"> 1192</span>&#160;<span class="preprocessor">#else</span></div>
<div class="line"><a name="l01193"></a><span class="lineno"> 1193</span>&#160;<span class="preprocessor"></span>            t = (t &gt;&gt; sr) | (d &lt;&lt; sl);</div>
<div class="line"><a name="l01194"></a><span class="lineno"> 1194</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01195"></a><span class="lineno"> 1195</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01196"></a><span class="lineno"> 1196</span>&#160;<span class="preprocessor">#if MURMUR == 2</span></div>
<div class="line"><a name="l01197"></a><span class="lineno"> 1197</span>&#160;<span class="preprocessor"></span>            <span class="keywordflow">if</span> (len &lt; (<span class="keywordtype">size_t</span>)align) <span class="keywordflow">goto</span> skip_tail;</div>
<div class="line"><a name="l01198"></a><span class="lineno"> 1198</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01199"></a><span class="lineno"> 1199</span>&#160;<span class="preprocessor"></span>            h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, t);</div>
<div class="line"><a name="l01200"></a><span class="lineno"> 1200</span>&#160;            data += pack;</div>
<div class="line"><a name="l01201"></a><span class="lineno"> 1201</span>&#160;            len -= pack;</div>
<div class="line"><a name="l01202"></a><span class="lineno"> 1202</span>&#160;        }</div>
<div class="line"><a name="l01203"></a><span class="lineno"> 1203</span>&#160;        <span class="keywordflow">else</span></div>
<div class="line"><a name="l01204"></a><span class="lineno"> 1204</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01205"></a><span class="lineno"> 1205</span>&#160;<span class="preprocessor"></span>        {</div>
<div class="line"><a name="l01206"></a><span class="lineno"> 1206</span>&#160;            <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l01207"></a><span class="lineno"> 1207</span>&#160;                h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, *(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> *)data);</div>
<div class="line"><a name="l01208"></a><span class="lineno"> 1208</span>&#160;                data += <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>);</div>
<div class="line"><a name="l01209"></a><span class="lineno"> 1209</span>&#160;                len -= <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>);</div>
<div class="line"><a name="l01210"></a><span class="lineno"> 1210</span>&#160;            } <span class="keywordflow">while</span> (len &gt;= <span class="keyword">sizeof</span>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>));</div>
<div class="line"><a name="l01211"></a><span class="lineno"> 1211</span>&#160;        }</div>
<div class="line"><a name="l01212"></a><span class="lineno"> 1212</span>&#160;    }</div>
<div class="line"><a name="l01213"></a><span class="lineno"> 1213</span>&#160;</div>
<div class="line"><a name="l01214"></a><span class="lineno"> 1214</span>&#160;    t = 0;</div>
<div class="line"><a name="l01215"></a><span class="lineno"> 1215</span>&#160;    <span class="keywordflow">switch</span> (len) {</div>
<div class="line"><a name="l01216"></a><span class="lineno"> 1216</span>&#160;<span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01217"></a><span class="lineno"> 1217</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># define UNALIGNED_ADD(n) case (n) + 1: \</span></div>
<div class="line"><a name="l01218"></a><span class="lineno"> 1218</span>&#160;<span class="preprocessor">        t |= data_at(n) &lt;&lt; CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 1)</span></div>
<div class="line"><a name="l01219"></a><span class="lineno"> 1219</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01220"></a><span class="lineno"> 1220</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># define UNALIGNED_ADD(n) case (n) + 1: \</span></div>
<div class="line"><a name="l01221"></a><span class="lineno"> 1221</span>&#160;<span class="preprocessor">        t |= data_at(n) &lt;&lt; CHAR_BIT*(n)</span></div>
<div class="line"><a name="l01222"></a><span class="lineno"> 1222</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01223"></a><span class="lineno"> 1223</span>&#160;<span class="preprocessor"></span>        <a class="code" href="../../d4/d71/st_8c.html#a58449b17c56fb078b9f006f8ab3c5314">UNALIGNED_ADD_ALL</a>;</div>
<div class="line"><a name="l01224"></a><span class="lineno"> 1224</span>&#160;<span class="preprocessor">#undef UNALIGNED_ADD</span></div>
<div class="line"><a name="l01225"></a><span class="lineno"> 1225</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01226"></a><span class="lineno"> 1226</span>&#160;<span class="preprocessor"></span>        h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, t);</div>
<div class="line"><a name="l01227"></a><span class="lineno"> 1227</span>&#160;<span class="preprocessor">#elif MURMUR == 2</span></div>
<div class="line"><a name="l01228"></a><span class="lineno"> 1228</span>&#160;<span class="preprocessor"></span><span class="preprocessor"># if !UNALIGNED_WORD_ACCESS</span></div>
<div class="line"><a name="l01229"></a><span class="lineno"> 1229</span>&#160;<span class="preprocessor"></span>      skip_tail:</div>
<div class="line"><a name="l01230"></a><span class="lineno"> 1230</span>&#160;<span class="preprocessor"># endif</span></div>
<div class="line"><a name="l01231"></a><span class="lineno"> 1231</span>&#160;<span class="preprocessor"></span>        h ^= <a class="code" href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a>;</div>
<div class="line"><a name="l01232"></a><span class="lineno"> 1232</span>&#160;        h *= <a class="code" href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd">MurmurMagic</a>;</div>
<div class="line"><a name="l01233"></a><span class="lineno"> 1233</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01234"></a><span class="lineno"> 1234</span>&#160;<span class="preprocessor"></span>    }</div>
<div class="line"><a name="l01235"></a><span class="lineno"> 1235</span>&#160;</div>
<div class="line"><a name="l01236"></a><span class="lineno"> 1236</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a7319d13cc614204b9b40b6c022d5f911">murmur_finish</a>(h);</div>
<div class="line"><a name="l01237"></a><span class="lineno"> 1237</span>&#160;}</div>
<div class="line"><a name="l01238"></a><span class="lineno"> 1238</span>&#160;</div>
<div class="line"><a name="l01239"></a><span class="lineno"> 1239</span>&#160;<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01240"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a3d78a46cfffcf594047cf492737d7406"> 1240</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a3d78a46cfffcf594047cf492737d7406">st_hash_uint32</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> h, <a class="code" href="../../db/d4d/sha2_8h.html#a435d1572bf3f880d55459d9805097f62">uint32_t</a> i)</div>
<div class="line"><a name="l01241"></a><span class="lineno"> 1241</span>&#160;{</div>
<div class="line"><a name="l01242"></a><span class="lineno"> 1242</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h + i, 16);</div>
<div class="line"><a name="l01243"></a><span class="lineno"> 1243</span>&#160;}</div>
<div class="line"><a name="l01244"></a><span class="lineno"> 1244</span>&#160;</div>
<div class="line"><a name="l01245"></a><span class="lineno"> 1245</span>&#160;<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01246"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a72b493fcb3ac68760a725d058f1cb5d3"> 1246</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a72b493fcb3ac68760a725d058f1cb5d3">st_hash_uint</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> h, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i)</div>
<div class="line"><a name="l01247"></a><span class="lineno"> 1247</span>&#160;{</div>
<div class="line"><a name="l01248"></a><span class="lineno"> 1248</span>&#160;    <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#a8603782009ff58be0587ea58013b3e52">v</a> = 0;</div>
<div class="line"><a name="l01249"></a><span class="lineno"> 1249</span>&#160;    h += <a class="code" href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a>;</div>
<div class="line"><a name="l01250"></a><span class="lineno"> 1250</span>&#160;<span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01251"></a><span class="lineno"> 1251</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT &gt; 12*8</span></div>
<div class="line"><a name="l01252"></a><span class="lineno"> 1252</span>&#160;<span class="preprocessor"></span>    v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h &gt;&gt; 12*8));</div>
<div class="line"><a name="l01253"></a><span class="lineno"> 1253</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01254"></a><span class="lineno"> 1254</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT &gt; 8*8</span></div>
<div class="line"><a name="l01255"></a><span class="lineno"> 1255</span>&#160;<span class="preprocessor"></span>    v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h &gt;&gt; 8*8));</div>
<div class="line"><a name="l01256"></a><span class="lineno"> 1256</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01257"></a><span class="lineno"> 1257</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT &gt; 4*8</span></div>
<div class="line"><a name="l01258"></a><span class="lineno"> 1258</span>&#160;<span class="preprocessor"></span>    v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h &gt;&gt; 4*8));</div>
<div class="line"><a name="l01259"></a><span class="lineno"> 1259</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01260"></a><span class="lineno"> 1260</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01261"></a><span class="lineno"> 1261</span>&#160;<span class="preprocessor"></span>    v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + h);</div>
<div class="line"><a name="l01262"></a><span class="lineno"> 1262</span>&#160;<span class="preprocessor">#ifndef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01263"></a><span class="lineno"> 1263</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT &gt; 4*8</span></div>
<div class="line"><a name="l01264"></a><span class="lineno"> 1264</span>&#160;<span class="preprocessor"></span>    v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h &gt;&gt; 4*8));</div>
<div class="line"><a name="l01265"></a><span class="lineno"> 1265</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01266"></a><span class="lineno"> 1266</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT &gt; 8*8</span></div>
<div class="line"><a name="l01267"></a><span class="lineno"> 1267</span>&#160;<span class="preprocessor"></span>    v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h &gt;&gt; 8*8));</div>
<div class="line"><a name="l01268"></a><span class="lineno"> 1268</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01269"></a><span class="lineno"> 1269</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT &gt; 12*8</span></div>
<div class="line"><a name="l01270"></a><span class="lineno"> 1270</span>&#160;<span class="preprocessor"></span>    v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h &gt;&gt; 12*8));</div>
<div class="line"><a name="l01271"></a><span class="lineno"> 1271</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01272"></a><span class="lineno"> 1272</span>&#160;<span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01273"></a><span class="lineno"> 1273</span>&#160;<span class="preprocessor"></span>    <span class="keywordflow">return</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#a8603782009ff58be0587ea58013b3e52">v</a>;</div>
<div class="line"><a name="l01274"></a><span class="lineno"> 1274</span>&#160;}</div>
<div class="line"><a name="l01275"></a><span class="lineno"> 1275</span>&#160;</div>
<div class="line"><a name="l01276"></a><span class="lineno"> 1276</span>&#160;<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01277"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aee487969705d500b3308fc5c146fd357"> 1277</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#aee487969705d500b3308fc5c146fd357">st_hash_end</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> h)</div>
<div class="line"><a name="l01278"></a><span class="lineno"> 1278</span>&#160;{</div>
<div class="line"><a name="l01279"></a><span class="lineno"> 1279</span>&#160;    h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, 10);</div>
<div class="line"><a name="l01280"></a><span class="lineno"> 1280</span>&#160;    h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, 17);</div>
<div class="line"><a name="l01281"></a><span class="lineno"> 1281</span>&#160;    <span class="keywordflow">return</span> h;</div>
<div class="line"><a name="l01282"></a><span class="lineno"> 1282</span>&#160;}</div>
<div class="line"><a name="l01283"></a><span class="lineno"> 1283</span>&#160;</div>
<div class="line"><a name="l01284"></a><span class="lineno"> 1284</span>&#160;<span class="preprocessor">#undef st_hash_start</span></div>
<div class="line"><a name="l01285"></a><span class="lineno"> 1285</span>&#160;<span class="preprocessor"></span><a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01286"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#abd6d8900985779079ec683ece31f6fd7"> 1286</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a1535c1b1e88190c7fe1a76e584bd9c59">st_hash_start</a>(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> h)</div>
<div class="line"><a name="l01287"></a><span class="lineno"> 1287</span>&#160;{</div>
<div class="line"><a name="l01288"></a><span class="lineno"> 1288</span>&#160;    <span class="keywordflow">return</span> h;</div>
<div class="line"><a name="l01289"></a><span class="lineno"> 1289</span>&#160;}</div>
<div class="line"><a name="l01290"></a><span class="lineno"> 1290</span>&#160;</div>
<div class="line"><a name="l01291"></a><span class="lineno"> 1291</span>&#160;<span class="keyword">static</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01292"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7"> 1292</a></span>&#160;<a class="code" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7">strhash</a>(<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> arg)</div>
<div class="line"><a name="l01293"></a><span class="lineno"> 1293</span>&#160;{</div>
<div class="line"><a name="l01294"></a><span class="lineno"> 1294</span>&#160;    <span class="keyword">register</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *<span class="keywordtype">string</span> = (<span class="keyword">const</span> <span class="keywordtype">char</span> *)arg;</div>
<div class="line"><a name="l01295"></a><span class="lineno"> 1295</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../dd/d24/st_8h.html#a970b36e65b43e8fcccbea3e3397aeefa">st_hash</a>(<span class="keywordtype">string</span>, <a class="code" href="../../d6/d7b/strchr_8c.html#a219836f542ce53545052bed5353820ca">strlen</a>(<span class="keywordtype">string</span>), <a class="code" href="../../d4/d71/st_8c.html#a40a142ccb9ca21d50ea9f6ed8589cc96">FNV1_32A_INIT</a>);</div>
<div class="line"><a name="l01296"></a><span class="lineno"> 1296</span>&#160;}</div>
<div class="line"><a name="l01297"></a><span class="lineno"> 1297</span>&#160;<span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01298"></a><span class="lineno"> 1298</span>&#160;<span class="preprocessor"></span></div>
<div class="line"><a name="l01299"></a><span class="lineno"> 1299</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l01300"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aa34004564b66661c5c2f6d396e567e93"> 1300</a></span>&#160;<a class="code" href="../../de/de6/ruby_2ruby_8h.html#aa34004564b66661c5c2f6d396e567e93">st_strcasecmp</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *s1, <span class="keyword">const</span> <span class="keywordtype">char</span> *s2)</div>
<div class="line"><a name="l01301"></a><span class="lineno"> 1301</span>&#160;{</div>
<div class="line"><a name="l01302"></a><span class="lineno"> 1302</span>&#160;    <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> c1, c2;</div>
<div class="line"><a name="l01303"></a><span class="lineno"> 1303</span>&#160;</div>
<div class="line"><a name="l01304"></a><span class="lineno"> 1304</span>&#160;    <span class="keywordflow">while</span> (1) {</div>
<div class="line"><a name="l01305"></a><span class="lineno"> 1305</span>&#160;        c1 = (<span class="keywordtype">unsigned</span> char)*s1++;</div>
<div class="line"><a name="l01306"></a><span class="lineno"> 1306</span>&#160;        c2 = (<span class="keywordtype">unsigned</span> char)*s2++;</div>
<div class="line"><a name="l01307"></a><span class="lineno"> 1307</span>&#160;        <span class="keywordflow">if</span> (c1 == <span class="charliteral">&#39;\0&#39;</span> || c2 == <span class="charliteral">&#39;\0&#39;</span>) {</div>
<div class="line"><a name="l01308"></a><span class="lineno"> 1308</span>&#160;            <span class="keywordflow">if</span> (c1 != <span class="charliteral">&#39;\0&#39;</span>) <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l01309"></a><span class="lineno"> 1309</span>&#160;            <span class="keywordflow">if</span> (c2 != <span class="charliteral">&#39;\0&#39;</span>) <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l01310"></a><span class="lineno"> 1310</span>&#160;            <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l01311"></a><span class="lineno"> 1311</span>&#160;        }</div>
<div class="line"><a name="l01312"></a><span class="lineno"> 1312</span>&#160;        <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c1 - <span class="charliteral">&#39;A&#39;</span>) &lt;= (<span class="charliteral">&#39;Z&#39;</span> - <span class="charliteral">&#39;A&#39;</span>)) c1 += <span class="charliteral">&#39;a&#39;</span> - <span class="charliteral">&#39;A&#39;</span>;</div>
<div class="line"><a name="l01313"></a><span class="lineno"> 1313</span>&#160;        <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c2 - <span class="charliteral">&#39;A&#39;</span>) &lt;= (<span class="charliteral">&#39;Z&#39;</span> - <span class="charliteral">&#39;A&#39;</span>)) c2 += <span class="charliteral">&#39;a&#39;</span> - <span class="charliteral">&#39;A&#39;</span>;</div>
<div class="line"><a name="l01314"></a><span class="lineno"> 1314</span>&#160;        <span class="keywordflow">if</span> (c1 != c2) {</div>
<div class="line"><a name="l01315"></a><span class="lineno"> 1315</span>&#160;            <span class="keywordflow">if</span> (c1 &gt; c2)</div>
<div class="line"><a name="l01316"></a><span class="lineno"> 1316</span>&#160;                <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l01317"></a><span class="lineno"> 1317</span>&#160;            <span class="keywordflow">else</span></div>
<div class="line"><a name="l01318"></a><span class="lineno"> 1318</span>&#160;                <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l01319"></a><span class="lineno"> 1319</span>&#160;        }</div>
<div class="line"><a name="l01320"></a><span class="lineno"> 1320</span>&#160;    }</div>
<div class="line"><a name="l01321"></a><span class="lineno"> 1321</span>&#160;}</div>
<div class="line"><a name="l01322"></a><span class="lineno"> 1322</span>&#160;</div>
<div class="line"><a name="l01323"></a><span class="lineno"> 1323</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l01324"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae5d944df8ef1621b6ff43bfcaecb7d46"> 1324</a></span>&#160;<a class="code" href="../../de/de6/ruby_2ruby_8h.html#ae5d944df8ef1621b6ff43bfcaecb7d46">st_strncasecmp</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *s1, <span class="keyword">const</span> <span class="keywordtype">char</span> *s2, <span class="keywordtype">size_t</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#aeab71244afb687f16d8c4f5ee9d6ef0e">n</a>)</div>
<div class="line"><a name="l01325"></a><span class="lineno"> 1325</span>&#160;{</div>
<div class="line"><a name="l01326"></a><span class="lineno"> 1326</span>&#160;    <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> c1, c2;</div>
<div class="line"><a name="l01327"></a><span class="lineno"> 1327</span>&#160;</div>
<div class="line"><a name="l01328"></a><span class="lineno"> 1328</span>&#160;    <span class="keywordflow">while</span> (n--) {</div>
<div class="line"><a name="l01329"></a><span class="lineno"> 1329</span>&#160;        c1 = (<span class="keywordtype">unsigned</span> char)*s1++;</div>
<div class="line"><a name="l01330"></a><span class="lineno"> 1330</span>&#160;        c2 = (<span class="keywordtype">unsigned</span> char)*s2++;</div>
<div class="line"><a name="l01331"></a><span class="lineno"> 1331</span>&#160;        <span class="keywordflow">if</span> (c1 == <span class="charliteral">&#39;\0&#39;</span> || c2 == <span class="charliteral">&#39;\0&#39;</span>) {</div>
<div class="line"><a name="l01332"></a><span class="lineno"> 1332</span>&#160;            <span class="keywordflow">if</span> (c1 != <span class="charliteral">&#39;\0&#39;</span>) <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l01333"></a><span class="lineno"> 1333</span>&#160;            <span class="keywordflow">if</span> (c2 != <span class="charliteral">&#39;\0&#39;</span>) <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l01334"></a><span class="lineno"> 1334</span>&#160;            <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l01335"></a><span class="lineno"> 1335</span>&#160;        }</div>
<div class="line"><a name="l01336"></a><span class="lineno"> 1336</span>&#160;        <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c1 - <span class="charliteral">&#39;A&#39;</span>) &lt;= (<span class="charliteral">&#39;Z&#39;</span> - <span class="charliteral">&#39;A&#39;</span>)) c1 += <span class="charliteral">&#39;a&#39;</span> - <span class="charliteral">&#39;A&#39;</span>;</div>
<div class="line"><a name="l01337"></a><span class="lineno"> 1337</span>&#160;        <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c2 - <span class="charliteral">&#39;A&#39;</span>) &lt;= (<span class="charliteral">&#39;Z&#39;</span> - <span class="charliteral">&#39;A&#39;</span>)) c2 += <span class="charliteral">&#39;a&#39;</span> - <span class="charliteral">&#39;A&#39;</span>;</div>
<div class="line"><a name="l01338"></a><span class="lineno"> 1338</span>&#160;        <span class="keywordflow">if</span> (c1 != c2) {</div>
<div class="line"><a name="l01339"></a><span class="lineno"> 1339</span>&#160;            <span class="keywordflow">if</span> (c1 &gt; c2)</div>
<div class="line"><a name="l01340"></a><span class="lineno"> 1340</span>&#160;                <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l01341"></a><span class="lineno"> 1341</span>&#160;            <span class="keywordflow">else</span></div>
<div class="line"><a name="l01342"></a><span class="lineno"> 1342</span>&#160;                <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l01343"></a><span class="lineno"> 1343</span>&#160;        }</div>
<div class="line"><a name="l01344"></a><span class="lineno"> 1344</span>&#160;    }</div>
<div class="line"><a name="l01345"></a><span class="lineno"> 1345</span>&#160;    <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l01346"></a><span class="lineno"> 1346</span>&#160;}</div>
<div class="line"><a name="l01347"></a><span class="lineno"> 1347</span>&#160;</div>
<div class="line"><a name="l01348"></a><span class="lineno"> 1348</span>&#160;<span class="keyword">static</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01349"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48"> 1349</a></span>&#160;<a class="code" href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48">strcasehash</a>(<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> arg)</div>
<div class="line"><a name="l01350"></a><span class="lineno"> 1350</span>&#160;{</div>
<div class="line"><a name="l01351"></a><span class="lineno"> 1351</span>&#160;    <span class="keyword">register</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *<span class="keywordtype">string</span> = (<span class="keyword">const</span> <span class="keywordtype">char</span> *)arg;</div>
<div class="line"><a name="l01352"></a><span class="lineno"> 1352</span>&#160;    <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d3/deb/lex_8c.html#afc4c7aea01574edcf6289eb0e999b889">hval</a> = <a class="code" href="../../d4/d71/st_8c.html#a40a142ccb9ca21d50ea9f6ed8589cc96">FNV1_32A_INIT</a>;</div>
<div class="line"><a name="l01353"></a><span class="lineno"> 1353</span>&#160;</div>
<div class="line"><a name="l01354"></a><span class="lineno"> 1354</span>&#160;    <span class="comment">/*</span></div>
<div class="line"><a name="l01355"></a><span class="lineno"> 1355</span>&#160;<span class="comment">     * FNV-1a hash each octet in the buffer</span></div>
<div class="line"><a name="l01356"></a><span class="lineno"> 1356</span>&#160;<span class="comment">     */</span></div>
<div class="line"><a name="l01357"></a><span class="lineno"> 1357</span>&#160;    <span class="keywordflow">while</span> (*<span class="keywordtype">string</span>) {</div>
<div class="line"><a name="l01358"></a><span class="lineno"> 1358</span>&#160;        <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="../../de/d07/bigdecimal_8c.html#a0ae1919f736e3a087fbc9cd8dcba9da9">c</a> = (<span class="keywordtype">unsigned</span> char)*<span class="keywordtype">string</span>++;</div>
<div class="line"><a name="l01359"></a><span class="lineno"> 1359</span>&#160;        <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c - <span class="charliteral">&#39;A&#39;</span>) &lt;= (<span class="charliteral">&#39;Z&#39;</span> - <span class="charliteral">&#39;A&#39;</span>)) c += <span class="charliteral">&#39;a&#39;</span> - <span class="charliteral">&#39;A&#39;</span>;</div>
<div class="line"><a name="l01360"></a><span class="lineno"> 1360</span>&#160;        hval ^= <a class="code" href="../../de/d07/bigdecimal_8c.html#a0ae1919f736e3a087fbc9cd8dcba9da9">c</a>;</div>
<div class="line"><a name="l01361"></a><span class="lineno"> 1361</span>&#160;</div>
<div class="line"><a name="l01362"></a><span class="lineno"> 1362</span>&#160;        <span class="comment">/* multiply by the 32 bit FNV magic prime mod 2^32 */</span></div>
<div class="line"><a name="l01363"></a><span class="lineno"> 1363</span>&#160;        hval *= <a class="code" href="../../d4/d71/st_8c.html#ae13a6565bea334e9b6fb19033a392857">FNV_32_PRIME</a>;</div>
<div class="line"><a name="l01364"></a><span class="lineno"> 1364</span>&#160;    }</div>
<div class="line"><a name="l01365"></a><span class="lineno"> 1365</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="../../d3/deb/lex_8c.html#afc4c7aea01574edcf6289eb0e999b889">hval</a>;</div>
<div class="line"><a name="l01366"></a><span class="lineno"> 1366</span>&#160;}</div>
<div class="line"><a name="l01367"></a><span class="lineno"> 1367</span>&#160;</div>
<div class="line"><a name="l01368"></a><span class="lineno"> 1368</span>&#160;<span class="keywordtype">int</span></div>
<div class="line"><a name="l01369"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4c9a444f4aabb6c83a19c5afacbfdaf6"> 1369</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a2839ae91d54936af83392d0df9f97488">st_numcmp</a>(<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> x, <a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> y)</div>
<div class="line"><a name="l01370"></a><span class="lineno"> 1370</span>&#160;{</div>
<div class="line"><a name="l01371"></a><span class="lineno"> 1371</span>&#160;    <span class="keywordflow">return</span> x != y;</div>
<div class="line"><a name="l01372"></a><span class="lineno"> 1372</span>&#160;}</div>
<div class="line"><a name="l01373"></a><span class="lineno"> 1373</span>&#160;</div>
<div class="line"><a name="l01374"></a><span class="lineno"> 1374</span>&#160;<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div>
<div class="line"><a name="l01375"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a012fbc7aee9522e01fa622dd6aafbaee"> 1375</a></span>&#160;<a class="code" href="../../dd/d24/st_8h.html#a50249b52a70e7a4aa8ca8582c380cd26">st_numhash</a>(<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a> <a class="code" href="../../de/d07/bigdecimal_8c.html#aeab71244afb687f16d8c4f5ee9d6ef0e">n</a>)</div>
<div class="line"><a name="l01376"></a><span class="lineno"> 1376</span>&#160;{</div>
<div class="line"><a name="l01377"></a><span class="lineno"> 1377</span>&#160;    <span class="keywordflow">return</span> (<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>)<a class="code" href="../../de/d07/bigdecimal_8c.html#aeab71244afb687f16d8c4f5ee9d6ef0e">n</a>;</div>
<div class="line"><a name="l01378"></a><span class="lineno"> 1378</span>&#160;}</div>
<div class="ttc" id="st_8h_html_a0c6a172fd99de7928916e65034ed8b1fa64ab176f8e8b9719bcd9b5297ccda9c7"><div class="ttname"><a href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa64ab176f8e8b9719bcd9b5297ccda9c7">ST_DELETE</a></div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00100">st.h:100</a></div></div>
<div class="ttc" id="st_8c_html_a24df014296a421392679e4dd79101e7a"><div class="ttname"><a href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a">new_size</a></div><div class="ttdeci">static st_index_t new_size(st_index_t size)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00120">st.c:120</a></div></div>
<div class="ttc" id="regint_8h_html_a698052a584b1c7daa968cd5d16a0a2d0"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a698052a584b1c7daa968cd5d16a0a2d0">st_init_strtable_with_size</a></div><div class="ttdeci">#define st_init_strtable_with_size</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00145">regint.h:145</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_aeab71244afb687f16d8c4f5ee9d6ef0e"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#aeab71244afb687f16d8c4f5ee9d6ef0e">n</a></div><div class="ttdeci">ssize_t n</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l05519">bigdecimal.c:5519</a></div></div>
<div class="ttc" id="structst__table__entry_html_a4054ac2ac0f2065f541246bd665c6c7d"><div class="ttname"><a href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">st_table_entry::hash</a></div><div class="ttdeci">st_index_t hash</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00021">st.c:21</a></div></div>
<div class="ttc" id="st_8c_html_a9bfe95f51203fde86c8dd3fe85d92bcd"><div class="ttname"><a href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd">MurmurMagic</a></div><div class="ttdeci">#define MurmurMagic</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01067">st.c:1067</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_accd5e629f58868c52137db996aaf8b83"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#accd5e629f58868c52137db996aaf8b83">int</a></div><div class="ttdeci">VP_EXPORT int</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l04911">bigdecimal.c:4911</a></div></div>
<div class="ttc" id="st_8c_html_afbf658274f1e8229ce3efad9b1eb11d3"><div class="ttname"><a href="../../d4/d71/st_8c.html#afbf658274f1e8229ce3efad9b1eb11d3">REMOVE_ENTRY</a></div><div class="ttdeci">#define REMOVE_ENTRY(table, ptr)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00607">st.c:607</a></div></div>
<div class="ttc" id="st_8h_html_a1535c1b1e88190c7fe1a76e584bd9c59"><div class="ttname"><a href="../../dd/d24/st_8h.html#a1535c1b1e88190c7fe1a76e584bd9c59">st_hash_start</a></div><div class="ttdeci">#define st_hash_start(h)</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00134">st.h:134</a></div></div>
<div class="ttc" id="strchr_8c_html_a219836f542ce53545052bed5353820ca"><div class="ttname"><a href="../../d6/d7b/strchr_8c.html#a219836f542ce53545052bed5353820ca">strlen</a></div><div class="ttdeci">size_t strlen(const char *)</div></div>
<div class="ttc" id="structst__table_html"><div class="ttname"><a href="../../d0/ddd/structst__table.html">st_table</a></div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00077">st.h:77</a></div></div>
<div class="ttc" id="st_8h_html_a72b493fcb3ac68760a725d058f1cb5d3"><div class="ttname"><a href="../../dd/d24/st_8h.html#a72b493fcb3ac68760a725d058f1cb5d3">st_hash_uint</a></div><div class="ttdeci">st_index_t st_hash_uint(st_index_t h, st_index_t i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01246">st.c:1246</a></div></div>
<div class="ttc" id="st_8h_html_a0c6a172fd99de7928916e65034ed8b1fa04b939c166d4baa471909eb224d5fed3"><div class="ttname"><a href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa04b939c166d4baa471909eb224d5fed3">ST_STOP</a></div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00100">st.h:100</a></div></div>
<div class="ttc" id="ripper_8c_html_a68fefa607ad528d20b0ae5d69a346d46"><div class="ttname"><a href="../../d5/d11/ripper_8c.html#a68fefa607ad528d20b0ae5d69a346d46">val</a></div><div class="ttdeci">parser parser_yylval val</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d11/ripper_8c_source.html#l14289">ripper.c:14289</a></div></div>
<div class="ttc" id="ruby_2ruby_8h_html"><div class="ttname"><a href="../../de/de6/ruby_2ruby_8h.html">ruby.h</a></div></div>
<div class="ttc" id="st_8c_html_ae13a6565bea334e9b6fb19033a392857"><div class="ttname"><a href="../../d4/d71/st_8c.html#ae13a6565bea334e9b6fb19033a392857">FNV_32_PRIME</a></div><div class="ttdeci">#define FNV_32_PRIME</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01020">st.c:1020</a></div></div>
<div class="ttc" id="regint_8h_html_a4a2fef263bb8fa14faff2a3222a407dd"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a4a2fef263bb8fa14faff2a3222a407dd">st_foreach</a></div><div class="ttdeci">#define st_foreach</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00150">regint.h:150</a></div></div>
<div class="ttc" id="tcltklib_8c_html_a67fbe68c1b421badd861a1fa7c525058"><div class="ttname"><a href="../../d5/d9d/tcltklib_8c.html#a67fbe68c1b421badd861a1fa7c525058">table</a></div><div class="ttdeci">static VALUE VALUE table</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d9d/tcltklib_8c_source.html#l10121">tcltklib.c:10121</a></div></div>
<div class="ttc" id="ossl__ssl_8c_html_a33775ffa49b921f1647bfac2850c6298"><div class="ttname"><a href="../../dc/dd1/ossl__ssl_8c.html#a33775ffa49b921f1647bfac2850c6298">func</a></div><div class="ttdeci">SSL_METHOD *(* func)(void)</div><div class="ttdef"><b>Definition:</b> <a href="../../dc/dd1/ossl__ssl_8c_source.html#l00104">ossl_ssl.c:104</a></div></div>
<div class="ttc" id="st_8c_html_a76ace81cc961cbcdba26190bcd706326"><div class="ttname"><a href="../../d4/d71/st_8c.html#a76ace81cc961cbcdba26190bcd706326">MINSIZE</a></div><div class="ttdeci">#define MINSIZE</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00082">st.c:82</a></div></div>
<div class="ttc" id="st_8h_html_a3d78a46cfffcf594047cf492737d7406"><div class="ttname"><a href="../../dd/d24/st_8h.html#a3d78a46cfffcf594047cf492737d7406">st_hash_uint32</a></div><div class="ttdeci">st_index_t st_hash_uint32(st_index_t h, uint32_t i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01240">st.c:1240</a></div></div>
<div class="ttc" id="st_8h_html_a2839ae91d54936af83392d0df9f97488"><div class="ttname"><a href="../../dd/d24/st_8h.html#a2839ae91d54936af83392d0df9f97488">st_numcmp</a></div><div class="ttdeci">int st_numcmp(st_data_t, st_data_t)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01369">st.c:1369</a></div></div>
<div class="ttc" id="tkutil_8c_html_ab3379c8db8c1bbea65e45f218b70e807"><div class="ttname"><a href="../../d9/dee/tkutil_8c.html#ab3379c8db8c1bbea65e45f218b70e807">ST_CHECK</a></div><div class="ttdeci">return ST_CHECK</div><div class="ttdef"><b>Definition:</b> <a href="../../d9/dee/tkutil_8c_source.html#l00271">tkutil.c:271</a></div></div>
<div class="ttc" id="structst__table_html_a03f11a1fe0b82094d6acb038fa8118c3"><div class="ttname"><a href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">st_table::num_bins</a></div><div class="ttdeci">st_index_t num_bins</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00079">st.h:79</a></div></div>
<div class="ttc" id="tkutil_8c_html_aa6e13b966bc7c446c09941d17bd42e05"><div class="ttname"><a href="../../d9/dee/tkutil_8c.html#aa6e13b966bc7c446c09941d17bd42e05">ST_CONTINUE</a></div><div class="ttdeci">return ST_CONTINUE</div><div class="ttdef"><b>Definition:</b> <a href="../../d9/dee/tkutil_8c_source.html#l01273">tkutil.c:1273</a></div></div>
<div class="ttc" id="st_8c_html_a94c395161bf80ffa3b1d224ad3542f11"><div class="ttname"><a href="../../d4/d71/st_8c.html#a94c395161bf80ffa3b1d224ad3542f11">Calloc</a></div><div class="ttdeci">#define Calloc(n, s)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00070">st.c:70</a></div></div>
<div class="ttc" id="st_8h_html_a67fcf8f213cf0367f1923b2ae72b868d"><div class="ttname"><a href="../../dd/d24/st_8h.html#a67fcf8f213cf0367f1923b2ae72b868d">st_get_key</a></div><div class="ttdeci">int st_get_key(st_table *, st_data_t, st_data_t *)</div></div>
<div class="ttc" id="structst__table__entry_html_a8c7fef89f13d76633cd71d595d39181d"><div class="ttname"><a href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">st_table_entry::next</a></div><div class="ttdeci">st_table_entry * next</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00024">st.c:24</a></div></div>
<div class="ttc" id="error_8c_html_a0f771a2840561f1838169b3d7d4616f3"><div class="ttname"><a href="../../db/dcc/error_8c.html#a0f771a2840561f1838169b3d7d4616f3">rb_raise</a></div><div class="ttdeci">void rb_raise(VALUE exc, const char *fmt,...)</div><div class="ttdef"><b>Definition:</b> <a href="../../db/dcc/error_8c_source.html#l01574">error.c:1574</a></div></div>
<div class="ttc" id="ruby_8c_html_ad7a5c5f28ee70e62307d4f72cfe9dc9b"><div class="ttname"><a href="../../df/d77/ruby_8c.html#ad7a5c5f28ee70e62307d4f72cfe9dc9b">str</a></div><div class="ttdeci">return str</div><div class="ttdef"><b>Definition:</b> <a href="../../df/d77/ruby_8c_source.html#l01183">ruby.c:1183</a></div></div>
<div class="ttc" id="structst__table__entry_html_a78379c2ee6cf57370697a50ff7971b17"><div class="ttname"><a href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">st_table_entry::record</a></div><div class="ttdeci">st_data_t record</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00023">st.c:23</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_a514f1b439f404f86f77090fa9edc96ce"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#a514f1b439f404f86f77090fa9edc96ce">r</a></div><div class="ttdeci">r</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l01154">bigdecimal.c:1154</a></div></div>
<div class="ttc" id="st_8h_html_ac214e5cdcf0de6a2108b9643e7fc12e0"><div class="ttname"><a href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="ttdeci">st_data_t st_index_t</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00063">st.h:63</a></div></div>
<div class="ttc" id="regint_8h_html_aa77af2b7839fb6d01facdc86fdd69544"><div class="ttname"><a href="../../d6/d87/regint_8h.html#aa77af2b7839fb6d01facdc86fdd69544">st_delete</a></div><div class="ttdeci">#define st_delete</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00146">regint.h:146</a></div></div>
<div class="ttc" id="regint_8h_html_a8032e662c4b4ee0ded05bbe3f15d5c45"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a8032e662c4b4ee0ded05bbe3f15d5c45">st_lookup</a></div><div class="ttdeci">#define st_lookup</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00149">regint.h:149</a></div></div>
<div class="ttc" id="nkf-utf8_2nkf_8c_html_ab0b853bc4e4e9658036bf7e604f398ad"><div class="ttname"><a href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a></div><div class="ttdeci">unsigned int last</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/da0/nkf-utf8_2nkf_8c_source.html#l03915">nkf.c:3915</a></div></div>
<div class="ttc" id="st_8c_html_a08e80c200b25893c4c490666ce639528"><div class="ttname"><a href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a></div><div class="ttdeci">#define murmur1(h)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01109">st.c:1109</a></div></div>
<div class="ttc" id="regint_8h_html_ae3540c476ad141816fa6f6bf6a30e7df"><div class="ttname"><a href="../../d6/d87/regint_8h.html#ae3540c476ad141816fa6f6bf6a30e7df">st_init_strtable</a></div><div class="ttdeci">#define st_init_strtable</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00144">regint.h:144</a></div></div>
<div class="ttc" id="tkutil_8c_html_ab758f7e37948b530e3b9542b69437065"><div class="ttname"><a href="../../d9/dee/tkutil_8c.html#ab758f7e37948b530e3b9542b69437065">tbl</a></div><div class="ttdeci">VALUE tbl</div><div class="ttdef"><b>Definition:</b> <a href="../../d9/dee/tkutil_8c_source.html#l01279">tkutil.c:1279</a></div></div>
<div class="ttc" id="st_8c_html_abd2051b6b857de0a4b8aec12043fe005"><div class="ttname"><a href="../../d4/d71/st_8c.html#abd2051b6b857de0a4b8aec12043fe005">unpack_entries</a></div><div class="ttdeci">static void unpack_entries(register st_table *table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00417">st.c:417</a></div></div>
<div class="ttc" id="regint_8h_html_a265827f28bd0539bc25cc4459fc83690"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a265827f28bd0539bc25cc4459fc83690">st_init_numtable_with_size</a></div><div class="ttdeci">#define st_init_numtable_with_size</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00143">regint.h:143</a></div></div>
<div class="ttc" id="structst__table_html_af86c7c8652d8c86d356b6dc620a56efb"><div class="ttname"><a href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">st_table::entries_packed</a></div><div class="ttdeci">unsigned int entries_packed</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00080">st.h:80</a></div></div>
<div class="ttc" id="strlcat_8c_html_a4baaf26ccdc71244db2410e8d4938e6a"><div class="ttname"><a href="../../d5/de6/strlcat_8c.html#a4baaf26ccdc71244db2410e8d4938e6a">d</a></div><div class="ttdeci">d</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/de6/strlcat_8c_source.html#l00058">strlcat.c:58</a></div></div>
<div class="ttc" id="missing_8h_html_a809a3e9326a0d3e5aa549b17085b057d"><div class="ttname"><a href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a></div><div class="ttdeci">RUBY_EXTERN void * memmove(void *, const void *, size_t)</div><div class="ttdef"><b>Definition:</b> <a href="../../da/d6f/memmove_8c_source.html#l00007">memmove.c:7</a></div></div>
<div class="ttc" id="struct____s_f_i_l_e_html"><div class="ttname"><a href="../../db/ddf/struct____s_f_i_l_e.html">__sFILE</a></div><div class="ttdef"><b>Definition:</b> <a href="../../da/d50/vsnprintf_8c_source.html#l00175">vsnprintf.c:175</a></div></div>
<div class="ttc" id="st_8c_html_a2e66e2285d7393eca0aea2eac98b8ded"><div class="ttname"><a href="../../d4/d71/st_8c.html#a2e66e2285d7393eca0aea2eac98b8ded">do_hash_bin</a></div><div class="ttdeci">#define do_hash_bin(key, table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00076">st.c:76</a></div></div>
<div class="ttc" id="st_8c_html_a5425f87cd69b75aba5ccbbb1c9a0a36a"><div class="ttname"><a href="../../d4/d71/st_8c.html#a5425f87cd69b75aba5ccbbb1c9a0a36a">MAX_PACKED_NUMHASH</a></div><div class="ttdeci">#define MAX_PACKED_NUMHASH</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00164">st.c:164</a></div></div>
<div class="ttc" id="st_8h_html_a6978e6fe886b41a3c781a50760eb7d70"><div class="ttname"><a href="../../dd/d24/st_8h.html#a6978e6fe886b41a3c781a50760eb7d70">st_insert2</a></div><div class="ttdeci">int st_insert2(st_table *, st_data_t, st_data_t, st_data_t(*)(st_data_t))</div></div>
<div class="ttc" id="st_8h_html_a60f14cceadd837db51e110881258944a"><div class="ttname"><a href="../../dd/d24/st_8h.html#a60f14cceadd837db51e110881258944a">st_init_strcasetable</a></div><div class="ttdeci">st_table * st_init_strcasetable(void)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00229">st.c:229</a></div></div>
<div class="ttc" id="st_8c_html_ade1811eeadef04915e40f72df282fa62"><div class="ttname"><a href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">FIND_ENTRY</a></div><div class="ttdeci">#define FIND_ENTRY(table, ptr, hash_val, bin_pos)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00309">st.c:309</a></div></div>
<div class="ttc" id="structst__hash__type_html"><div class="ttname"><a href="../../d6/d34/structst__hash__type.html">st_hash_type</a></div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00070">st.h:70</a></div></div>
<div class="ttc" id="st_8h_html_aa9a4938f87639b4d9a1c921f8ace1faa"><div class="ttname"><a href="../../dd/d24/st_8h.html#aa9a4938f87639b4d9a1c921f8ace1faa">SIZEOF_ST_INDEX_T</a></div><div class="ttdeci">#define SIZEOF_ST_INDEX_T</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00068">st.h:68</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_ae676aee4547572d937505cfb336c18d5"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#ae676aee4547572d937505cfb336c18d5">memset</a></div><div class="ttdeci">memset(y-&gt;frac+ix+1, 0,(y-&gt;Prec-(ix+1))*sizeof(BDIGIT))</div></div>
<div class="ttc" id="yaml2byte_8c_html_a735984d41155bc1032e09bece8f8d66d"><div class="ttname"><a href="../../dd/dfb/yaml2byte_8c.html#a735984d41155bc1032e09bece8f8d66d">data</a></div><div class="ttdeci">void * data</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/dfb/yaml2byte_8c_source.html#l00131">yaml2byte.c:131</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_ae524ec6ce1980bec6f25676783609004"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#ae524ec6ce1980bec6f25676783609004">m</a></div><div class="ttdeci">BDIGIT m</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l04946">bigdecimal.c:4946</a></div></div>
<div class="ttc" id="st_8h_html_a8650831f7c601411625cb369422ee6d4"><div class="ttname"><a href="../../dd/d24/st_8h.html#a8650831f7c601411625cb369422ee6d4">st_init_strcasetable_with_size</a></div><div class="ttdeci">st_table * st_init_strcasetable_with_size(st_index_t)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00235">st.c:235</a></div></div>
<div class="ttc" id="st_8c_html_a91069e070d6e0fbc1ff1145127c29742"><div class="ttname"><a href="../../d4/d71/st_8c.html#a91069e070d6e0fbc1ff1145127c29742">type_strcasehash</a></div><div class="ttdeci">static struct st_hash_type type_strcasehash</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00054">st.c:54</a></div></div>
<div class="ttc" id="error_8c_html_a95ad3953d535707e2cf2b1d837f5e253"><div class="ttname"><a href="../../db/dcc/error_8c.html#a95ad3953d535707e2cf2b1d837f5e253">rb_eRuntimeError</a></div><div class="ttdeci">VALUE rb_eRuntimeError</div><div class="ttdef"><b>Definition:</b> <a href="../../db/dcc/error_8c_source.html#l00466">error.c:466</a></div></div>
<div class="ttc" id="regint_8h_html_a845e6c2e4ee26cff035aa0a1ca344490"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a></div><div class="ttdeci">#define st_init_table_with_size</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00141">regint.h:141</a></div></div>
<div class="ttc" id="st_8c_html_a58449b17c56fb078b9f006f8ab3c5314"><div class="ttname"><a href="../../d4/d71/st_8c.html#a58449b17c56fb078b9f006f8ab3c5314">UNALIGNED_ADD_ALL</a></div><div class="ttdeci">#define UNALIGNED_ADD_ALL</div></div>
<div class="ttc" id="structst__table__entry_html"><div class="ttname"><a href="../../df/dfb/structst__table__entry.html">st_table_entry</a></div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00020">st.c:20</a></div></div>
<div class="ttc" id="st_8c_html_a7319d13cc614204b9b40b6c022d5f911"><div class="ttname"><a href="../../d4/d71/st_8c.html#a7319d13cc614204b9b40b6c022d5f911">murmur_finish</a></div><div class="ttdeci">static st_index_t murmur_finish(st_index_t h)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01091">st.c:1091</a></div></div>
<div class="ttc" id="st_8c_html_a42fee74992f1efd43ebdfb2d1c2c7538"><div class="ttname"><a href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a></div><div class="ttdeci">#define murmur_step(h, k)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01104">st.c:1104</a></div></div>
<div class="ttc" id="st_8c_html_a6f8bc2a6eef7714715e56451ed32521c"><div class="ttname"><a href="../../d4/d71/st_8c.html#a6f8bc2a6eef7714715e56451ed32521c">murmur</a></div><div class="ttdeci">static st_index_t murmur(st_index_t h, st_index_t k, int r)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01072">st.c:1072</a></div></div>
<div class="ttc" id="subst_8h_html_aa367b75c5aed883fef5befbdf04835a4"><div class="ttname"><a href="../../d7/d72/subst_8h.html#aa367b75c5aed883fef5befbdf04835a4">snprintf</a></div><div class="ttdeci">#define snprintf</div><div class="ttdef"><b>Definition:</b> <a href="../../d7/d72/subst_8h_source.html#l00006">subst.h:6</a></div></div>
<div class="ttc" id="st_8c_html_afa0b3f5a7c236c57525153e59dd3c608"><div class="ttname"><a href="../../d4/d71/st_8c.html#afa0b3f5a7c236c57525153e59dd3c608">primes</a></div><div class="ttdeci">static const unsigned int primes[]</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00087">st.c:87</a></div></div>
<div class="ttc" id="st_8c_html_a167297ecc6a15b3e40576309d41e68d7"><div class="ttname"><a href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7">strhash</a></div><div class="ttdeci">static st_index_t strhash(st_data_t)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01292">st.c:1292</a></div></div>
<div class="ttc" id="st_8c_html_acfaf774315212a7f26b139e77e62f75d"><div class="ttname"><a href="../../d4/d71/st_8c.html#acfaf774315212a7f26b139e77e62f75d">type_strhash</a></div><div class="ttdeci">static struct st_hash_type type_strhash</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00048">st.c:48</a></div></div>
<div class="ttc" id="structst__table__entry_html_a2cd684cc9d44752fa7de8946e10e0c13"><div class="ttname"><a href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">st_table_entry::back</a></div><div class="ttdeci">st_table_entry * back</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00025">st.c:25</a></div></div>
<div class="ttc" id="structst__table_html_aedc787fe0df08aff2d4079255a246878"><div class="ttname"><a href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">st_table::head</a></div><div class="ttdeci">struct st_table_entry * head</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00095">st.h:95</a></div></div>
<div class="ttc" id="tkutil_8c_html_a300a5cc1ad956ba66d9082e9e1945142"><div class="ttname"><a href="../../d9/dee/tkutil_8c.html#a300a5cc1ad956ba66d9082e9e1945142">key</a></div><div class="ttdeci">static int VALUE key</div><div class="ttdef"><b>Definition:</b> <a href="../../d9/dee/tkutil_8c_source.html#l00265">tkutil.c:265</a></div></div>
<div class="ttc" id="st_8c_html_ae79a2e19d2287b6ac8d9a82f5c423a1c"><div class="ttname"><a href="../../d4/d71/st_8c.html#ae79a2e19d2287b6ac8d9a82f5c423a1c">rehash</a></div><div class="ttdeci">static void rehash(st_table *)</div></div>
<div class="ttc" id="structst__table__entry_html_a4f0048fd99145b5a1558da33c145ead3"><div class="ttname"><a href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">st_table_entry::fore</a></div><div class="ttdeci">st_table_entry * fore</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00025">st.c:25</a></div></div>
<div class="ttc" id="lex_8c_html_afc4c7aea01574edcf6289eb0e999b889"><div class="ttname"><a href="../../d3/deb/lex_8c.html#afc4c7aea01574edcf6289eb0e999b889">hval</a></div><div class="ttdeci">register int hval</div><div class="ttdef"><b>Definition:</b> <a href="../../d3/deb/lex_8c_source.html#l00089">lex.c:89</a></div></div>
<div class="ttc" id="st_8h_html_aee487969705d500b3308fc5c146fd357"><div class="ttname"><a href="../../dd/d24/st_8h.html#aee487969705d500b3308fc5c146fd357">st_hash_end</a></div><div class="ttdeci">st_index_t st_hash_end(st_index_t h)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01277">st.c:1277</a></div></div>
<div class="ttc" id="tcltklib_8c_html_a7aa3ca79548709bc580aa259ad1fd2d2"><div class="ttname"><a href="../../d5/d9d/tcltklib_8c.html#a7aa3ca79548709bc580aa259ad1fd2d2">memcpy</a></div><div class="ttdeci">memcpy(buf+1, str, len)</div></div>
<div class="ttc" id="tcltklib_8c_html_ae6cf673d09a03d1dfd71928b32d95161"><div class="ttname"><a href="../../d5/d9d/tcltklib_8c.html#ae6cf673d09a03d1dfd71928b32d95161">result</a></div><div class="ttdeci">q result</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d9d/tcltklib_8c_source.html#l07059">tcltklib.c:7059</a></div></div>
<div class="ttc" id="st_8c_html_ab3e563ba13f240493c3b964db47c91d9"><div class="ttname"><a href="../../d4/d71/st_8c.html#ab3e563ba13f240493c3b964db47c91d9">type_numhash</a></div><div class="ttdeci">static struct st_hash_type type_numhash</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00041">st.c:41</a></div></div>
<div class="ttc" id="tcltklib_8c_html_aecdd94a9fd50703da3e57eaf5ccb9809"><div class="ttname"><a href="../../d5/d9d/tcltklib_8c.html#aecdd94a9fd50703da3e57eaf5ccb9809">value</a></div><div class="ttdeci">volatile VALUE value</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d9d/tcltklib_8c_source.html#l09429">tcltklib.c:9429</a></div></div>
<div class="ttc" id="regint_8h_html_adbb0bc2c9aa9b562682b49d3149b8ea3"><div class="ttname"><a href="../../d6/d87/regint_8h.html#adbb0bc2c9aa9b562682b49d3149b8ea3">st_init_table</a></div><div class="ttdeci">#define st_init_table</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00140">regint.h:140</a></div></div>
<div class="ttc" id="tcltklib_8c_html_ae3ed9756fe65ccdbec5dc78d6f3422dc"><div class="ttname"><a href="../../d5/d9d/tcltklib_8c.html#ae3ed9756fe65ccdbec5dc78d6f3422dc">retval</a></div><div class="ttdeci">VALUE retval</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d9d/tcltklib_8c_source.html#l07817">tcltklib.c:7817</a></div></div>
<div class="ttc" id="st_8h_html_a0c6a172fd99de7928916e65034ed8b1f"><div class="ttname"><a href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1f">st_retval</a></div><div class="ttdeci">st_retval</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00100">st.h:100</a></div></div>
<div class="ttc" id="tcltklib_8c_html_ac765329451135abec74c45e1897abf26"><div class="ttname"><a href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a></div><div class="ttdeci">int type</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d9d/tcltklib_8c_source.html#l00107">tcltklib.c:107</a></div></div>
<div class="ttc" id="structst__table_html_ae05091dd67490761fee653130e12c997"><div class="ttname"><a href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">st_table::bins</a></div><div class="ttdeci">struct st_table_entry ** bins</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00094">st.h:94</a></div></div>
<div class="ttc" id="st_8c_html_a40a142ccb9ca21d50ea9f6ed8589cc96"><div class="ttname"><a href="../../d4/d71/st_8c.html#a40a142ccb9ca21d50ea9f6ed8589cc96">FNV1_32A_INIT</a></div><div class="ttdeci">#define FNV1_32A_INIT</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01015">st.c:1015</a></div></div>
<div class="ttc" id="structst__table__entry_html_a7c3f404248d6b3ed3235c49425c2b899"><div class="ttname"><a href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">st_table_entry::key</a></div><div class="ttdeci">st_data_t key</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00022">st.c:22</a></div></div>
<div class="ttc" id="dir_8c_html_aee28fd8a0e40b6d958f7d20348e45368"><div class="ttname"><a href="../../de/d32/dir_8c.html#aee28fd8a0e40b6d958f7d20348e45368">getenv</a></div><div class="ttdeci">char * getenv()</div></div>
<div class="ttc" id="name2ctype_8h_html_aed1cc4dca5d94cb452f79691f54f7423"><div class="ttname"><a href="../../d3/d15/name2ctype_8h.html#aed1cc4dca5d94cb452f79691f54f7423">len</a></div><div class="ttdeci">register unsigned int len</div><div class="ttdef"><b>Definition:</b> <a href="../../d3/d15/name2ctype_8h_source.html#l22210">name2ctype.h:22210</a></div></div>
<div class="ttc" id="st_8c_html_a385b96996caa48e6349681cf8036322f"><div class="ttname"><a href="../../d4/d71/st_8c.html#a385b96996caa48e6349681cf8036322f">alloc</a></div><div class="ttdeci">#define alloc(type)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00069">st.c:69</a></div></div>
<div class="ttc" id="dln_8c_html_affb9fc32698fab7f7b36e0cf8e64c83e"><div class="ttname"><a href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a></div><div class="ttdeci">#define free(x)</div><div class="ttdef"><b>Definition:</b> <a href="../../d1/ddc/dln_8c_source.html#l00050">dln.c:50</a></div></div>
<div class="ttc" id="tcltklib_8c_html_a9d08db2e7a99d650ace90f02ea93108b"><div class="ttname"><a href="../../d5/d9d/tcltklib_8c.html#a9d08db2e7a99d650ace90f02ea93108b">ptr</a></div><div class="ttdeci">return ptr</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d9d/tcltklib_8c_source.html#l00780">tcltklib.c:780</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_a0ae1919f736e3a087fbc9cd8dcba9da9"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#a0ae1919f736e3a087fbc9cd8dcba9da9">c</a></div><div class="ttdeci">VpDivd * c</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l01163">bigdecimal.c:1163</a></div></div>
<div class="ttc" id="ruby_2ruby_8h_html_a308d9dd2c0028ddb184b455bbd7865de"><div class="ttname"><a href="../../de/de6/ruby_2ruby_8h.html#a308d9dd2c0028ddb184b455bbd7865de">CHAR_BIT</a></div><div class="ttdeci">#define CHAR_BIT</div><div class="ttdef"><b>Definition:</b> <a href="../../de/de6/ruby_2ruby_8h_source.html#l00192">ruby.h:192</a></div></div>
<div class="ttc" id="syck_8h_html_a8a45dfe133c1fd041e1b902bda9e43e8"><div class="ttname"><a href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a></div><div class="ttdeci">long st_data_t</div><div class="ttdef"><b>Definition:</b> <a href="../../de/dce/syck_8h_source.html#l00069">syck.h:69</a></div></div>
<div class="ttc" id="sha2_8h_html_a435d1572bf3f880d55459d9805097f62"><div class="ttname"><a href="../../db/d4d/sha2_8h.html#a435d1572bf3f880d55459d9805097f62">uint32_t</a></div><div class="ttdeci">unsigned int uint32_t</div><div class="ttdef"><b>Definition:</b> <a href="../../db/d4d/sha2_8h_source.html#l00101">sha2.h:101</a></div></div>
<div class="ttc" id="st_8h_html_a970b36e65b43e8fcccbea3e3397aeefa"><div class="ttname"><a href="../../dd/d24/st_8h.html#a970b36e65b43e8fcccbea3e3397aeefa">st_hash</a></div><div class="ttdeci">st_index_t st_hash(const void *ptr, size_t len, st_index_t h)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01113">st.c:1113</a></div></div>
<div class="ttc" id="ripper_8y_html_ad608e57b446d6346a20ff2ce5ad16a13"><div class="ttname"><a href="../../d3/d09/ripper_8y.html#ad608e57b446d6346a20ff2ce5ad16a13">arg</a></div><div class="ttdeci">arg</div><div class="ttdef"><b>Definition:</b> <a href="../../d3/d09/ripper_8y_source.html#l01287">ripper.y:1287</a></div></div>
<div class="ttc" id="encoding_8c_html_a439227feff9d7f55384e8780cfc2eb82"><div class="ttname"><a href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a></div><div class="ttdeci">int size</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/db5/encoding_8c_source.html#l00051">encoding.c:51</a></div></div>
<div class="ttc" id="ruby_2ruby_8h_html_ae5d944df8ef1621b6ff43bfcaecb7d46"><div class="ttname"><a href="../../de/de6/ruby_2ruby_8h.html#ae5d944df8ef1621b6ff43bfcaecb7d46">st_strncasecmp</a></div><div class="ttdeci">int st_strncasecmp(const char *s1, const char *s2, size_t n)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01324">st.c:1324</a></div></div>
<div class="ttc" id="st_8h_html_aed6c9d02c64512b18cd464930cb866e1"><div class="ttname"><a href="../../dd/d24/st_8h.html#aed6c9d02c64512b18cd464930cb866e1">st_shift</a></div><div class="ttdeci">int st_shift(st_table *, st_data_t *, st_data_t *)</div></div>
<div class="ttc" id="st_8c_html_a8719b25fa2e849ad268f0bb382bae21c"><div class="ttname"><a href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a></div><div class="ttdeci">#define do_hash(key, table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00075">st.c:75</a></div></div>
<div class="ttc" id="st_8h_html_a1d0d955fb1f39486c18162f222deb82b"><div class="ttname"><a href="../../dd/d24/st_8h.html#a1d0d955fb1f39486c18162f222deb82b">st_memsize</a></div><div class="ttdeci">size_t st_memsize(const st_table *)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00274">st.c:274</a></div></div>
<div class="ttc" id="regint_8h_html_a6de11f24647b8c2938badf820e79a976"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a6de11f24647b8c2938badf820e79a976">st_init_numtable</a></div><div class="ttdeci">#define st_init_numtable</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00142">regint.h:142</a></div></div>
<div class="ttc" id="ripper_8c_html_a93ca48b6ca5634eebe9872b8dc2650ee"><div class="ttname"><a href="../../d5/d11/ripper_8c.html#a93ca48b6ca5634eebe9872b8dc2650ee">t</a></div><div class="ttdeci">int t</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/d11/ripper_8c_source.html#l14285">ripper.c:14285</a></div></div>
<div class="ttc" id="defines_8h_html_af4fd7cbafda9af704310f78516042dfb"><div class="ttname"><a href="../../d8/db0/defines_8h.html#af4fd7cbafda9af704310f78516042dfb">ANYARGS</a></div><div class="ttdeci">#define ANYARGS</div><div class="ttdef"><b>Definition:</b> <a href="../../d8/db0/defines_8h_source.html#l00057">defines.h:57</a></div></div>
<div class="ttc" id="st_8c_html_ab5676cd1fb91981de326030c5b15c867"><div class="ttname"><a href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867">EQUAL</a></div><div class="ttdeci">#define EQUAL(table, x, y)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00072">st.c:72</a></div></div>
<div class="ttc" id="regint_8h_html_a6477fd60857602de7863fc715badfd0d"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a6477fd60857602de7863fc715badfd0d">st_cleanup_safe</a></div><div class="ttdeci">#define st_cleanup_safe</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00153">regint.h:153</a></div></div>
<div class="ttc" id="st_8h_html_ad7c52b70fe389bc967a1868c76a1e10c"><div class="ttname"><a href="../../dd/d24/st_8h.html#ad7c52b70fe389bc967a1868c76a1e10c">st_reverse_foreach</a></div><div class="ttdeci">int st_reverse_foreach(st_table *, int(*)(ANYARGS), st_data_t)</div></div>
<div class="ttc" id="st_8c_html_a2adf90985f6ca4ecff6def2304d3d2dd"><div class="ttname"><a href="../../d4/d71/st_8c.html#a2adf90985f6ca4ecff6def2304d3d2dd">ADD_DIRECT</a></div><div class="ttdeci">#define ADD_DIRECT(table, key, value, hash_val, bin_pos)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00389">st.c:389</a></div></div>
<div class="ttc" id="regint_8h_html_a98c731e7988ea9e138c2deac3ad4a3f1"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a98c731e7988ea9e138c2deac3ad4a3f1">st_add_direct</a></div><div class="ttdeci">#define st_add_direct</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00151">regint.h:151</a></div></div>
<div class="ttc" id="regint_8h_html_ab6920d7d3a34f3d179d1f35806e1965f"><div class="ttname"><a href="../../d6/d87/regint_8h.html#ab6920d7d3a34f3d179d1f35806e1965f">st_insert</a></div><div class="ttdeci">#define st_insert</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00148">regint.h:148</a></div></div>
<div class="ttc" id="defines_8h_html_a40740062faf2d95d4935112447c464ef"><div class="ttname"><a href="../../d8/db0/defines_8h.html#a40740062faf2d95d4935112447c464ef">xrealloc</a></div><div class="ttdeci">#define xrealloc</div><div class="ttdef"><b>Definition:</b> <a href="../../d8/db0/defines_8h_source.html#l00067">defines.h:67</a></div></div>
<div class="ttc" id="regint_8h_html_ae0adede5868e71009c620a32a7b9d61e"><div class="ttname"><a href="../../d6/d87/regint_8h.html#ae0adede5868e71009c620a32a7b9d61e">st_free_table</a></div><div class="ttdeci">#define st_free_table</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00152">regint.h:152</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_a5aed264da6cfdc8d553b69a2508c5334"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#a5aed264da6cfdc8d553b69a2508c5334">e</a></div><div class="ttdeci">BDIGIT e</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l04946">bigdecimal.c:4946</a></div></div>
<div class="ttc" id="ruby_2ruby_8h_html_aa34004564b66661c5c2f6d396e567e93"><div class="ttname"><a href="../../de/de6/ruby_2ruby_8h.html#aa34004564b66661c5c2f6d396e567e93">st_strcasecmp</a></div><div class="ttdeci">int st_strcasecmp(const char *s1, const char *s2)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01300">st.c:1300</a></div></div>
<div class="ttc" id="regint_8h_html"><div class="ttname"><a href="../../d6/d87/regint_8h.html">regint.h</a></div></div>
<div class="ttc" id="st_8h_html_ad6324e2f86dbf2243270fd24aac5367f"><div class="ttname"><a href="../../dd/d24/st_8h.html#ad6324e2f86dbf2243270fd24aac5367f">st_clear</a></div><div class="ttdeci">void st_clear(st_table *)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00241">st.c:241</a></div></div>
<div class="ttc" id="name2ctype_8h_html_a86f2415763322050063a5502f87c9422"><div class="ttname"><a href="../../d3/d15/name2ctype_8h.html#a86f2415763322050063a5502f87c9422">long</a></div><div class="ttdeci">#define long</div><div class="ttdef"><b>Definition:</b> <a href="../../d3/d15/name2ctype_8h_source.html#l00037">name2ctype.h:37</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_acb559820d9ca11295b4500f179ef6392"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#acb559820d9ca11295b4500f179ef6392">i</a></div><div class="ttdeci">ssize_t i</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l05519">bigdecimal.c:5519</a></div></div>
<div class="ttc" id="st_8c_html_a1a0a643d881cfc8e9def03ff92d49b48"><div class="ttname"><a href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48">strcasehash</a></div><div class="ttdeci">static st_index_t strcasehash(st_data_t)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01349">st.c:1349</a></div></div>
<div class="ttc" id="bigdecimal_8c_html_a8603782009ff58be0587ea58013b3e52"><div class="ttname"><a href="../../de/d07/bigdecimal_8c.html#a8603782009ff58be0587ea58013b3e52">v</a></div><div class="ttdeci">BDIGIT v</div><div class="ttdef"><b>Definition:</b> <a href="../../de/d07/bigdecimal_8c_source.html#l05520">bigdecimal.c:5520</a></div></div>
<div class="ttc" id="regint_8h_html_a0cf4ec3779291117380260d7c3579d6c"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a0cf4ec3779291117380260d7c3579d6c">st_copy</a></div><div class="ttdeci">#define st_copy</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00154">regint.h:154</a></div></div>
<div class="ttc" id="structst__table_html_aee1c61d83bbbf2f176255a8a903a92ed"><div class="ttname"><a href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">st_table::tail</a></div><div class="ttdeci">struct st_table_entry * tail</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00095">st.h:95</a></div></div>
<div class="ttc" id="structst__table_html_aa593a5229fc7d02d628a4518f56f71b6"><div class="ttname"><a href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">st_table::num_entries</a></div><div class="ttdeci">st_index_t num_entries</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00093">st.h:93</a></div></div>
<div class="ttc" id="st_8h_html_a50249b52a70e7a4aa8ca8582c380cd26"><div class="ttname"><a href="../../dd/d24/st_8h.html#a50249b52a70e7a4aa8ca8582c380cd26">st_numhash</a></div><div class="ttdeci">st_index_t st_numhash(st_data_t)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01375">st.c:1375</a></div></div>
<div class="ttc" id="regint_8h_html_a00eac09dbce81822a60fc5a7c42cd9ff"><div class="ttname"><a href="../../d6/d87/regint_8h.html#a00eac09dbce81822a60fc5a7c42cd9ff">st_delete_safe</a></div><div class="ttdeci">#define st_delete_safe</div><div class="ttdef"><b>Definition:</b> <a href="../../d6/d87/regint_8h_source.html#l00147">regint.h:147</a></div></div>
<div class="ttc" id="st_8c_html_aecc14cc0cf491182bee62e6d4db68334"><div class="ttname"><a href="../../d4/d71/st_8c.html#aecc14cc0cf491182bee62e6d4db68334">MORE_PACKABLE_P</a></div><div class="ttdeci">#define MORE_PACKABLE_P(table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00385">st.c:385</a></div></div>
<div class="ttc" id="st_8c_html_a4ac8fee05a285361c33a2b0d9c2d555c"><div class="ttname"><a href="../../d4/d71/st_8c.html#a4ac8fee05a285361c33a2b0d9c2d555c">numberof</a></div><div class="ttdeci">#define numberof(array)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00067">st.c:67</a></div></div>
<div class="ttc" id="structst__table_html_af56241399d8c6ebedbea58467e9efa61"><div class="ttname"><a href="../../d0/ddd/structst__table.html#af56241399d8c6ebedbea58467e9efa61">st_table::type</a></div><div class="ttdeci">struct st_hash_type * type</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00078">st.h:78</a></div></div>
</div><!-- fragment --></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.5
</small></address>
</body>
</html>