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
 <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 Page</span></a></li>
<li><a href="../../modules.html"><span>Modules</span></a></li>
<li><a href="../../annotated.html"><span>Data 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 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> <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> </div>
<div class="line"><a name="l00003"></a><span class="lineno"> 3</span> <span class="comment">/* static char sccsid[] = "@(#) st.c 5.1 89/12/14 Crucible"; */</span></div>
<div class="line"><a name="l00004"></a><span class="lineno"> 4</span> </div>
<div class="line"><a name="l00005"></a><span class="lineno"> 5</span> <span class="preprocessor">#ifdef NOT_RUBY</span></div>
<div class="line"><a name="l00006"></a><span class="lineno"> 6</span> <span class="preprocessor"></span><span class="preprocessor">#include "<a class="code" href="../../d6/d87/regint_8h.html">regint.h</a>"</span></div>
<div class="line"><a name="l00007"></a><span class="lineno"> 7</span> <span class="preprocessor">#include "st.h"</span></div>
<div class="line"><a name="l00008"></a><span class="lineno"> 8</span> <span class="preprocessor">#else</span></div>
<div class="line"><a name="l00009"></a><span class="lineno"> 9</span> <span class="preprocessor"></span><span class="preprocessor">#include "<a class="code" href="../../de/de6/ruby_2ruby_8h.html">ruby/ruby.h</a>"</span></div>
<div class="line"><a name="l00010"></a><span class="lineno"> 10</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00011"></a><span class="lineno"> 11</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00012"></a><span class="lineno"> 12</span> <span class="preprocessor">#include <stdio.h></span></div>
<div class="line"><a name="l00013"></a><span class="lineno"> 13</span> <span class="preprocessor">#ifdef HAVE_STDLIB_H</span></div>
<div class="line"><a name="l00014"></a><span class="lineno"> 14</span> <span class="preprocessor"></span><span class="preprocessor">#include <stdlib.h></span></div>
<div class="line"><a name="l00015"></a><span class="lineno"> 15</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00016"></a><span class="lineno"> 16</span> <span class="preprocessor"></span><span class="preprocessor">#include <string.h></span></div>
<div class="line"><a name="l00017"></a><span class="lineno"> 17</span> </div>
<div class="line"><a name="l00018"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4bafc81982b39c3f3fa20e5f7b3dbbf5"> 18</a></span> <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> </div>
<div class="line"><a name="l00020"></a><span class="lineno"><a class="line" href="../../df/dfb/structst__table__entry.html"> 20</a></span> <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>  <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>  <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>  <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>  <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>  <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> };</div>
<div class="line"><a name="l00027"></a><span class="lineno"> 27</span> </div>
<div class="line"><a name="l00028"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4f884be75490db2c92e409a0209fdbcb"> 28</a></span> <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> <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> <span class="preprocessor"></span></div>
<div class="line"><a name="l00031"></a><span class="lineno"> 31</span>  <span class="comment">/*</span></div>
<div class="line"><a name="l00032"></a><span class="lineno"> 32</span> <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> <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> <span class="comment"> * bins</span></div>
<div class="line"><a name="l00035"></a><span class="lineno"> 35</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00036"></a><span class="lineno"> 36</span> <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> <span class="comment"> * allocated initially</span></div>
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00039"></a><span class="lineno"> 39</span> <span class="comment"> */</span></div>
<div class="line"><a name="l00040"></a><span class="lineno"> 40</span> </div>
<div class="line"><a name="l00041"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab3e563ba13f240493c3b964db47c91d9"> 41</a></span> <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>  <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>  <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> };</div>
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span> </div>
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span> <span class="comment">/* extern int strcmp(const char *, const char *); */</span></div>
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span> <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> <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>  strcmp,</div>
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>  <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> };</div>
<div class="line"><a name="l00052"></a><span class="lineno"> 52</span> </div>
<div class="line"><a name="l00053"></a><span class="lineno"> 53</span> <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> <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>  <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>  <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> };</div>
<div class="line"><a name="l00058"></a><span class="lineno"> 58</span> </div>
<div class="line"><a name="l00059"></a><span class="lineno"> 59</span> <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> </div>
<div class="line"><a name="l00061"></a><span class="lineno"> 61</span> <span class="preprocessor">#ifdef RUBY</span></div>
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span> <span class="preprocessor"></span><span class="preprocessor">#define malloc xmalloc</span></div>
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span> <span class="preprocessor"></span><span class="preprocessor">#define calloc xcalloc</span></div>
<div class="line"><a name="l00064"></a><span class="lineno"> 64</span> <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> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00066"></a><span class="lineno"> 66</span> <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> <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> <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> <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> <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> <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> <span class="preprocessor">#define EQUAL(table,x,y) ((x)==(y) || (*(table)->type->compare)((x),(y)) == 0)</span></div>
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00074"></a><span class="lineno"> 74</span> <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> <span class="preprocessor">#define do_hash(key,table) (unsigned int)(st_index_t)(*(table)->type->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> <span class="preprocessor"></span><span class="preprocessor">#define do_hash_bin(key,table) (do_hash((key), (table))%(table)->num_bins)</span></div>
<div class="line"><a name="l00077"></a><span class="lineno"> 77</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00078"></a><span class="lineno"> 78</span> <span class="comment">/*</span></div>
<div class="line"><a name="l00079"></a><span class="lineno"> 79</span> <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> <span class="comment"> */</span></div>
<div class="line"><a name="l00081"></a><span class="lineno"> 81</span> </div>
<div class="line"><a name="l00082"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a76ace81cc961cbcdba26190bcd706326"> 82</a></span> <span class="preprocessor">#define MINSIZE 8</span></div>
<div class="line"><a name="l00083"></a><span class="lineno"> 83</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00084"></a><span class="lineno"> 84</span> <span class="comment">/*</span></div>
<div class="line"><a name="l00085"></a><span class="lineno"> 85</span> <span class="comment">Table of prime numbers 2^n+a, 2<=n<=30.</span></div>
<div class="line"><a name="l00086"></a><span class="lineno"> 86</span> <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> <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>  8 + 3,</div>
<div class="line"><a name="l00089"></a><span class="lineno"> 89</span>  16 + 3,</div>
<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>  32 + 5,</div>
<div class="line"><a name="l00091"></a><span class="lineno"> 91</span>  64 + 3,</div>
<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>  128 + 3,</div>
<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>  256 + 27,</div>
<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>  512 + 9,</div>
<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>  1024 + 9,</div>
<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>  2048 + 5,</div>
<div class="line"><a name="l00097"></a><span class="lineno"> 97</span>  4096 + 3,</div>
<div class="line"><a name="l00098"></a><span class="lineno"> 98</span>  8192 + 27,</div>
<div class="line"><a name="l00099"></a><span class="lineno"> 99</span>  16384 + 43,</div>
<div class="line"><a name="l00100"></a><span class="lineno"> 100</span>  32768 + 3,</div>
<div class="line"><a name="l00101"></a><span class="lineno"> 101</span>  65536 + 45,</div>
<div class="line"><a name="l00102"></a><span class="lineno"> 102</span>  131072 + 29,</div>
<div class="line"><a name="l00103"></a><span class="lineno"> 103</span>  262144 + 3,</div>
<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>  524288 + 21,</div>
<div class="line"><a name="l00105"></a><span class="lineno"> 105</span>  1048576 + 7,</div>
<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>  2097152 + 17,</div>
<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>  4194304 + 15,</div>
<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>  8388608 + 9,</div>
<div class="line"><a name="l00109"></a><span class="lineno"> 109</span>  16777216 + 43,</div>
<div class="line"><a name="l00110"></a><span class="lineno"> 110</span>  33554432 + 35,</div>
<div class="line"><a name="l00111"></a><span class="lineno"> 111</span>  67108864 + 15,</div>
<div class="line"><a name="l00112"></a><span class="lineno"> 112</span>  134217728 + 29,</div>
<div class="line"><a name="l00113"></a><span class="lineno"> 113</span>  268435456 + 3,</div>
<div class="line"><a name="l00114"></a><span class="lineno"> 114</span>  536870912 + 11,</div>
<div class="line"><a name="l00115"></a><span class="lineno"> 115</span>  1073741824 + 85,</div>
<div class="line"><a name="l00116"></a><span class="lineno"> 116</span>  0</div>
<div class="line"><a name="l00117"></a><span class="lineno"> 117</span> };</div>
<div class="line"><a name="l00118"></a><span class="lineno"> 118</span> </div>
<div class="line"><a name="l00119"></a><span class="lineno"> 119</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="l00120"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a"> 120</a></span> <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> {</div>
<div class="line"><a name="l00122"></a><span class="lineno"> 122</span>  <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> </div>
<div class="line"><a name="l00124"></a><span class="lineno"> 124</span> <span class="preprocessor">#if 0</span></div>
<div class="line"><a name="l00125"></a><span class="lineno"> 125</span> <span class="preprocessor"></span> <span class="keywordflow">for</span> (i=3; i<31; i++) {</div>
<div class="line"><a name="l00126"></a><span class="lineno"> 126</span>  <span class="keywordflow">if</span> ((1<<i) > size) <span class="keywordflow">return</span> 1<<<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>  }</div>
<div class="line"><a name="l00128"></a><span class="lineno"> 128</span>  <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l00129"></a><span class="lineno"> 129</span> <span class="preprocessor">#else</span></div>
<div class="line"><a name="l00130"></a><span class="lineno"> 130</span> <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> </div>
<div class="line"><a name="l00132"></a><span class="lineno"> 132</span>  <span class="keywordflow">for</span> (i = 0, newsize = <a class="code" href="../../d4/d71/st_8c.html#a76ace81cc961cbcdba26190bcd706326">MINSIZE</a>; i < <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 <<= 1) {</div>
<div class="line"><a name="l00133"></a><span class="lineno"> 133</span>  <span class="keywordflow">if</span> (newsize > 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>  }</div>
<div class="line"><a name="l00135"></a><span class="lineno"> 135</span>  <span class="comment">/* Ran out of polynomials */</span></div>
<div class="line"><a name="l00136"></a><span class="lineno"> 136</span> <span class="preprocessor">#ifndef NOT_RUBY</span></div>
<div class="line"><a name="l00137"></a><span class="lineno"> 137</span> <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">"st_table too big"</span>);</div>
<div class="line"><a name="l00138"></a><span class="lineno"> 138</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00139"></a><span class="lineno"> 139</span> <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> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00141"></a><span class="lineno"> 141</span> <span class="preprocessor"></span>}</div>
<div class="line"><a name="l00142"></a><span class="lineno"> 142</span> </div>
<div class="line"><a name="l00143"></a><span class="lineno"> 143</span> <span class="preprocessor">#ifdef HASH_LOG</span></div>
<div class="line"><a name="l00144"></a><span class="lineno"> 144</span> <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> <span class="preprocessor"></span><span class="preprocessor">#include <unistd.h></span></div>
<div class="line"><a name="l00146"></a><span class="lineno"> 146</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00147"></a><span class="lineno"> 147</span> <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>  <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> } collision;</div>
<div class="line"><a name="l00150"></a><span class="lineno"> 150</span> <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> </div>
<div class="line"><a name="l00152"></a><span class="lineno"> 152</span> <span class="keyword">static</span> <span class="keywordtype">void</span></div>
<div class="line"><a name="l00153"></a><span class="lineno"> 153</span> stat_col(<span class="keywordtype">void</span>)</div>
<div class="line"><a name="l00154"></a><span class="lineno"> 154</span> {</div>
<div class="line"><a name="l00155"></a><span class="lineno"> 155</span>  <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>  <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">"/tmp/col%ld"</span>, (<span class="keywordtype">long</span>)getpid()), fname), <span class="stringliteral">"w"</span>);</div>
<div class="line"><a name="l00157"></a><span class="lineno"> 157</span>  fprintf(f, <span class="stringliteral">"collision: %d / %d (%6.2f)\n"</span>, collision.all, collision.total,</div>
<div class="line"><a name="l00158"></a><span class="lineno"> 158</span>  ((<span class="keywordtype">double</span>)collision.all / (collision.total)) * 100);</div>
<div class="line"><a name="l00159"></a><span class="lineno"> 159</span>  fprintf(f, <span class="stringliteral">"num: %d, str: %d, strcase: %d\n"</span>, collision.num, collision.str, collision.strcase);</div>
<div class="line"><a name="l00160"></a><span class="lineno"> 160</span>  fclose(f);</div>
<div class="line"><a name="l00161"></a><span class="lineno"> 161</span> }</div>
<div class="line"><a name="l00162"></a><span class="lineno"> 162</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00163"></a><span class="lineno"> 163</span> <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> <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> <span class="preprocessor"></span></div>
<div class="line"><a name="l00166"></a><span class="lineno"> 166</span> <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> <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> {</div>
<div class="line"><a name="l00169"></a><span class="lineno"> 169</span>  <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> </div>
<div class="line"><a name="l00171"></a><span class="lineno"> 171</span> <span class="preprocessor">#ifdef HASH_LOG</span></div>
<div class="line"><a name="l00172"></a><span class="lineno"> 172</span> <span class="preprocessor"></span><span class="preprocessor"># if HASH_LOG+0 < 0</span></div>
<div class="line"><a name="l00173"></a><span class="lineno"> 173</span> <span class="preprocessor"></span> {</div>
<div class="line"><a name="l00174"></a><span class="lineno"> 174</span>  <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">"ST_HASH_LOG"</span>);</div>
<div class="line"><a name="l00175"></a><span class="lineno"> 175</span>  <span class="keywordflow">if</span> (!e || !*e) init_st = 1;</div>
<div class="line"><a name="l00176"></a><span class="lineno"> 176</span>  }</div>
<div class="line"><a name="l00177"></a><span class="lineno"> 177</span> <span class="preprocessor"># endif</span></div>
<div class="line"><a name="l00178"></a><span class="lineno"> 178</span> <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>  init_st = 1;</div>
<div class="line"><a name="l00180"></a><span class="lineno"> 180</span>  atexit(stat_col);</div>
<div class="line"><a name="l00181"></a><span class="lineno"> 181</span>  }</div>
<div class="line"><a name="l00182"></a><span class="lineno"> 182</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00183"></a><span class="lineno"> 183</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00184"></a><span class="lineno"> 184</span>  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> </div>
<div class="line"><a name="l00186"></a><span class="lineno"> 186</span>  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>  tbl-><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>  tbl-><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>  tbl-><a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a> = type == &type_numhash && size/2 <= <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>  tbl-><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>  tbl-><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>  tbl-><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>  tbl-><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> </div>
<div class="line"><a name="l00195"></a><span class="lineno"> 195</span>  <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> }</div>
<div class="line"><a name="l00197"></a><span class="lineno"> 197</span> </div>
<div class="line"><a name="l00198"></a><span class="lineno"> 198</span> <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> <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> {</div>
<div class="line"><a name="l00201"></a><span class="lineno"> 201</span>  <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> }</div>
<div class="line"><a name="l00203"></a><span class="lineno"> 203</span> </div>
<div class="line"><a name="l00204"></a><span class="lineno"> 204</span> <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> <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> {</div>
<div class="line"><a name="l00207"></a><span class="lineno"> 207</span>  <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#adbb0bc2c9aa9b562682b49d3149b8ea3">st_init_table</a>(&type_numhash);</div>
<div class="line"><a name="l00208"></a><span class="lineno"> 208</span> }</div>
<div class="line"><a name="l00209"></a><span class="lineno"> 209</span> </div>
<div class="line"><a name="l00210"></a><span class="lineno"> 210</span> <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> <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> {</div>
<div class="line"><a name="l00213"></a><span class="lineno"> 213</span>  <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a>(&type_numhash, size);</div>
<div class="line"><a name="l00214"></a><span class="lineno"> 214</span> }</div>
<div class="line"><a name="l00215"></a><span class="lineno"> 215</span> </div>
<div class="line"><a name="l00216"></a><span class="lineno"> 216</span> <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> <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> {</div>
<div class="line"><a name="l00219"></a><span class="lineno"> 219</span>  <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#adbb0bc2c9aa9b562682b49d3149b8ea3">st_init_table</a>(&type_strhash);</div>
<div class="line"><a name="l00220"></a><span class="lineno"> 220</span> }</div>
<div class="line"><a name="l00221"></a><span class="lineno"> 221</span> </div>
<div class="line"><a name="l00222"></a><span class="lineno"> 222</span> <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> <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> {</div>
<div class="line"><a name="l00225"></a><span class="lineno"> 225</span>  <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a>(&type_strhash, size);</div>
<div class="line"><a name="l00226"></a><span class="lineno"> 226</span> }</div>
<div class="line"><a name="l00227"></a><span class="lineno"> 227</span> </div>
<div class="line"><a name="l00228"></a><span class="lineno"> 228</span> <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> <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> {</div>
<div class="line"><a name="l00231"></a><span class="lineno"> 231</span>  <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#adbb0bc2c9aa9b562682b49d3149b8ea3">st_init_table</a>(&type_strcasehash);</div>
<div class="line"><a name="l00232"></a><span class="lineno"> 232</span> }</div>
<div class="line"><a name="l00233"></a><span class="lineno"> 233</span> </div>
<div class="line"><a name="l00234"></a><span class="lineno"> 234</span> <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> <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> {</div>
<div class="line"><a name="l00237"></a><span class="lineno"> 237</span>  <span class="keywordflow">return</span> <a class="code" href="../../d6/d87/regint_8h.html#a845e6c2e4ee26cff035aa0a1ca344490">st_init_table_with_size</a>(&type_strcasehash, size);</div>
<div class="line"><a name="l00238"></a><span class="lineno"> 238</span> }</div>
<div class="line"><a name="l00239"></a><span class="lineno"> 239</span> </div>
<div class="line"><a name="l00240"></a><span class="lineno"> 240</span> <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> <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> {</div>
<div class="line"><a name="l00243"></a><span class="lineno"> 243</span>  <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>  <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> </div>
<div class="line"><a name="l00246"></a><span class="lineno"> 246</span>  <span class="keywordflow">if</span> (table-><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>  table-><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>  <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00249"></a><span class="lineno"> 249</span>  }</div>
<div class="line"><a name="l00250"></a><span class="lineno"> 250</span> </div>
<div class="line"><a name="l00251"></a><span class="lineno"> 251</span>  <span class="keywordflow">for</span>(i = 0; i < table-><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>  ptr = table-><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>  table-><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>  <span class="keywordflow">while</span> (ptr != 0) {</div>
<div class="line"><a name="l00255"></a><span class="lineno"> 255</span>  next = ptr-><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>  <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>  ptr = next;</div>
<div class="line"><a name="l00258"></a><span class="lineno"> 258</span>  }</div>
<div class="line"><a name="l00259"></a><span class="lineno"> 259</span>  }</div>
<div class="line"><a name="l00260"></a><span class="lineno"> 260</span>  table-><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>  table-><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>  table-><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> }</div>
<div class="line"><a name="l00264"></a><span class="lineno"> 264</span> </div>
<div class="line"><a name="l00265"></a><span class="lineno"> 265</span> <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> <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> {</div>
<div class="line"><a name="l00268"></a><span class="lineno"> 268</span>  <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>  <a class="code" href="../../d1/ddc/dln_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(table-><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>  <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> }</div>
<div class="line"><a name="l00272"></a><span class="lineno"> 272</span> </div>
<div class="line"><a name="l00273"></a><span class="lineno"> 273</span> <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> <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> {</div>
<div class="line"><a name="l00276"></a><span class="lineno"> 276</span>  <span class="keywordflow">if</span> (table-><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>  <span class="keywordflow">return</span> table-><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>  }</div>
<div class="line"><a name="l00279"></a><span class="lineno"> 279</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00280"></a><span class="lineno"> 280</span>  <span class="keywordflow">return</span> table-><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->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>  }</div>
<div class="line"><a name="l00282"></a><span class="lineno"> 282</span> }</div>
<div class="line"><a name="l00283"></a><span class="lineno"> 283</span> </div>
<div class="line"><a name="l00284"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a349734f8cc08a7685ec22c76d31d0d87"> 284</a></span> <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> <span class="preprocessor">((ptr) != 0 && ((ptr)->hash != (hash_val) || !EQUAL((table), (key), (ptr)->key)))</span></div>
<div class="line"><a name="l00286"></a><span class="lineno"> 286</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00287"></a><span class="lineno"> 287</span> <span class="preprocessor">#ifdef HASH_LOG</span></div>
<div class="line"><a name="l00288"></a><span class="lineno"> 288</span> <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> 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> {</div>
<div class="line"><a name="l00291"></a><span class="lineno"> 291</span>  collision.all++;</div>
<div class="line"><a name="l00292"></a><span class="lineno"> 292</span>  <span class="keywordflow">if</span> (type == &type_numhash) {</div>
<div class="line"><a name="l00293"></a><span class="lineno"> 293</span>  collision.num++;</div>
<div class="line"><a name="l00294"></a><span class="lineno"> 294</span>  }</div>
<div class="line"><a name="l00295"></a><span class="lineno"> 295</span>  <span class="keywordflow">else</span> <span class="keywordflow">if</span> (type == &type_strhash) {</div>
<div class="line"><a name="l00296"></a><span class="lineno"> 296</span>  collision.strcase++;</div>
<div class="line"><a name="l00297"></a><span class="lineno"> 297</span>  }</div>
<div class="line"><a name="l00298"></a><span class="lineno"> 298</span>  <span class="keywordflow">else</span> <span class="keywordflow">if</span> (type == &type_strcasehash) {</div>
<div class="line"><a name="l00299"></a><span class="lineno"> 299</span>  collision.str++;</div>
<div class="line"><a name="l00300"></a><span class="lineno"> 300</span>  }</div>
<div class="line"><a name="l00301"></a><span class="lineno"> 301</span> }</div>
<div class="line"><a name="l00302"></a><span class="lineno"> 302</span> <span class="preprocessor">#define COLLISION (collision_check ? count_collision(table->type) : (void)0)</span></div>
<div class="line"><a name="l00303"></a><span class="lineno"> 303</span> <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> <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> <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> <span class="preprocessor"></span><span class="preprocessor">#define FOUND_ENTRY</span></div>
<div class="line"><a name="l00307"></a><span class="lineno"> 307</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00308"></a><span class="lineno"> 308</span> <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> <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> <span class="preprocessor"> (bin_pos) = (hash_val)%(table)->num_bins;\</span></div>
<div class="line"><a name="l00311"></a><span class="lineno"> 311</span> <span class="preprocessor"> (ptr) = (table)->bins[(bin_pos)];\</span></div>
<div class="line"><a name="l00312"></a><span class="lineno"> 312</span> <span class="preprocessor"> FOUND_ENTRY;\</span></div>
<div class="line"><a name="l00313"></a><span class="lineno"> 313</span> <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> <span class="preprocessor"> COLLISION;\</span></div>
<div class="line"><a name="l00315"></a><span class="lineno"> 315</span> <span class="preprocessor"> while (PTR_NOT_EQUAL((table), (ptr)->next, (hash_val), key)) {\</span></div>
<div class="line"><a name="l00316"></a><span class="lineno"> 316</span> <span class="preprocessor"> (ptr) = (ptr)->next;\</span></div>
<div class="line"><a name="l00317"></a><span class="lineno"> 317</span> <span class="preprocessor"> }\</span></div>
<div class="line"><a name="l00318"></a><span class="lineno"> 318</span> <span class="preprocessor"> (ptr) = (ptr)->next;\</span></div>
<div class="line"><a name="l00319"></a><span class="lineno"> 319</span> <span class="preprocessor"> }\</span></div>
<div class="line"><a name="l00320"></a><span class="lineno"> 320</span> <span class="preprocessor">} while (0)</span></div>
<div class="line"><a name="l00321"></a><span class="lineno"> 321</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00322"></a><span class="lineno"> 322</span> <span class="preprocessor">#define collision_check 0</span></div>
<div class="line"><a name="l00323"></a><span class="lineno"> 323</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00324"></a><span class="lineno"> 324</span> <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> <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> {</div>
<div class="line"><a name="l00327"></a><span class="lineno"> 327</span>  <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>  <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> </div>
<div class="line"><a name="l00330"></a><span class="lineno"> 330</span>  <span class="keywordflow">if</span> (table-><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>  <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>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">if</span> (value !=0) *value = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00336"></a><span class="lineno"> 336</span>  }</div>
<div class="line"><a name="l00337"></a><span class="lineno"> 337</span>  }</div>
<div class="line"><a name="l00338"></a><span class="lineno"> 338</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00339"></a><span class="lineno"> 339</span>  }</div>
<div class="line"><a name="l00340"></a><span class="lineno"> 340</span> </div>
<div class="line"><a name="l00341"></a><span class="lineno"> 341</span>  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>  <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> </div>
<div class="line"><a name="l00344"></a><span class="lineno"> 344</span>  <span class="keywordflow">if</span> (ptr == 0) {</div>
<div class="line"><a name="l00345"></a><span class="lineno"> 345</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00346"></a><span class="lineno"> 346</span>  }</div>
<div class="line"><a name="l00347"></a><span class="lineno"> 347</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00348"></a><span class="lineno"> 348</span>  <span class="keywordflow">if</span> (value != 0) *value = ptr-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00350"></a><span class="lineno"> 350</span>  }</div>
<div class="line"><a name="l00351"></a><span class="lineno"> 351</span> }</div>
<div class="line"><a name="l00352"></a><span class="lineno"> 352</span> </div>
<div class="line"><a name="l00353"></a><span class="lineno"> 353</span> <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> <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> {</div>
<div class="line"><a name="l00356"></a><span class="lineno"> 356</span>  <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>  <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> </div>
<div class="line"><a name="l00359"></a><span class="lineno"> 359</span>  <span class="keywordflow">if</span> (table-><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>  <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>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">if</span> (result !=0) *result = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00365"></a><span class="lineno"> 365</span>  }</div>
<div class="line"><a name="l00366"></a><span class="lineno"> 366</span>  }</div>
<div class="line"><a name="l00367"></a><span class="lineno"> 367</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00368"></a><span class="lineno"> 368</span>  }</div>
<div class="line"><a name="l00369"></a><span class="lineno"> 369</span> </div>
<div class="line"><a name="l00370"></a><span class="lineno"> 370</span>  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>  <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> </div>
<div class="line"><a name="l00373"></a><span class="lineno"> 373</span>  <span class="keywordflow">if</span> (ptr == 0) {</div>
<div class="line"><a name="l00374"></a><span class="lineno"> 374</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00375"></a><span class="lineno"> 375</span>  }</div>
<div class="line"><a name="l00376"></a><span class="lineno"> 376</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00377"></a><span class="lineno"> 377</span>  <span class="keywordflow">if</span> (result != 0) *result = ptr-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00379"></a><span class="lineno"> 379</span>  }</div>
<div class="line"><a name="l00380"></a><span class="lineno"> 380</span> }</div>
<div class="line"><a name="l00381"></a><span class="lineno"> 381</span> </div>
<div class="line"><a name="l00382"></a><span class="lineno"> 382</span> <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> <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> <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> <span class="preprocessor">#define MORE_PACKABLE_P(table) \</span></div>
<div class="line"><a name="l00386"></a><span class="lineno"> 386</span> <span class="preprocessor"> ((st_index_t)((table)->num_entries+1) * 2 <= (table)->num_bins && \</span></div>
<div class="line"><a name="l00387"></a><span class="lineno"> 387</span> <span class="preprocessor"> (table)->num_entries+1 <= MAX_PACKED_NUMHASH)</span></div>
<div class="line"><a name="l00388"></a><span class="lineno"> 388</span> <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> <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> <span class="preprocessor">do {\</span></div>
<div class="line"><a name="l00391"></a><span class="lineno"> 391</span> <span class="preprocessor"> st_table_entry *entry;\</span></div>
<div class="line"><a name="l00392"></a><span class="lineno"> 392</span> <span class="preprocessor"> if ((table)->num_entries > ST_DEFAULT_MAX_DENSITY * (table)->num_bins) {\</span></div>
<div class="line"><a name="l00393"></a><span class="lineno"> 393</span> <span class="preprocessor"> rehash(table);\</span></div>
<div class="line"><a name="l00394"></a><span class="lineno"> 394</span> <span class="preprocessor"> (bin_pos) = (hash_val) % (table)->num_bins;\</span></div>
<div class="line"><a name="l00395"></a><span class="lineno"> 395</span> <span class="preprocessor"> }\</span></div>
<div class="line"><a name="l00396"></a><span class="lineno"> 396</span> <span class="preprocessor"> \</span></div>
<div class="line"><a name="l00397"></a><span class="lineno"> 397</span> <span class="preprocessor"> entry = alloc(st_table_entry);\</span></div>
<div class="line"><a name="l00398"></a><span class="lineno"> 398</span> <span class="preprocessor"> \</span></div>
<div class="line"><a name="l00399"></a><span class="lineno"> 399</span> <span class="preprocessor"> entry->hash = (hash_val);\</span></div>
<div class="line"><a name="l00400"></a><span class="lineno"> 400</span> <span class="preprocessor"> entry->key = (key);\</span></div>
<div class="line"><a name="l00401"></a><span class="lineno"> 401</span> <span class="preprocessor"> entry->record = (value);\</span></div>
<div class="line"><a name="l00402"></a><span class="lineno"> 402</span> <span class="preprocessor"> entry->next = (table)->bins[(bin_pos)];\</span></div>
<div class="line"><a name="l00403"></a><span class="lineno"> 403</span> <span class="preprocessor"> if ((table)->head != 0) {\</span></div>
<div class="line"><a name="l00404"></a><span class="lineno"> 404</span> <span class="preprocessor"> entry->fore = 0;\</span></div>
<div class="line"><a name="l00405"></a><span class="lineno"> 405</span> <span class="preprocessor"> (entry->back = (table)->tail)->fore = entry;\</span></div>
<div class="line"><a name="l00406"></a><span class="lineno"> 406</span> <span class="preprocessor"> (table)->tail = entry;\</span></div>
<div class="line"><a name="l00407"></a><span class="lineno"> 407</span> <span class="preprocessor"> }\</span></div>
<div class="line"><a name="l00408"></a><span class="lineno"> 408</span> <span class="preprocessor"> else {\</span></div>
<div class="line"><a name="l00409"></a><span class="lineno"> 409</span> <span class="preprocessor"> (table)->head = (table)->tail = entry;\</span></div>
<div class="line"><a name="l00410"></a><span class="lineno"> 410</span> <span class="preprocessor"> entry->fore = entry->back = 0;\</span></div>
<div class="line"><a name="l00411"></a><span class="lineno"> 411</span> <span class="preprocessor"> }\</span></div>
<div class="line"><a name="l00412"></a><span class="lineno"> 412</span> <span class="preprocessor"> (table)->bins[(bin_pos)] = entry;\</span></div>
<div class="line"><a name="l00413"></a><span class="lineno"> 413</span> <span class="preprocessor"> (table)->num_entries++;\</span></div>
<div class="line"><a name="l00414"></a><span class="lineno"> 414</span> <span class="preprocessor">} while (0)</span></div>
<div class="line"><a name="l00415"></a><span class="lineno"> 415</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00416"></a><span class="lineno"> 416</span> <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> <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> {</div>
<div class="line"><a name="l00419"></a><span class="lineno"> 419</span>  <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>  <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>  <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> </div>
<div class="line"><a name="l00423"></a><span class="lineno"> 423</span>  <a class="code" href="../../d5/d9d/tcltklib_8c.html#a7aa3ca79548709bc580aa259ad1fd2d2">memcpy</a>(packed_bins, table-><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-><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>  table-><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>  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>  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>  <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>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  <a class="code" href="../../d6/d87/regint_8h.html#ab6920d7d3a34f3d179d1f35806e1965f">st_insert</a>(&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>  }</div>
<div class="line"><a name="l00431"></a><span class="lineno"> 431</span>  *table = tmp_table;</div>
<div class="line"><a name="l00432"></a><span class="lineno"> 432</span> }</div>
<div class="line"><a name="l00433"></a><span class="lineno"> 433</span> </div>
<div class="line"><a name="l00434"></a><span class="lineno"> 434</span> <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> <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> {</div>
<div class="line"><a name="l00437"></a><span class="lineno"> 437</span>  <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>  <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> </div>
<div class="line"><a name="l00440"></a><span class="lineno"> 440</span>  <span class="keywordflow">if</span> (table-><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>  <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>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  table-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00446"></a><span class="lineno"> 446</span>  }</div>
<div class="line"><a name="l00447"></a><span class="lineno"> 447</span>  }</div>
<div class="line"><a name="l00448"></a><span class="lineno"> 448</span>  <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>  i = table-><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>  table-><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>  table-><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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00453"></a><span class="lineno"> 453</span>  }</div>
<div class="line"><a name="l00454"></a><span class="lineno"> 454</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00455"></a><span class="lineno"> 455</span>  <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>  }</div>
<div class="line"><a name="l00457"></a><span class="lineno"> 457</span>  }</div>
<div class="line"><a name="l00458"></a><span class="lineno"> 458</span> </div>
<div class="line"><a name="l00459"></a><span class="lineno"> 459</span>  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>  <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> </div>
<div class="line"><a name="l00462"></a><span class="lineno"> 462</span>  <span class="keywordflow">if</span> (ptr == 0) {</div>
<div class="line"><a name="l00463"></a><span class="lineno"> 463</span>  <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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00465"></a><span class="lineno"> 465</span>  }</div>
<div class="line"><a name="l00466"></a><span class="lineno"> 466</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00467"></a><span class="lineno"> 467</span>  ptr-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00469"></a><span class="lineno"> 469</span>  }</div>
<div class="line"><a name="l00470"></a><span class="lineno"> 470</span> }</div>
<div class="line"><a name="l00471"></a><span class="lineno"> 471</span> </div>
<div class="line"><a name="l00472"></a><span class="lineno"> 472</span> <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> <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>  <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> {</div>
<div class="line"><a name="l00476"></a><span class="lineno"> 476</span>  <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>  <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> </div>
<div class="line"><a name="l00479"></a><span class="lineno"> 479</span>  <span class="keywordflow">if</span> (table-><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>  <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>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  table-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00485"></a><span class="lineno"> 485</span>  }</div>
<div class="line"><a name="l00486"></a><span class="lineno"> 486</span>  }</div>
<div class="line"><a name="l00487"></a><span class="lineno"> 487</span>  <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>  i = table-><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>  table-><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>  table-><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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00492"></a><span class="lineno"> 492</span>  }</div>
<div class="line"><a name="l00493"></a><span class="lineno"> 493</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00494"></a><span class="lineno"> 494</span>  <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>  }</div>
<div class="line"><a name="l00496"></a><span class="lineno"> 496</span>  }</div>
<div class="line"><a name="l00497"></a><span class="lineno"> 497</span> </div>
<div class="line"><a name="l00498"></a><span class="lineno"> 498</span>  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>  <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> </div>
<div class="line"><a name="l00501"></a><span class="lineno"> 501</span>  <span class="keywordflow">if</span> (ptr == 0) {</div>
<div class="line"><a name="l00502"></a><span class="lineno"> 502</span>  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>  <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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00505"></a><span class="lineno"> 505</span>  }</div>
<div class="line"><a name="l00506"></a><span class="lineno"> 506</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00507"></a><span class="lineno"> 507</span>  ptr-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00509"></a><span class="lineno"> 509</span>  }</div>
<div class="line"><a name="l00510"></a><span class="lineno"> 510</span> }</div>
<div class="line"><a name="l00511"></a><span class="lineno"> 511</span> </div>
<div class="line"><a name="l00512"></a><span class="lineno"> 512</span> <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> <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> {</div>
<div class="line"><a name="l00515"></a><span class="lineno"> 515</span>  <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> </div>
<div class="line"><a name="l00517"></a><span class="lineno"> 517</span>  <span class="keywordflow">if</span> (table-><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>  <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>  <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>  i = table-><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>  table-><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>  table-><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>  <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00524"></a><span class="lineno"> 524</span>  }</div>
<div class="line"><a name="l00525"></a><span class="lineno"> 525</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00526"></a><span class="lineno"> 526</span>  <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>  }</div>
<div class="line"><a name="l00528"></a><span class="lineno"> 528</span>  }</div>
<div class="line"><a name="l00529"></a><span class="lineno"> 529</span> </div>
<div class="line"><a name="l00530"></a><span class="lineno"> 530</span>  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>  bin_pos = hash_val % table-><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>  <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> }</div>
<div class="line"><a name="l00534"></a><span class="lineno"> 534</span> </div>
<div class="line"><a name="l00535"></a><span class="lineno"> 535</span> <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> <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> {</div>
<div class="line"><a name="l00538"></a><span class="lineno"> 538</span>  <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>  <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> </div>
<div class="line"><a name="l00541"></a><span class="lineno"> 541</span>  new_num_bins = <a class="code" href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a">new_size</a>(table-><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>  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>  <a class="code" href="../../d8/db0/defines_8h.html#a40740062faf2d95d4935112447c464ef">xrealloc</a>(table-><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>  <span class="keywordflow">for</span> (i = 0; i < 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>  table-><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>  table-><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> </div>
<div class="line"><a name="l00548"></a><span class="lineno"> 548</span>  <span class="keywordflow">if</span> ((ptr = table-><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>  <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00550"></a><span class="lineno"> 550</span>  hash_val = ptr-><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>  ptr-><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>  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>  } <span class="keywordflow">while</span> ((ptr = ptr-><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>  }</div>
<div class="line"><a name="l00555"></a><span class="lineno"> 555</span> }</div>
<div class="line"><a name="l00556"></a><span class="lineno"> 556</span> </div>
<div class="line"><a name="l00557"></a><span class="lineno"> 557</span> <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> <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> {</div>
<div class="line"><a name="l00560"></a><span class="lineno"> 560</span>  <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>  <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>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> num_bins = old_table-><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>  <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> </div>
<div class="line"><a name="l00565"></a><span class="lineno"> 565</span>  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>  <span class="keywordflow">if</span> (new_table == 0) {</div>
<div class="line"><a name="l00567"></a><span class="lineno"> 567</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00568"></a><span class="lineno"> 568</span>  }</div>
<div class="line"><a name="l00569"></a><span class="lineno"> 569</span> </div>
<div class="line"><a name="l00570"></a><span class="lineno"> 570</span>  *new_table = *old_table;</div>
<div class="line"><a name="l00571"></a><span class="lineno"> 571</span>  new_table-><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>  <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> </div>
<div class="line"><a name="l00574"></a><span class="lineno"> 574</span>  <span class="keywordflow">if</span> (new_table-><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>  <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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00577"></a><span class="lineno"> 577</span>  }</div>
<div class="line"><a name="l00578"></a><span class="lineno"> 578</span> </div>
<div class="line"><a name="l00579"></a><span class="lineno"> 579</span>  <span class="keywordflow">if</span> (old_table-><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>  <a class="code" href="../../d5/d9d/tcltklib_8c.html#a7aa3ca79548709bc580aa259ad1fd2d2">memcpy</a>(new_table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, old_table-><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-><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>  <span class="keywordflow">return</span> new_table;</div>
<div class="line"><a name="l00582"></a><span class="lineno"> 582</span>  }</div>
<div class="line"><a name="l00583"></a><span class="lineno"> 583</span> </div>
<div class="line"><a name="l00584"></a><span class="lineno"> 584</span>  <span class="keywordflow">if</span> ((ptr = old_table-><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>  prev = 0;</div>
<div class="line"><a name="l00586"></a><span class="lineno"> 586</span>  tail = &new_table-><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>  <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00588"></a><span class="lineno"> 588</span>  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>  <span class="keywordflow">if</span> (entry == 0) {</div>
<div class="line"><a name="l00590"></a><span class="lineno"> 590</span>  <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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00592"></a><span class="lineno"> 592</span>  }</div>
<div class="line"><a name="l00593"></a><span class="lineno"> 593</span>  *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>  hash_val = entry-><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>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a> = new_table-><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>  new_table-><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>  entry-><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>  *tail = prev = entry;</div>
<div class="line"><a name="l00599"></a><span class="lineno"> 599</span>  tail = &entry-><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>  } <span class="keywordflow">while</span> ((ptr = ptr-><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>  new_table-><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>  }</div>
<div class="line"><a name="l00603"></a><span class="lineno"> 603</span> </div>
<div class="line"><a name="l00604"></a><span class="lineno"> 604</span>  <span class="keywordflow">return</span> new_table;</div>
<div class="line"><a name="l00605"></a><span class="lineno"> 605</span> }</div>
<div class="line"><a name="l00606"></a><span class="lineno"> 606</span> </div>
<div class="line"><a name="l00607"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#afbf658274f1e8229ce3efad9b1eb11d3"> 607</a></span> <span class="preprocessor">#define REMOVE_ENTRY(table, ptr) do \</span></div>
<div class="line"><a name="l00608"></a><span class="lineno"> 608</span> <span class="preprocessor"> { \</span></div>
<div class="line"><a name="l00609"></a><span class="lineno"> 609</span> <span class="preprocessor"> if ((ptr)->fore == 0 && (ptr)->back == 0) { \</span></div>
<div class="line"><a name="l00610"></a><span class="lineno"> 610</span> <span class="preprocessor"> (table)->head = 0; \</span></div>
<div class="line"><a name="l00611"></a><span class="lineno"> 611</span> <span class="preprocessor"> (table)->tail = 0; \</span></div>
<div class="line"><a name="l00612"></a><span class="lineno"> 612</span> <span class="preprocessor"> } \</span></div>
<div class="line"><a name="l00613"></a><span class="lineno"> 613</span> <span class="preprocessor"> else { \</span></div>
<div class="line"><a name="l00614"></a><span class="lineno"> 614</span> <span class="preprocessor"> st_table_entry *fore = (ptr)->fore, *back = (ptr)->back; \</span></div>
<div class="line"><a name="l00615"></a><span class="lineno"> 615</span> <span class="preprocessor"> if (fore) fore->back = back; \</span></div>
<div class="line"><a name="l00616"></a><span class="lineno"> 616</span> <span class="preprocessor"> if (back) back->fore = fore; \</span></div>
<div class="line"><a name="l00617"></a><span class="lineno"> 617</span> <span class="preprocessor"> if ((ptr) == (table)->head) (table)->head = fore; \</span></div>
<div class="line"><a name="l00618"></a><span class="lineno"> 618</span> <span class="preprocessor"> if ((ptr) == (table)->tail) (table)->tail = back; \</span></div>
<div class="line"><a name="l00619"></a><span class="lineno"> 619</span> <span class="preprocessor"> } \</span></div>
<div class="line"><a name="l00620"></a><span class="lineno"> 620</span> <span class="preprocessor"> (table)->num_entries--; \</span></div>
<div class="line"><a name="l00621"></a><span class="lineno"> 621</span> <span class="preprocessor"> } while (0)</span></div>
<div class="line"><a name="l00622"></a><span class="lineno"> 622</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00623"></a><span class="lineno"> 623</span> <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> <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> {</div>
<div class="line"><a name="l00626"></a><span class="lineno"> 626</span>  <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>  <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>  <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> </div>
<div class="line"><a name="l00630"></a><span class="lineno"> 630</span>  <span class="keywordflow">if</span> (table-><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>  <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>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">if</span> (value != 0) *value = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  table-><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>  <a class="code" href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a>(&table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2], &table-><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>  <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-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00639"></a><span class="lineno"> 639</span>  }</div>
<div class="line"><a name="l00640"></a><span class="lineno"> 640</span>  }</div>
<div class="line"><a name="l00641"></a><span class="lineno"> 641</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00642"></a><span class="lineno"> 642</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00643"></a><span class="lineno"> 643</span>  }</div>
<div class="line"><a name="l00644"></a><span class="lineno"> 644</span> </div>
<div class="line"><a name="l00645"></a><span class="lineno"> 645</span>  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> </div>
<div class="line"><a name="l00647"></a><span class="lineno"> 647</span>  <span class="keywordflow">for</span> (prev = &table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val]; (ptr = *prev) != 0; prev = &ptr-><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>  <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867">EQUAL</a>(table, *key, ptr-><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>  *prev = ptr-><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>  <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>  <span class="keywordflow">if</span> (value != 0) *value = ptr-><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>  *key = ptr-><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>  <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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00655"></a><span class="lineno"> 655</span>  }</div>
<div class="line"><a name="l00656"></a><span class="lineno"> 656</span>  }</div>
<div class="line"><a name="l00657"></a><span class="lineno"> 657</span> </div>
<div class="line"><a name="l00658"></a><span class="lineno"> 658</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00659"></a><span class="lineno"> 659</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00660"></a><span class="lineno"> 660</span> }</div>
<div class="line"><a name="l00661"></a><span class="lineno"> 661</span> </div>
<div class="line"><a name="l00662"></a><span class="lineno"> 662</span> <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> <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> {</div>
<div class="line"><a name="l00665"></a><span class="lineno"> 665</span>  <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>  <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> </div>
<div class="line"><a name="l00668"></a><span class="lineno"> 668</span>  <span class="keywordflow">if</span> (table-><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>  <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>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">if</span> (value != 0) *value = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  table-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00675"></a><span class="lineno"> 675</span>  }</div>
<div class="line"><a name="l00676"></a><span class="lineno"> 676</span>  }</div>
<div class="line"><a name="l00677"></a><span class="lineno"> 677</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00678"></a><span class="lineno"> 678</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00679"></a><span class="lineno"> 679</span>  }</div>
<div class="line"><a name="l00680"></a><span class="lineno"> 680</span> </div>
<div class="line"><a name="l00681"></a><span class="lineno"> 681</span>  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>  ptr = table-><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> </div>
<div class="line"><a name="l00684"></a><span class="lineno"> 684</span>  <span class="keywordflow">for</span> (; ptr != 0; ptr = ptr-><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>  <span class="keywordflow">if</span> ((ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a> != never) && <a class="code" href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867">EQUAL</a>(table, ptr-><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>  <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>  *key = ptr-><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>  <span class="keywordflow">if</span> (value != 0) *value = ptr-><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>  ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a> = ptr-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00691"></a><span class="lineno"> 691</span>  }</div>
<div class="line"><a name="l00692"></a><span class="lineno"> 692</span>  }</div>
<div class="line"><a name="l00693"></a><span class="lineno"> 693</span> </div>
<div class="line"><a name="l00694"></a><span class="lineno"> 694</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00695"></a><span class="lineno"> 695</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00696"></a><span class="lineno"> 696</span> }</div>
<div class="line"><a name="l00697"></a><span class="lineno"> 697</span> </div>
<div class="line"><a name="l00698"></a><span class="lineno"> 698</span> <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> <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> {</div>
<div class="line"><a name="l00701"></a><span class="lineno"> 701</span>  <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>  <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>  <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> </div>
<div class="line"><a name="l00705"></a><span class="lineno"> 705</span>  <span class="keywordflow">if</span> (table-><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>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00707"></a><span class="lineno"> 707</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00708"></a><span class="lineno"> 708</span>  }</div>
<div class="line"><a name="l00709"></a><span class="lineno"> 709</span> </div>
<div class="line"><a name="l00710"></a><span class="lineno"> 710</span>  <span class="keywordflow">if</span> (table-><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>  <span class="keywordflow">if</span> (value != 0) *value = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  *key = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  table-><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>  <a class="code" href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a>(&table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[0], &table-><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>  <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-><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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00717"></a><span class="lineno"> 717</span>  }</div>
<div class="line"><a name="l00718"></a><span class="lineno"> 718</span> </div>
<div class="line"><a name="l00719"></a><span class="lineno"> 719</span>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a2e66e2285d7393eca0aea2eac98b8ded">do_hash_bin</a>(table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>-><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>  prev = &table-><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>  <span class="keywordflow">for</span> (;(ptr = *prev) != 0; prev = &ptr-><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>  <span class="keywordflow">if</span> (ptr == table-><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>  *prev = ptr-><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>  <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>  <span class="keywordflow">if</span> (value != 0) *value = ptr-><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>  *key = ptr-><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>  <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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00729"></a><span class="lineno"> 729</span>  }</div>
<div class="line"><a name="l00730"></a><span class="lineno"> 730</span>  }</div>
<div class="line"><a name="l00731"></a><span class="lineno"> 731</span> </div>
<div class="line"><a name="l00732"></a><span class="lineno"> 732</span>  <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>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div>
<div class="line"><a name="l00734"></a><span class="lineno"> 734</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00735"></a><span class="lineno"> 735</span> }</div>
<div class="line"><a name="l00736"></a><span class="lineno"> 736</span> </div>
<div class="line"><a name="l00737"></a><span class="lineno"> 737</span> <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> <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> {</div>
<div class="line"><a name="l00740"></a><span class="lineno"> 740</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>, **<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>  <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> </div>
<div class="line"><a name="l00743"></a><span class="lineno"> 743</span>  <span class="keywordflow">if</span> (table-><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>  <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>  <span class="keywordflow">while</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">if</span> (i++ == table-><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>  }</div>
<div class="line"><a name="l00748"></a><span class="lineno"> 748</span>  <span class="keywordflow">for</span> (j = i; ++i < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[j*2] = table-><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>  table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[j*2+1] = table-><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>  j++;</div>
<div class="line"><a name="l00753"></a><span class="lineno"> 753</span>  }</div>
<div class="line"><a name="l00754"></a><span class="lineno"> 754</span>  table-><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>  <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00756"></a><span class="lineno"> 756</span>  }</div>
<div class="line"><a name="l00757"></a><span class="lineno"> 757</span> </div>
<div class="line"><a name="l00758"></a><span class="lineno"> 758</span>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  ptr = *(last = &table-><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>  <span class="keywordflow">while</span> (ptr != 0) {</div>
<div class="line"><a name="l00761"></a><span class="lineno"> 761</span>  <span class="keywordflow">if</span> (ptr-><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>  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>  *last = ptr = ptr-><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>  <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>  }</div>
<div class="line"><a name="l00766"></a><span class="lineno"> 766</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00767"></a><span class="lineno"> 767</span>  ptr = *(last = &ptr-><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>  }</div>
<div class="line"><a name="l00769"></a><span class="lineno"> 769</span>  }</div>
<div class="line"><a name="l00770"></a><span class="lineno"> 770</span>  }</div>
<div class="line"><a name="l00771"></a><span class="lineno"> 771</span> }</div>
<div class="line"><a name="l00772"></a><span class="lineno"> 772</span> </div>
<div class="line"><a name="l00773"></a><span class="lineno"> 773</span> <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> <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> {</div>
<div class="line"><a name="l00776"></a><span class="lineno"> 776</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>, **<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>  <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>  <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> </div>
<div class="line"><a name="l00780"></a><span class="lineno"> 780</span>  <span class="keywordflow">if</span> (table-><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>  <span class="keywordflow">for</span> (i = 0; i < table-><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>  <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>  <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>  key = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  val = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  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>  <span class="keywordflow">if</span> (!table-><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>  <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>  <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>  <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>  <span class="keywordflow">goto</span> unpacked_continue;</div>
<div class="line"><a name="l00792"></a><span class="lineno"> 792</span>  }</div>
<div class="line"><a name="l00793"></a><span class="lineno"> 793</span>  <span class="keywordflow">goto</span> unpacked;</div>
<div class="line"><a name="l00794"></a><span class="lineno"> 794</span>  }</div>
<div class="line"><a name="l00795"></a><span class="lineno"> 795</span>  <span class="keywordflow">switch</span> (retval) {</div>
<div class="line"><a name="l00796"></a><span class="lineno"> 796</span>  <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>  <span class="keywordflow">for</span> (j = 0; j < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00800"></a><span class="lineno"> 800</span>  }</div>
<div class="line"><a name="l00801"></a><span class="lineno"> 801</span>  <span class="keywordflow">if</span> (j == table-><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>  <span class="keywordflow">goto</span> deleted;</div>
<div class="line"><a name="l00803"></a><span class="lineno"> 803</span>  }</div>
<div class="line"><a name="l00804"></a><span class="lineno"> 804</span>  <span class="comment">/* fall through */</span></div>
<div class="line"><a name="l00805"></a><span class="lineno"> 805</span>  <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>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00807"></a><span class="lineno"> 807</span>  <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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00809"></a><span class="lineno"> 809</span>  <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>  table-><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>  <a class="code" href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a>(&table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2], &table-><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>  <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-><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>  i--;</div>
<div class="line"><a name="l00814"></a><span class="lineno"> 814</span>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00815"></a><span class="lineno"> 815</span>  }</div>
<div class="line"><a name="l00816"></a><span class="lineno"> 816</span>  }</div>
<div class="line"><a name="l00817"></a><span class="lineno"> 817</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00818"></a><span class="lineno"> 818</span>  }</div>
<div class="line"><a name="l00819"></a><span class="lineno"> 819</span>  <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00820"></a><span class="lineno"> 820</span>  ptr = table-><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>  }</div>
<div class="line"><a name="l00822"></a><span class="lineno"> 822</span> </div>
<div class="line"><a name="l00823"></a><span class="lineno"> 823</span>  <span class="keywordflow">if</span> (ptr != 0) {</div>
<div class="line"><a name="l00824"></a><span class="lineno"> 824</span>  <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00825"></a><span class="lineno"> 825</span>  i = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % table-><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>  retval = (*func)(ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>, ptr-><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>  unpacked:</div>
<div class="line"><a name="l00828"></a><span class="lineno"> 828</span>  <span class="keywordflow">switch</span> (retval) {</div>
<div class="line"><a name="l00829"></a><span class="lineno"> 829</span>  <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>  <span class="keywordflow">for</span> (tmp = table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i]; tmp != ptr; tmp = tmp-><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>  <span class="keywordflow">if</span> (!tmp) {</div>
<div class="line"><a name="l00832"></a><span class="lineno"> 832</span>  deleted:</div>
<div class="line"><a name="l00833"></a><span class="lineno"> 833</span>  <span class="comment">/* call func with error notice */</span></div>
<div class="line"><a name="l00834"></a><span class="lineno"> 834</span>  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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00836"></a><span class="lineno"> 836</span>  }</div>
<div class="line"><a name="l00837"></a><span class="lineno"> 837</span>  }</div>
<div class="line"><a name="l00838"></a><span class="lineno"> 838</span>  <span class="comment">/* fall through */</span></div>
<div class="line"><a name="l00839"></a><span class="lineno"> 839</span>  <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>  unpacked_continue:</div>
<div class="line"><a name="l00841"></a><span class="lineno"> 841</span>  ptr = ptr-><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>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00843"></a><span class="lineno"> 843</span>  <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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00845"></a><span class="lineno"> 845</span>  <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>  last = &table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % table-><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>  <span class="keywordflow">for</span> (; (tmp = *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>) != 0; last = &tmp-><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>  <span class="keywordflow">if</span> (ptr == tmp) {</div>
<div class="line"><a name="l00849"></a><span class="lineno"> 849</span>  tmp = ptr-><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>  *last = ptr-><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>  <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>  <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>  <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>  ptr = tmp;</div>
<div class="line"><a name="l00855"></a><span class="lineno"> 855</span>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00856"></a><span class="lineno"> 856</span>  }</div>
<div class="line"><a name="l00857"></a><span class="lineno"> 857</span>  }</div>
<div class="line"><a name="l00858"></a><span class="lineno"> 858</span>  }</div>
<div class="line"><a name="l00859"></a><span class="lineno"> 859</span>  } <span class="keywordflow">while</span> (ptr && table-><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>  }</div>
<div class="line"><a name="l00861"></a><span class="lineno"> 861</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00862"></a><span class="lineno"> 862</span> }</div>
<div class="line"><a name="l00863"></a><span class="lineno"> 863</span> </div>
<div class="line"><a name="l00864"></a><span class="lineno"> 864</span> <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> <span class="preprocessor"></span><span class="keywordtype">int</span></div>
<div class="line"><a name="l00866"></a><span class="lineno"> 866</span> <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> {</div>
<div class="line"><a name="l00868"></a><span class="lineno"> 868</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>, **<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>  <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>  <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> </div>
<div class="line"><a name="l00872"></a><span class="lineno"> 872</span>  <span class="keywordflow">if</span> (table-><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>  <span class="keywordflow">for</span> (i = table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>-1; 0 <= i; i--) {</div>
<div class="line"><a name="l00874"></a><span class="lineno"> 874</span>  <span class="keywordtype">int</span> j;</div>
<div class="line"><a name="l00875"></a><span class="lineno"> 875</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="../../d5/d11/ripper_8c.html#a68fefa607ad528d20b0ae5d69a346d46">val</a>;</div>
<div class="line"><a name="l00876"></a><span class="lineno"> 876</span>  key = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  val = (<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  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>  <span class="keywordflow">switch</span> (retval) {</div>
<div class="line"><a name="l00880"></a><span class="lineno"> 880</span>  <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>  <span class="keywordflow">for</span> (j = 0; j < table-><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>  <span class="keywordflow">if</span> ((<a class="code" href="../../de/dce/syck_8h.html#a8a45dfe133c1fd041e1b902bda9e43e8">st_data_t</a>)table-><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>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00884"></a><span class="lineno"> 884</span>  }</div>
<div class="line"><a name="l00885"></a><span class="lineno"> 885</span>  <span class="keywordflow">if</span> (j == table-><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>  <span class="comment">/* call func with error notice */</span></div>
<div class="line"><a name="l00887"></a><span class="lineno"> 887</span>  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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00889"></a><span class="lineno"> 889</span>  }</div>
<div class="line"><a name="l00890"></a><span class="lineno"> 890</span>  <span class="comment">/* fall through */</span></div>
<div class="line"><a name="l00891"></a><span class="lineno"> 891</span>  <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>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00893"></a><span class="lineno"> 893</span>  <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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00895"></a><span class="lineno"> 895</span>  <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>  table-><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>  <a class="code" href="../../d3/d90/missing_8h.html#a809a3e9326a0d3e5aa549b17085b057d">memmove</a>(&table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i*2], &table-><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>  <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-><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>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00900"></a><span class="lineno"> 900</span>  }</div>
<div class="line"><a name="l00901"></a><span class="lineno"> 901</span>  }</div>
<div class="line"><a name="l00902"></a><span class="lineno"> 902</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00903"></a><span class="lineno"> 903</span>  }</div>
<div class="line"><a name="l00904"></a><span class="lineno"> 904</span> </div>
<div class="line"><a name="l00905"></a><span class="lineno"> 905</span>  <span class="keywordflow">if</span> ((ptr = table-><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>  ptr = ptr-><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>  <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l00908"></a><span class="lineno"> 908</span>  retval = (*func)(ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>, ptr-><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>  <span class="keywordflow">switch</span> (retval) {</div>
<div class="line"><a name="l00910"></a><span class="lineno"> 910</span>  <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>  i = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % table-><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>  <span class="keywordflow">for</span> (tmp = table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i]; tmp != ptr; tmp = tmp-><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>  <span class="keywordflow">if</span> (!tmp) {</div>
<div class="line"><a name="l00914"></a><span class="lineno"> 914</span>  <span class="comment">/* call func with error notice */</span></div>
<div class="line"><a name="l00915"></a><span class="lineno"> 915</span>  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>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l00917"></a><span class="lineno"> 917</span>  }</div>
<div class="line"><a name="l00918"></a><span class="lineno"> 918</span>  }</div>
<div class="line"><a name="l00919"></a><span class="lineno"> 919</span>  <span class="comment">/* fall through */</span></div>
<div class="line"><a name="l00920"></a><span class="lineno"> 920</span>  <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>  ptr = ptr-><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>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00923"></a><span class="lineno"> 923</span>  <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>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00925"></a><span class="lineno"> 925</span>  <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>  last = &table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> % table-><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>  <span class="keywordflow">for</span> (; (tmp = *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>) != 0; last = &tmp-><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>  <span class="keywordflow">if</span> (ptr == tmp) {</div>
<div class="line"><a name="l00929"></a><span class="lineno"> 929</span>  tmp = ptr-><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>  *last = ptr-><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>  <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>  <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>  ptr = tmp;</div>
<div class="line"><a name="l00934"></a><span class="lineno"> 934</span>  <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00935"></a><span class="lineno"> 935</span>  }</div>
<div class="line"><a name="l00936"></a><span class="lineno"> 936</span>  }</div>
<div class="line"><a name="l00937"></a><span class="lineno"> 937</span>  ptr = ptr-><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>  <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>  table-><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>  }</div>
<div class="line"><a name="l00941"></a><span class="lineno"> 941</span>  } <span class="keywordflow">while</span> (ptr && table-><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>  }</div>
<div class="line"><a name="l00943"></a><span class="lineno"> 943</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l00944"></a><span class="lineno"> 944</span> }</div>
<div class="line"><a name="l00945"></a><span class="lineno"> 945</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l00946"></a><span class="lineno"> 946</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l00947"></a><span class="lineno"> 947</span> <span class="comment">/*</span></div>
<div class="line"><a name="l00948"></a><span class="lineno"> 948</span> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00950"></a><span class="lineno"> 950</span> <span class="comment"> * @(#) $Hash32: Revision: 1.1 $</span></div>
<div class="line"><a name="l00951"></a><span class="lineno"> 951</span> <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> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00954"></a><span class="lineno"> 954</span> <span class="comment"> ***</span></div>
<div class="line"><a name="l00955"></a><span class="lineno"> 955</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00956"></a><span class="lineno"> 956</span> <span class="comment"> * Fowler/Noll/Vo hash</span></div>
<div class="line"><a name="l00957"></a><span class="lineno"> 957</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00958"></a><span class="lineno"> 958</span> <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> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00961"></a><span class="lineno"> 961</span> <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> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00964"></a><span class="lineno"> 964</span> <span class="comment"> * In a subsequent ballot round:</span></div>
<div class="line"><a name="l00965"></a><span class="lineno"> 965</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00966"></a><span class="lineno"> 966</span> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00968"></a><span class="lineno"> 968</span> <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> <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> <span class="comment"> * to Landon, they named it the ``Fowler/Noll/Vo'' or FNV hash.</span></div>
<div class="line"><a name="l00971"></a><span class="lineno"> 971</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00972"></a><span class="lineno"> 972</span> <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> <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> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00976"></a><span class="lineno"> 976</span> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00978"></a><span class="lineno"> 978</span> <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> <span class="comment"> ***</span></div>
<div class="line"><a name="l00980"></a><span class="lineno"> 980</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00981"></a><span class="lineno"> 981</span> <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> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00984"></a><span class="lineno"> 984</span> <span class="comment"> ***</span></div>
<div class="line"><a name="l00985"></a><span class="lineno"> 985</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00986"></a><span class="lineno"> 986</span> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l00988"></a><span class="lineno"> 988</span> <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> <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> <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> <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> <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> <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> <span class="comment"> * PERFORMANCE OF THIS SOFTWARE.</span></div>
<div class="line"><a name="l00995"></a><span class="lineno"> 995</span> <span class="comment"> *</span></div>
<div class="line"><a name="l00996"></a><span class="lineno"> 996</span> <span class="comment"> * By:</span></div>
<div class="line"><a name="l00997"></a><span class="lineno"> 997</span> <span class="comment"> * chongo <Landon Curt Noll> /\oo/\</span></div>
<div class="line"><a name="l00998"></a><span class="lineno"> 998</span> <span class="comment"> * http://www.isthe.com/chongo/</span></div>
<div class="line"><a name="l00999"></a><span class="lineno"> 999</span> <span class="comment"> *</span></div>
<div class="line"><a name="l01000"></a><span class="lineno"> 1000</span> <span class="comment"> * Share and Enjoy! :-)</span></div>
<div class="line"><a name="l01001"></a><span class="lineno"> 1001</span> <span class="comment"> */</span></div>
<div class="line"><a name="l01002"></a><span class="lineno"> 1002</span> </div>
<div class="line"><a name="l01003"></a><span class="lineno"> 1003</span> <span class="comment">/*</span></div>
<div class="line"><a name="l01004"></a><span class="lineno"> 1004</span> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l01006"></a><span class="lineno"> 1006</span> <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> <span class="comment"> *</span></div>
<div class="line"><a name="l01008"></a><span class="lineno"> 1008</span> <span class="comment"> * chongo <Landon Curt Noll> /\../\</span></div>
<div class="line"><a name="l01009"></a><span class="lineno"> 1009</span> <span class="comment"> *</span></div>
<div class="line"><a name="l01010"></a><span class="lineno"> 1010</span> <span class="comment"> * NOTE: The \'s above are not back-slashing escape characters.</span></div>
<div class="line"><a name="l01011"></a><span class="lineno"> 1011</span> <span class="comment"> * They are literal ASCII backslash 0x5c characters.</span></div>
<div class="line"><a name="l01012"></a><span class="lineno"> 1012</span> <span class="comment"> *</span></div>
<div class="line"><a name="l01013"></a><span class="lineno"> 1013</span> <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> <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> <span class="preprocessor">#define FNV1_32A_INIT 0x811c9dc5</span></div>
<div class="line"><a name="l01016"></a><span class="lineno"> 1016</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01017"></a><span class="lineno"> 1017</span> <span class="comment">/*</span></div>
<div class="line"><a name="l01018"></a><span class="lineno"> 1018</span> <span class="comment"> * 32 bit magic FNV-1a prime</span></div>
<div class="line"><a name="l01019"></a><span class="lineno"> 1019</span> <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> <span class="preprocessor">#define FNV_32_PRIME 0x01000193</span></div>
<div class="line"><a name="l01021"></a><span class="lineno"> 1021</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01022"></a><span class="lineno"> 1022</span> <span class="preprocessor">#ifdef ST_USE_FNV1</span></div>
<div class="line"><a name="l01023"></a><span class="lineno"> 1023</span> <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> <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> {</div>
<div class="line"><a name="l01026"></a><span class="lineno"> 1026</span>  <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>  <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> </div>
<div class="line"><a name="l01029"></a><span class="lineno"> 1029</span>  <span class="comment">/*</span></div>
<div class="line"><a name="l01030"></a><span class="lineno"> 1030</span> <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> <span class="comment"> */</span></div>
<div class="line"><a name="l01032"></a><span class="lineno"> 1032</span>  <span class="keywordflow">while</span> (*<span class="keywordtype">string</span>) {</div>
<div class="line"><a name="l01033"></a><span class="lineno"> 1033</span>  <span class="comment">/* xor the bottom with the current octet */</span></div>
<div class="line"><a name="l01034"></a><span class="lineno"> 1034</span>  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> </div>
<div class="line"><a name="l01036"></a><span class="lineno"> 1036</span>  <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>  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>  }</div>
<div class="line"><a name="l01039"></a><span class="lineno"> 1039</span>  <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> }</div>
<div class="line"><a name="l01041"></a><span class="lineno"> 1041</span> <span class="preprocessor">#else</span></div>
<div class="line"><a name="l01042"></a><span class="lineno"> 1042</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01043"></a><span class="lineno"> 1043</span> <span class="preprocessor">#ifndef UNALIGNED_WORD_ACCESS</span></div>
<div class="line"><a name="l01044"></a><span class="lineno"> 1044</span> <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> <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> <span class="preprocessor"> defined(__mc68020__)</span></div>
<div class="line"><a name="l01047"></a><span class="lineno"> 1047</span> <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> <span class="preprocessor"></span><span class="preprocessor"># endif</span></div>
<div class="line"><a name="l01049"></a><span class="lineno"> 1049</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01050"></a><span class="lineno"> 1050</span> <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> <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> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01053"></a><span class="lineno"> 1053</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01054"></a><span class="lineno"> 1054</span> <span class="comment">/* MurmurHash described in http://murmurhash.googlepages.com/ */</span></div>
<div class="line"><a name="l01055"></a><span class="lineno"> 1055</span> <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> <span class="preprocessor"></span><span class="preprocessor">#define MURMUR 2</span></div>
<div class="line"><a name="l01057"></a><span class="lineno"> 1057</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01058"></a><span class="lineno"> 1058</span> <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> <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> <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> <span class="preprocessor"></span><span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01062"></a><span class="lineno"> 1062</span> <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> <span class="preprocessor"></span><span class="preprocessor">#elif MURMUR == 2</span></div>
<div class="line"><a name="l01064"></a><span class="lineno"> 1064</span> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T > 4</span></div>
<div class="line"><a name="l01065"></a><span class="lineno"> 1065</span> <span class="preprocessor"></span><span class="preprocessor">#define MurmurMagic ((MurmurMagic_1 << 32) | MurmurMagic_2)</span></div>
<div class="line"><a name="l01066"></a><span class="lineno"> 1066</span> <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> <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> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01069"></a><span class="lineno"> 1069</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01070"></a><span class="lineno"> 1070</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01071"></a><span class="lineno"> 1071</span> <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> <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> {</div>
<div class="line"><a name="l01074"></a><span class="lineno"> 1074</span>  <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> <span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01076"></a><span class="lineno"> 1076</span> <span class="preprocessor"></span> h += k;</div>
<div class="line"><a name="l01077"></a><span class="lineno"> 1077</span>  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>  h ^= h >> <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> <span class="preprocessor">#elif MURMUR == 2</span></div>
<div class="line"><a name="l01080"></a><span class="lineno"> 1080</span> <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>  k ^= k >> <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>  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> </div>
<div class="line"><a name="l01084"></a><span class="lineno"> 1084</span>  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>  h ^= k;</div>
<div class="line"><a name="l01086"></a><span class="lineno"> 1086</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01087"></a><span class="lineno"> 1087</span> <span class="preprocessor"></span> <span class="keywordflow">return</span> h;</div>
<div class="line"><a name="l01088"></a><span class="lineno"> 1088</span> }</div>
<div class="line"><a name="l01089"></a><span class="lineno"> 1089</span> </div>
<div class="line"><a name="l01090"></a><span class="lineno"> 1090</span> <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> <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> {</div>
<div class="line"><a name="l01093"></a><span class="lineno"> 1093</span> <span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01094"></a><span class="lineno"> 1094</span> <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>  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> <span class="preprocessor">#elif MURMUR == 2</span></div>
<div class="line"><a name="l01097"></a><span class="lineno"> 1097</span> <span class="preprocessor"></span> h ^= h >> 13;</div>
<div class="line"><a name="l01098"></a><span class="lineno"> 1098</span>  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>  h ^= h >> 15;</div>
<div class="line"><a name="l01100"></a><span class="lineno"> 1100</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01101"></a><span class="lineno"> 1101</span> <span class="preprocessor"></span> <span class="keywordflow">return</span> h;</div>
<div class="line"><a name="l01102"></a><span class="lineno"> 1102</span> }</div>
<div class="line"><a name="l01103"></a><span class="lineno"> 1103</span> </div>
<div class="line"><a name="l01104"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538"> 1104</a></span> <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> <span class="preprocessor"></span></div>
<div class="line"><a name="l01106"></a><span class="lineno"> 1106</span> <span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01107"></a><span class="lineno"> 1107</span> <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> <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> <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> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01111"></a><span class="lineno"> 1111</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01112"></a><span class="lineno"> 1112</span> <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> <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> {</div>
<div class="line"><a name="l01115"></a><span class="lineno"> 1115</span>  <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>  <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> </div>
<div class="line"><a name="l01118"></a><span class="lineno"> 1118</span>  h += 0xdeadbeef;</div>
<div class="line"><a name="l01119"></a><span class="lineno"> 1119</span> </div>
<div class="line"><a name="l01120"></a><span class="lineno"> 1120</span> <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> <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> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T > 4</span></div>
<div class="line"><a name="l01123"></a><span class="lineno"> 1123</span> <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> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T > 8</span></div>
<div class="line"><a name="l01125"></a><span class="lineno"> 1125</span> <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> <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> <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> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01129"></a><span class="lineno"> 1129</span> <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> <span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01131"></a><span class="lineno"> 1131</span> <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> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01133"></a><span class="lineno"> 1133</span> <span class="preprocessor"></span> <span class="keywordflow">if</span> (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="l01134"></a><span class="lineno"> 1134</span> <span class="preprocessor">#if !UNALIGNED_WORD_ACCESS</span></div>
<div class="line"><a name="l01135"></a><span class="lineno"> 1135</span> <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>  <span class="keywordflow">if</span> (align) {</div>
<div class="line"><a name="l01137"></a><span class="lineno"> 1137</span>  <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>  <span class="keywordtype">int</span> sl, sr, pack;</div>
<div class="line"><a name="l01139"></a><span class="lineno"> 1139</span> </div>
<div class="line"><a name="l01140"></a><span class="lineno"> 1140</span>  <span class="keywordflow">switch</span> (align) {</div>
<div class="line"><a name="l01141"></a><span class="lineno"> 1141</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01142"></a><span class="lineno"> 1142</span> <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> <span class="preprocessor"> t |= data_at(n) << CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 2)</span></div>
<div class="line"><a name="l01144"></a><span class="lineno"> 1144</span> <span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01145"></a><span class="lineno"> 1145</span> <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> <span class="preprocessor"> t |= data_at(n) << CHAR_BIT*(n)</span></div>
<div class="line"><a name="l01147"></a><span class="lineno"> 1147</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01148"></a><span class="lineno"> 1148</span> <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> <span class="preprocessor">#undef UNALIGNED_ADD</span></div>
<div class="line"><a name="l01150"></a><span class="lineno"> 1150</span> <span class="preprocessor"></span> }</div>
<div class="line"><a name="l01151"></a><span class="lineno"> 1151</span> </div>
<div class="line"><a name="l01152"></a><span class="lineno"> 1152</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01153"></a><span class="lineno"> 1153</span> <span class="preprocessor"></span> t >>= (<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> <span class="preprocessor">#else</span></div>
<div class="line"><a name="l01155"></a><span class="lineno"> 1155</span> <span class="preprocessor"></span> t <<= (<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> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01157"></a><span class="lineno"> 1157</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01158"></a><span class="lineno"> 1158</span>  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>  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> </div>
<div class="line"><a name="l01161"></a><span class="lineno"> 1161</span>  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>  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> </div>
<div class="line"><a name="l01164"></a><span class="lineno"> 1164</span>  <span class="keywordflow">while</span> (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="l01165"></a><span class="lineno"> 1165</span>  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> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01167"></a><span class="lineno"> 1167</span> <span class="preprocessor"></span> t = (t << sr) | (d >> sl);</div>
<div class="line"><a name="l01168"></a><span class="lineno"> 1168</span> <span class="preprocessor">#else</span></div>
<div class="line"><a name="l01169"></a><span class="lineno"> 1169</span> <span class="preprocessor"></span> t = (t >> sr) | (d << sl);</div>
<div class="line"><a name="l01170"></a><span class="lineno"> 1170</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01171"></a><span class="lineno"> 1171</span> <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>  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>  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>  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>  }</div>
<div class="line"><a name="l01176"></a><span class="lineno"> 1176</span> </div>
<div class="line"><a name="l01177"></a><span class="lineno"> 1177</span>  pack = len < (size_t)align ? (<span class="keywordtype">int</span>)len : align;</div>
<div class="line"><a name="l01178"></a><span class="lineno"> 1178</span>  d = 0;</div>
<div class="line"><a name="l01179"></a><span class="lineno"> 1179</span>  <span class="keywordflow">switch</span> (pack) {</div>
<div class="line"><a name="l01180"></a><span class="lineno"> 1180</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01181"></a><span class="lineno"> 1181</span> <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> <span class="preprocessor"> d |= data_at(n) << CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 1)</span></div>
<div class="line"><a name="l01183"></a><span class="lineno"> 1183</span> <span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01184"></a><span class="lineno"> 1184</span> <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> <span class="preprocessor"> d |= data_at(n) << CHAR_BIT*(n)</span></div>
<div class="line"><a name="l01186"></a><span class="lineno"> 1186</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01187"></a><span class="lineno"> 1187</span> <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> <span class="preprocessor">#undef UNALIGNED_ADD</span></div>
<div class="line"><a name="l01189"></a><span class="lineno"> 1189</span> <span class="preprocessor"></span> }</div>
<div class="line"><a name="l01190"></a><span class="lineno"> 1190</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01191"></a><span class="lineno"> 1191</span> <span class="preprocessor"></span> t = (t << sr) | (d >> sl);</div>
<div class="line"><a name="l01192"></a><span class="lineno"> 1192</span> <span class="preprocessor">#else</span></div>
<div class="line"><a name="l01193"></a><span class="lineno"> 1193</span> <span class="preprocessor"></span> t = (t >> sr) | (d << sl);</div>
<div class="line"><a name="l01194"></a><span class="lineno"> 1194</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01195"></a><span class="lineno"> 1195</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01196"></a><span class="lineno"> 1196</span> <span class="preprocessor">#if MURMUR == 2</span></div>
<div class="line"><a name="l01197"></a><span class="lineno"> 1197</span> <span class="preprocessor"></span> <span class="keywordflow">if</span> (len < (<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> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01199"></a><span class="lineno"> 1199</span> <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>  data += pack;</div>
<div class="line"><a name="l01201"></a><span class="lineno"> 1201</span>  len -= pack;</div>
<div class="line"><a name="l01202"></a><span class="lineno"> 1202</span>  }</div>
<div class="line"><a name="l01203"></a><span class="lineno"> 1203</span>  <span class="keywordflow">else</span></div>
<div class="line"><a name="l01204"></a><span class="lineno"> 1204</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01205"></a><span class="lineno"> 1205</span> <span class="preprocessor"></span> {</div>
<div class="line"><a name="l01206"></a><span class="lineno"> 1206</span>  <span class="keywordflow">do</span> {</div>
<div class="line"><a name="l01207"></a><span class="lineno"> 1207</span>  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>  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>  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>  } <span class="keywordflow">while</span> (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="l01211"></a><span class="lineno"> 1211</span>  }</div>
<div class="line"><a name="l01212"></a><span class="lineno"> 1212</span>  }</div>
<div class="line"><a name="l01213"></a><span class="lineno"> 1213</span> </div>
<div class="line"><a name="l01214"></a><span class="lineno"> 1214</span>  t = 0;</div>
<div class="line"><a name="l01215"></a><span class="lineno"> 1215</span>  <span class="keywordflow">switch</span> (len) {</div>
<div class="line"><a name="l01216"></a><span class="lineno"> 1216</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01217"></a><span class="lineno"> 1217</span> <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> <span class="preprocessor"> t |= data_at(n) << CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 1)</span></div>
<div class="line"><a name="l01219"></a><span class="lineno"> 1219</span> <span class="preprocessor"></span><span class="preprocessor">#else</span></div>
<div class="line"><a name="l01220"></a><span class="lineno"> 1220</span> <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> <span class="preprocessor"> t |= data_at(n) << CHAR_BIT*(n)</span></div>
<div class="line"><a name="l01222"></a><span class="lineno"> 1222</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01223"></a><span class="lineno"> 1223</span> <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> <span class="preprocessor">#undef UNALIGNED_ADD</span></div>
<div class="line"><a name="l01225"></a><span class="lineno"> 1225</span> <span class="preprocessor"></span><span class="preprocessor">#if MURMUR == 1</span></div>
<div class="line"><a name="l01226"></a><span class="lineno"> 1226</span> <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> <span class="preprocessor">#elif MURMUR == 2</span></div>
<div class="line"><a name="l01228"></a><span class="lineno"> 1228</span> <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> <span class="preprocessor"></span> skip_tail:</div>
<div class="line"><a name="l01230"></a><span class="lineno"> 1230</span> <span class="preprocessor"># endif</span></div>
<div class="line"><a name="l01231"></a><span class="lineno"> 1231</span> <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>  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> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01234"></a><span class="lineno"> 1234</span> <span class="preprocessor"></span> }</div>
<div class="line"><a name="l01235"></a><span class="lineno"> 1235</span> </div>
<div class="line"><a name="l01236"></a><span class="lineno"> 1236</span>  <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> }</div>
<div class="line"><a name="l01238"></a><span class="lineno"> 1238</span> </div>
<div class="line"><a name="l01239"></a><span class="lineno"> 1239</span> <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> <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> {</div>
<div class="line"><a name="l01242"></a><span class="lineno"> 1242</span>  <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> }</div>
<div class="line"><a name="l01244"></a><span class="lineno"> 1244</span> </div>
<div class="line"><a name="l01245"></a><span class="lineno"> 1245</span> <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> <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> {</div>
<div class="line"><a name="l01248"></a><span class="lineno"> 1248</span>  <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>  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> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01251"></a><span class="lineno"> 1251</span> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 12*8</span></div>
<div class="line"><a name="l01252"></a><span class="lineno"> 1252</span> <span class="preprocessor"></span> v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 12*8));</div>
<div class="line"><a name="l01253"></a><span class="lineno"> 1253</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01254"></a><span class="lineno"> 1254</span> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 8*8</span></div>
<div class="line"><a name="l01255"></a><span class="lineno"> 1255</span> <span class="preprocessor"></span> v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 8*8));</div>
<div class="line"><a name="l01256"></a><span class="lineno"> 1256</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01257"></a><span class="lineno"> 1257</span> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 4*8</span></div>
<div class="line"><a name="l01258"></a><span class="lineno"> 1258</span> <span class="preprocessor"></span> v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 4*8));</div>
<div class="line"><a name="l01259"></a><span class="lineno"> 1259</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01260"></a><span class="lineno"> 1260</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01261"></a><span class="lineno"> 1261</span> <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> <span class="preprocessor">#ifndef WORDS_BIGENDIAN</span></div>
<div class="line"><a name="l01263"></a><span class="lineno"> 1263</span> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 4*8</span></div>
<div class="line"><a name="l01264"></a><span class="lineno"> 1264</span> <span class="preprocessor"></span> v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 4*8));</div>
<div class="line"><a name="l01265"></a><span class="lineno"> 1265</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01266"></a><span class="lineno"> 1266</span> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 8*8</span></div>
<div class="line"><a name="l01267"></a><span class="lineno"> 1267</span> <span class="preprocessor"></span> v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 8*8));</div>
<div class="line"><a name="l01268"></a><span class="lineno"> 1268</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01269"></a><span class="lineno"> 1269</span> <span class="preprocessor"></span><span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 12*8</span></div>
<div class="line"><a name="l01270"></a><span class="lineno"> 1270</span> <span class="preprocessor"></span> v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 12*8));</div>
<div class="line"><a name="l01271"></a><span class="lineno"> 1271</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01272"></a><span class="lineno"> 1272</span> <span class="preprocessor"></span><span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01273"></a><span class="lineno"> 1273</span> <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> }</div>
<div class="line"><a name="l01275"></a><span class="lineno"> 1275</span> </div>
<div class="line"><a name="l01276"></a><span class="lineno"> 1276</span> <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> <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> {</div>
<div class="line"><a name="l01279"></a><span class="lineno"> 1279</span>  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>  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>  <span class="keywordflow">return</span> h;</div>
<div class="line"><a name="l01282"></a><span class="lineno"> 1282</span> }</div>
<div class="line"><a name="l01283"></a><span class="lineno"> 1283</span> </div>
<div class="line"><a name="l01284"></a><span class="lineno"> 1284</span> <span class="preprocessor">#undef st_hash_start</span></div>
<div class="line"><a name="l01285"></a><span class="lineno"> 1285</span> <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> <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> {</div>
<div class="line"><a name="l01288"></a><span class="lineno"> 1288</span>  <span class="keywordflow">return</span> h;</div>
<div class="line"><a name="l01289"></a><span class="lineno"> 1289</span> }</div>
<div class="line"><a name="l01290"></a><span class="lineno"> 1290</span> </div>
<div class="line"><a name="l01291"></a><span class="lineno"> 1291</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="l01292"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7"> 1292</a></span> <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> {</div>
<div class="line"><a name="l01294"></a><span class="lineno"> 1294</span>  <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>  <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> }</div>
<div class="line"><a name="l01297"></a><span class="lineno"> 1297</span> <span class="preprocessor">#endif</span></div>
<div class="line"><a name="l01298"></a><span class="lineno"> 1298</span> <span class="preprocessor"></span></div>
<div class="line"><a name="l01299"></a><span class="lineno"> 1299</span> <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> <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> {</div>
<div class="line"><a name="l01302"></a><span class="lineno"> 1302</span>  <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> </div>
<div class="line"><a name="l01304"></a><span class="lineno"> 1304</span>  <span class="keywordflow">while</span> (1) {</div>
<div class="line"><a name="l01305"></a><span class="lineno"> 1305</span>  c1 = (<span class="keywordtype">unsigned</span> char)*s1++;</div>
<div class="line"><a name="l01306"></a><span class="lineno"> 1306</span>  c2 = (<span class="keywordtype">unsigned</span> char)*s2++;</div>
<div class="line"><a name="l01307"></a><span class="lineno"> 1307</span>  <span class="keywordflow">if</span> (c1 == <span class="charliteral">'\0'</span> || c2 == <span class="charliteral">'\0'</span>) {</div>
<div class="line"><a name="l01308"></a><span class="lineno"> 1308</span>  <span class="keywordflow">if</span> (c1 != <span class="charliteral">'\0'</span>) <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l01309"></a><span class="lineno"> 1309</span>  <span class="keywordflow">if</span> (c2 != <span class="charliteral">'\0'</span>) <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l01310"></a><span class="lineno"> 1310</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l01311"></a><span class="lineno"> 1311</span>  }</div>
<div class="line"><a name="l01312"></a><span class="lineno"> 1312</span>  <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c1 - <span class="charliteral">'A'</span>) <= (<span class="charliteral">'Z'</span> - <span class="charliteral">'A'</span>)) c1 += <span class="charliteral">'a'</span> - <span class="charliteral">'A'</span>;</div>
<div class="line"><a name="l01313"></a><span class="lineno"> 1313</span>  <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c2 - <span class="charliteral">'A'</span>) <= (<span class="charliteral">'Z'</span> - <span class="charliteral">'A'</span>)) c2 += <span class="charliteral">'a'</span> - <span class="charliteral">'A'</span>;</div>
<div class="line"><a name="l01314"></a><span class="lineno"> 1314</span>  <span class="keywordflow">if</span> (c1 != c2) {</div>
<div class="line"><a name="l01315"></a><span class="lineno"> 1315</span>  <span class="keywordflow">if</span> (c1 > c2)</div>
<div class="line"><a name="l01316"></a><span class="lineno"> 1316</span>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l01317"></a><span class="lineno"> 1317</span>  <span class="keywordflow">else</span></div>
<div class="line"><a name="l01318"></a><span class="lineno"> 1318</span>  <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l01319"></a><span class="lineno"> 1319</span>  }</div>
<div class="line"><a name="l01320"></a><span class="lineno"> 1320</span>  }</div>
<div class="line"><a name="l01321"></a><span class="lineno"> 1321</span> }</div>
<div class="line"><a name="l01322"></a><span class="lineno"> 1322</span> </div>
<div class="line"><a name="l01323"></a><span class="lineno"> 1323</span> <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> <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> {</div>
<div class="line"><a name="l01326"></a><span class="lineno"> 1326</span>  <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> </div>
<div class="line"><a name="l01328"></a><span class="lineno"> 1328</span>  <span class="keywordflow">while</span> (n--) {</div>
<div class="line"><a name="l01329"></a><span class="lineno"> 1329</span>  c1 = (<span class="keywordtype">unsigned</span> char)*s1++;</div>
<div class="line"><a name="l01330"></a><span class="lineno"> 1330</span>  c2 = (<span class="keywordtype">unsigned</span> char)*s2++;</div>
<div class="line"><a name="l01331"></a><span class="lineno"> 1331</span>  <span class="keywordflow">if</span> (c1 == <span class="charliteral">'\0'</span> || c2 == <span class="charliteral">'\0'</span>) {</div>
<div class="line"><a name="l01332"></a><span class="lineno"> 1332</span>  <span class="keywordflow">if</span> (c1 != <span class="charliteral">'\0'</span>) <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l01333"></a><span class="lineno"> 1333</span>  <span class="keywordflow">if</span> (c2 != <span class="charliteral">'\0'</span>) <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l01334"></a><span class="lineno"> 1334</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l01335"></a><span class="lineno"> 1335</span>  }</div>
<div class="line"><a name="l01336"></a><span class="lineno"> 1336</span>  <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c1 - <span class="charliteral">'A'</span>) <= (<span class="charliteral">'Z'</span> - <span class="charliteral">'A'</span>)) c1 += <span class="charliteral">'a'</span> - <span class="charliteral">'A'</span>;</div>
<div class="line"><a name="l01337"></a><span class="lineno"> 1337</span>  <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c2 - <span class="charliteral">'A'</span>) <= (<span class="charliteral">'Z'</span> - <span class="charliteral">'A'</span>)) c2 += <span class="charliteral">'a'</span> - <span class="charliteral">'A'</span>;</div>
<div class="line"><a name="l01338"></a><span class="lineno"> 1338</span>  <span class="keywordflow">if</span> (c1 != c2) {</div>
<div class="line"><a name="l01339"></a><span class="lineno"> 1339</span>  <span class="keywordflow">if</span> (c1 > c2)</div>
<div class="line"><a name="l01340"></a><span class="lineno"> 1340</span>  <span class="keywordflow">return</span> 1;</div>
<div class="line"><a name="l01341"></a><span class="lineno"> 1341</span>  <span class="keywordflow">else</span></div>
<div class="line"><a name="l01342"></a><span class="lineno"> 1342</span>  <span class="keywordflow">return</span> -1;</div>
<div class="line"><a name="l01343"></a><span class="lineno"> 1343</span>  }</div>
<div class="line"><a name="l01344"></a><span class="lineno"> 1344</span>  }</div>
<div class="line"><a name="l01345"></a><span class="lineno"> 1345</span>  <span class="keywordflow">return</span> 0;</div>
<div class="line"><a name="l01346"></a><span class="lineno"> 1346</span> }</div>
<div class="line"><a name="l01347"></a><span class="lineno"> 1347</span> </div>
<div class="line"><a name="l01348"></a><span class="lineno"> 1348</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="l01349"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48"> 1349</a></span> <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> {</div>
<div class="line"><a name="l01351"></a><span class="lineno"> 1351</span>  <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>  <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> </div>
<div class="line"><a name="l01354"></a><span class="lineno"> 1354</span>  <span class="comment">/*</span></div>
<div class="line"><a name="l01355"></a><span class="lineno"> 1355</span> <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> <span class="comment"> */</span></div>
<div class="line"><a name="l01357"></a><span class="lineno"> 1357</span>  <span class="keywordflow">while</span> (*<span class="keywordtype">string</span>) {</div>
<div class="line"><a name="l01358"></a><span class="lineno"> 1358</span>  <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>  <span class="keywordflow">if</span> ((<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>)(c - <span class="charliteral">'A'</span>) <= (<span class="charliteral">'Z'</span> - <span class="charliteral">'A'</span>)) c += <span class="charliteral">'a'</span> - <span class="charliteral">'A'</span>;</div>
<div class="line"><a name="l01360"></a><span class="lineno"> 1360</span>  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> </div>
<div class="line"><a name="l01362"></a><span class="lineno"> 1362</span>  <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>  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>  }</div>
<div class="line"><a name="l01365"></a><span class="lineno"> 1365</span>  <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> }</div>
<div class="line"><a name="l01367"></a><span class="lineno"> 1367</span> </div>
<div class="line"><a name="l01368"></a><span class="lineno"> 1368</span> <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> <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> {</div>
<div class="line"><a name="l01371"></a><span class="lineno"> 1371</span>  <span class="keywordflow">return</span> x != y;</div>
<div class="line"><a name="l01372"></a><span class="lineno"> 1372</span> }</div>
<div class="line"><a name="l01373"></a><span class="lineno"> 1373</span> </div>
<div class="line"><a name="l01374"></a><span class="lineno"> 1374</span> <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> <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> {</div>
<div class="line"><a name="l01377"></a><span class="lineno"> 1377</span>  <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> }</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->frac+ix+1, 0,(y->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  <a href="http://www.doxygen.org/index.html">
<img class="footer" src="../../doxygen.png" alt="doxygen"/>
</a> 1.8.5
</small></address>
</body>
</html>