Linux heracles.o2switch.net 4.18.0-553.62.1.lve.el8.x86_64 #1 SMP Mon Jul 21 17:50:35 UTC 2025 x86_64
/
opt
/
alt
/
ruby21
/
share
/
doc
/
ruby
/
capi
/
html
/
d4
/
d71
/
//opt/alt/ruby21/share/doc/ruby/capi/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.14"/> <meta name="viewport" content="width=device-width, initial-scale=1"/> <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 id="projectalign" style="padding-left: 0.5em;"> <div id="projectname">Ruby  <span id="projectnumber">2.1.10p492(2016-04-01revision54464)</span> </div> </td> </tr> </tbody> </table> </div> <!-- end header part --> <!-- Generated by Doxygen 1.8.14 --> <script type="text/javascript" src="../../menudata.js"></script> <script type="text/javascript" src="../../menu.js"></script> <script type="text/javascript"> /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ $(function() { initMenu('../../',false,false,'search.php','Search'); }); /* @license-end */</script> <div id="main-nav"></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">#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">#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> </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">#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">#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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">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="../../d8/ddd/structst__packed__entry.html"> 28</a></span> <span class="keyword">typedef</span> <span class="keyword">struct </span><a class="code" href="../../d8/ddd/structst__packed__entry.html">st_packed_entry</a> {</div><div class="line"><a name="l00029"></a><span class="lineno"><a class="line" href="../../d8/ddd/structst__packed__entry.html#a35a714a0761f0319735d1ce91298328b"> 29</a></span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d8/ddd/structst__packed__entry.html#a35a714a0761f0319735d1ce91298328b">hash</a>;</div><div class="line"><a name="l00030"></a><span class="lineno"><a class="line" href="../../d8/ddd/structst__packed__entry.html#a709049731ea4672ec675de3585e97c31"> 30</a></span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../d8/ddd/structst__packed__entry.html#ad82c9cdfeaa161b28652002eeaf1999c">key</a>, <a class="code" href="../../d8/ddd/structst__packed__entry.html#a709049731ea4672ec675de3585e97c31">val</a>;</div><div class="line"><a name="l00031"></a><span class="lineno"> 31</span> } <a class="code" href="../../d4/d71/st_8c.html#a733a85dcefc9d237eb5cf9fb38798e42">st_packed_entry</a>;</div><div class="line"><a name="l00032"></a><span class="lineno"> 32</span> </div><div class="line"><a name="l00033"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a7c82a8a77cae6b7a0ad72e9a43e8d0c5"> 33</a></span> <span class="preprocessor">#define STATIC_ASSERT(name, expr) typedef int static_assert_##name##_check[(expr) ? 1 : -1];</span></div><div class="line"><a name="l00034"></a><span class="lineno"> 34</span> </div><div class="line"><a name="l00035"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4f884be75490db2c92e409a0209fdbcb"> 35</a></span> <span class="preprocessor">#define ST_DEFAULT_MAX_DENSITY 5</span></div><div class="line"><a name="l00036"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a311df13f4d458054df7d87ca22782ab2"> 36</a></span> <span class="preprocessor">#define ST_DEFAULT_INIT_TABLE_SIZE 11</span></div><div class="line"><a name="l00037"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#af968643d33d8ca4088601fdad8783913"> 37</a></span> <span class="preprocessor">#define ST_DEFAULT_SECOND_TABLE_SIZE 19</span></div><div class="line"><a name="l00038"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab1314d055fd90b84911a9ec5e802edf7"> 38</a></span> <span class="preprocessor">#define ST_DEFAULT_PACKED_TABLE_SIZE 18</span></div><div class="line"><a name="l00039"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a157fecaa7d870fdf190ee0f8c073edd1"> 39</a></span> <span class="preprocessor">#define PACKED_UNIT (int)(sizeof(st_packed_entry) / sizeof(st_table_entry*))</span></div><div class="line"><a name="l00040"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a2e84b634e97a0834e9f03658d1cb202f"> 40</a></span> <span class="preprocessor">#define MAX_PACKED_HASH (int)(ST_DEFAULT_PACKED_TABLE_SIZE * sizeof(st_table_entry*) / sizeof(st_packed_entry))</span></div><div class="line"><a name="l00041"></a><span class="lineno"> 41</span> </div><div class="line"><a name="l00042"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a58d32e5d38529e5a66c736fa198737db"> 42</a></span> <a class="code" href="../../d4/d71/st_8c.html#a7c82a8a77cae6b7a0ad72e9a43e8d0c5">STATIC_ASSERT</a>(<a class="code" href="../../d8/ddd/structst__packed__entry.html">st_packed_entry</a>, <span class="keyword">sizeof</span>(<a class="code" href="../../d8/ddd/structst__packed__entry.html">st_packed_entry</a>) == <span class="keyword">sizeof</span>(<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*[<a class="code" href="../../d4/d71/st_8c.html#a157fecaa7d870fdf190ee0f8c073edd1">PACKED_UNIT</a>]))</div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span> <a class="code" href="../../d4/d71/st_8c.html#a7c82a8a77cae6b7a0ad72e9a43e8d0c5">STATIC_ASSERT</a>(st_packed_bins, <span class="keyword">sizeof</span>(<a class="code" href="../../d8/ddd/structst__packed__entry.html">st_packed_entry</a>[<a class="code" href="../../d4/d71/st_8c.html#a2e84b634e97a0834e9f03658d1cb202f">MAX_PACKED_HASH</a>]) <= <span class="keyword">sizeof</span>(<a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*[<a class="code" href="../../d4/d71/st_8c.html#ab1314d055fd90b84911a9ec5e802edf7">ST_DEFAULT_PACKED_TABLE_SIZE</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>  <span class="comment">/*</span></div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span> <span class="comment"> * DEFAULT_MAX_DENSITY is the default for the largest we allow the</span></div><div class="line"><a name="l00047"></a><span class="lineno"> 47</span> <span class="comment"> * average number of items per bin before increasing the number of</span></div><div class="line"><a name="l00048"></a><span class="lineno"> 48</span> <span class="comment"> * bins</span></div><div class="line"><a name="l00049"></a><span class="lineno"> 49</span> <span class="comment"> *</span></div><div class="line"><a name="l00050"></a><span class="lineno"> 50</span> <span class="comment"> * DEFAULT_INIT_TABLE_SIZE is the default for the number of bins</span></div><div class="line"><a name="l00051"></a><span class="lineno"> 51</span> <span class="comment"> * allocated initially</span></div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span> <span class="comment"> *</span></div><div class="line"><a name="l00053"></a><span class="lineno"> 53</span> <span class="comment"> */</span></div><div class="line"><a name="l00054"></a><span class="lineno"> 54</span> </div><div class="line"><a name="l00055"></a><span class="lineno"> 55</span> <span class="preprocessor">#define type_numhash st_hashtype_num</span></div><div class="line"><a name="l00056"></a><span class="lineno"> 56</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="../../d1/d04/hash_8c.html#afd38f591d634bb21e98b8bc7b0e6ac49">st_hashtype_num</a> = {</div><div class="line"><a name="l00057"></a><span class="lineno"> 57</span>  <a class="code" href="../../d4/d71/st_8c.html#a4c9a444f4aabb6c83a19c5afacbfdaf6">st_numcmp</a>,</div><div class="line"><a name="l00058"></a><span class="lineno"> 58</span>  <a class="code" href="../../d4/d71/st_8c.html#a012fbc7aee9522e01fa622dd6aafbaee">st_numhash</a>,</div><div class="line"><a name="l00059"></a><span class="lineno"> 59</span> };</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="comment">/* extern int strcmp(const char *, const char *); */</span></div><div class="line"><a name="l00062"></a><span class="lineno"> 62</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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a>);</div><div class="line"><a name="l00063"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#af83cfc72d5d16b336475bf69c3a95133"> 63</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#af83cfc72d5d16b336475bf69c3a95133">type_strhash</a> = {</div><div class="line"><a name="l00064"></a><span class="lineno"> 64</span>  strcmp,</div><div class="line"><a name="l00065"></a><span class="lineno"> 65</span>  <a class="code" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7">strhash</a>,</div><div class="line"><a name="l00066"></a><span class="lineno"> 66</span> };</div><div class="line"><a name="l00067"></a><span class="lineno"> 67</span> </div><div class="line"><a name="l00068"></a><span class="lineno"> 68</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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a>);</div><div class="line"><a name="l00069"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a028396ceb63492536a3609e4e824d148"> 69</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#a028396ceb63492536a3609e4e824d148">type_strcasehash</a> = {</div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span>  <a class="code" href="../../d4/d71/st_8c.html#a2cae14784f5ba5121ab215cb3e1c6a53">st_locale_insensitive_strcasecmp</a>,</div><div class="line"><a name="l00071"></a><span class="lineno"> 71</span>  <a class="code" href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48">strcasehash</a>,</div><div class="line"><a name="l00072"></a><span class="lineno"> 72</span> };</div><div class="line"><a name="l00073"></a><span class="lineno"> 73</span> </div><div class="line"><a name="l00074"></a><span class="lineno"> 74</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="l00075"></a><span class="lineno"> 75</span> </div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span> <span class="preprocessor">#ifdef RUBY</span></div><div class="line"><a name="l00077"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#acf143577800376dd931c059ecc61ba06"> 77</a></span> <span class="preprocessor">#define malloc xmalloc</span></div><div class="line"><a name="l00078"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a84beef8cc122add35118ec7cd35286c4"> 78</a></span> <span class="preprocessor">#define calloc xcalloc</span></div><div class="line"><a name="l00079"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1b739878adcdb46fb5d209af7ce79628"> 79</a></span> <span class="preprocessor">#define realloc xrealloc</span></div><div class="line"><a name="l00080"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e"> 80</a></span> <span class="preprocessor">#define free(x) xfree(x)</span></div><div class="line"><a name="l00081"></a><span class="lineno"> 81</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l00082"></a><span class="lineno"> 82</span> </div><div class="line"><a name="l00083"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4ac8fee05a285361c33a2b0d9c2d555c"> 83</a></span> <span class="preprocessor">#define numberof(array) (int)(sizeof(array) / sizeof((array)[0]))</span></div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span> </div><div class="line"><a name="l00085"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867"> 85</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="l00086"></a><span class="lineno"> 86</span> </div><div class="line"><a name="l00087"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c"> 87</a></span> <span class="preprocessor">#define do_hash(key,table) (st_index_t)(*(table)->type->hash)((key))</span></div><div class="line"><a name="l00088"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a2e66e2285d7393eca0aea2eac98b8ded"> 88</a></span> <span class="preprocessor">#define do_hash_bin(key,table) (do_hash((key), (table))%(table)->num_bins)</span></div><div class="line"><a name="l00089"></a><span class="lineno"> 89</span> </div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span> <span class="comment">/* preparation for possible allocation improvements */</span></div><div class="line"><a name="l00091"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aa9053dd461189a7780f276bfac62194c"> 91</a></span> <span class="preprocessor">#define st_alloc_entry() (st_table_entry *)malloc(sizeof(st_table_entry))</span></div><div class="line"><a name="l00092"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b"> 92</a></span> <span class="preprocessor">#define st_free_entry(entry) free(entry)</span></div><div class="line"><a name="l00093"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4bfcb3c7be49d9acd35fa21e8372cd41"> 93</a></span> <span class="preprocessor">#define st_alloc_table() (st_table *)malloc(sizeof(st_table))</span></div><div class="line"><a name="l00094"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#af2207ffbfcc7d6db423a059634117edb"> 94</a></span> <span class="preprocessor">#define st_dealloc_table(table) free(table)</span></div><div class="line"><a name="l00095"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae3ba2172909b8e58e5abfdef7642155b"> 95</a></span> <span class="preprocessor">#define st_alloc_bins(size) (st_table_entry **)calloc(size, sizeof(st_table_entry *))</span></div><div class="line"><a name="l00096"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ad9d5f8f4ebdb3e9b80ea1e37ca4d234d"> 96</a></span> <span class="preprocessor">#define st_free_bins(bins, size) free(bins)</span></div><div class="line"><a name="l00097"></a><span class="lineno"> 97</span> <span class="keyword">static</span> <span class="keyword">inline</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>**</div><div class="line"><a name="l00098"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4fc94afd44187992a916a7a4608481d4"> 98</a></span> <a class="code" href="../../d4/d71/st_8c.html#a4fc94afd44187992a916a7a4608481d4">st_realloc_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#ae0b961792c432d4637ada06390832cb7">bins</a>, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> newsize, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> oldsize)</div><div class="line"><a name="l00099"></a><span class="lineno"> 99</span> {</div><div class="line"><a name="l00100"></a><span class="lineno"> 100</span>  <a class="code" href="../../d4/d71/st_8c.html#ae0b961792c432d4637ada06390832cb7">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#a1b739878adcdb46fb5d209af7ce79628">realloc</a>(<a class="code" href="../../d4/d71/st_8c.html#ae0b961792c432d4637ada06390832cb7">bins</a>, newsize * <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="l00101"></a><span class="lineno"> 101</span>  <a class="code" href="../../de/de6/ruby_2ruby_8h.html#a56d620b94b668ed7665d1616b2c54e48">MEMZERO</a>(<a class="code" href="../../d4/d71/st_8c.html#ae0b961792c432d4637ada06390832cb7">bins</a>, <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a>*, newsize);</div><div class="line"><a name="l00102"></a><span class="lineno"> 102</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#ae0b961792c432d4637ada06390832cb7">bins</a>;</div><div class="line"><a name="l00103"></a><span class="lineno"> 103</span> }</div><div class="line"><a name="l00104"></a><span class="lineno"> 104</span> </div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span> <span class="comment">/* Shortcut */</span></div><div class="line"><a name="l00106"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae0b961792c432d4637ada06390832cb7"> 106</a></span> <span class="preprocessor">#define bins as.big.bins</span></div><div class="line"><a name="l00107"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a6d1197264c8235ebd5bda57ba423914e"> 107</a></span> <span class="preprocessor">#define head as.big.head</span></div><div class="line"><a name="l00108"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aeb205b1461b511358d0bdd0a457b6428"> 108</a></span> <span class="preprocessor">#define tail as.big.tail</span></div><div class="line"><a name="l00109"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc"> 109</a></span> <span class="preprocessor">#define real_entries as.packed.real_entries</span></div><div class="line"><a name="l00110"></a><span class="lineno"> 110</span> </div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span> <span class="comment">/* preparation for possible packing improvements */</span></div><div class="line"><a name="l00112"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a79bb3acd36ef8b09877de02e883ea92c"> 112</a></span> <span class="preprocessor">#define PACKED_BINS(table) ((table)->as.packed.entries)</span></div><div class="line"><a name="l00113"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a438ae9ef62bab55aac6d75766e76d553"> 113</a></span> <span class="preprocessor">#define PACKED_ENT(table, i) PACKED_BINS(table)[i]</span></div><div class="line"><a name="l00114"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a"> 114</a></span> <span class="preprocessor">#define PKEY(table, i) PACKED_ENT((table), (i)).key</span></div><div class="line"><a name="l00115"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6"> 115</a></span> <span class="preprocessor">#define PVAL(table, i) PACKED_ENT((table), (i)).val</span></div><div class="line"><a name="l00116"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a51731773e02649913e2a8d91d6ca4ad1"> 116</a></span> <span class="preprocessor">#define PHASH(table, i) PACKED_ENT((table), (i)).hash</span></div><div class="line"><a name="l00117"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab0f310ebc69f2456e8608a505662e139"> 117</a></span> <span class="preprocessor">#define PKEY_SET(table, i, v) (PKEY((table), (i)) = (v))</span></div><div class="line"><a name="l00118"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab2607640960e5c6916c5164be9a3646b"> 118</a></span> <span class="preprocessor">#define PVAL_SET(table, i, v) (PVAL((table), (i)) = (v))</span></div><div class="line"><a name="l00119"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a7ae8f8630077956a99c2fb7966beae3d"> 119</a></span> <span class="preprocessor">#define PHASH_SET(table, i, v) (PHASH((table), (i)) = (v))</span></div><div class="line"><a name="l00120"></a><span class="lineno"> 120</span> </div><div class="line"><a name="l00121"></a><span class="lineno"> 121</span> <span class="comment">/* this function depends much on packed layout, so that it placed here */</span></div><div class="line"><a name="l00122"></a><span class="lineno"> 122</span> <span class="keyword">static</span> <span class="keyword">inline</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00123"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a0fccb1100278656a74bdfd5d7c3f9913"> 123</a></span> <a class="code" href="../../d4/d71/st_8c.html#a0fccb1100278656a74bdfd5d7c3f9913">remove_packed_entry</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i)</div><div class="line"><a name="l00124"></a><span class="lineno"> 124</span> {</div><div class="line"><a name="l00125"></a><span class="lineno"> 125</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>--;</div><div class="line"><a name="l00126"></a><span class="lineno"> 126</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div><div class="line"><a name="l00127"></a><span class="lineno"> 127</span>  <span class="keywordflow">if</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a>) {</div><div class="line"><a name="l00128"></a><span class="lineno"> 128</span>  <a class="code" href="../../de/de6/ruby_2ruby_8h.html#aad09de334c9b8c7f717d314b14679e62">MEMMOVE</a>(&<a class="code" href="../../d4/d71/st_8c.html#a438ae9ef62bab55aac6d75766e76d553">PACKED_ENT</a>(table, i), &<a class="code" href="../../d4/d71/st_8c.html#a438ae9ef62bab55aac6d75766e76d553">PACKED_ENT</a>(table, i+1),</div><div class="line"><a name="l00129"></a><span class="lineno"> 129</span>  <a class="code" href="../../d8/ddd/structst__packed__entry.html">st_packed_entry</a>, table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a> - i);</div><div class="line"><a name="l00130"></a><span class="lineno"> 130</span>  }</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> </div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span> <span class="keyword">static</span> <span class="keyword">inline</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00134"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab663e132c2bb344be9d0763540c23509"> 134</a></span> <a class="code" href="../../d4/d71/st_8c.html#ab663e132c2bb344be9d0763540c23509">remove_safe_packed_entry</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> never)</div><div class="line"><a name="l00135"></a><span class="lineno"> 135</span> {</div><div class="line"><a name="l00136"></a><span class="lineno"> 136</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div><div class="line"><a name="l00137"></a><span class="lineno"> 137</span>  <a class="code" href="../../d4/d71/st_8c.html#ab0f310ebc69f2456e8608a505662e139">PKEY_SET</a>(table, i, never);</div><div class="line"><a name="l00138"></a><span class="lineno"> 138</span>  <a class="code" href="../../d4/d71/st_8c.html#ab2607640960e5c6916c5164be9a3646b">PVAL_SET</a>(table, i, never);</div><div class="line"><a name="l00139"></a><span class="lineno"> 139</span>  <a class="code" href="../../d4/d71/st_8c.html#a7ae8f8630077956a99c2fb7966beae3d">PHASH_SET</a>(table, i, 0);</div><div class="line"><a name="l00140"></a><span class="lineno"> 140</span> }</div><div class="line"><a name="l00141"></a><span class="lineno"> 141</span> </div><div class="line"><a name="l00142"></a><span class="lineno"> 142</span> <span class="comment">/*</span></div><div class="line"><a name="l00143"></a><span class="lineno"> 143</span> <span class="comment"> * MINSIZE is the minimum size of a dictionary.</span></div><div class="line"><a name="l00144"></a><span class="lineno"> 144</span> <span class="comment"> */</span></div><div class="line"><a name="l00145"></a><span class="lineno"> 145</span> </div><div class="line"><a name="l00146"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a76ace81cc961cbcdba26190bcd706326"> 146</a></span> <span class="preprocessor">#define MINSIZE 8</span></div><div class="line"><a name="l00147"></a><span class="lineno"> 147</span> </div><div class="line"><a name="l00148"></a><span class="lineno"> 148</span> <span class="comment">/*</span></div><div class="line"><a name="l00149"></a><span class="lineno"> 149</span> <span class="comment">Table of prime numbers 2^n+a, 2<=n<=30.</span></div><div class="line"><a name="l00150"></a><span class="lineno"> 150</span> <span class="comment">*/</span></div><div class="line"><a name="l00151"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#afa0b3f5a7c236c57525153e59dd3c608"> 151</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="l00152"></a><span class="lineno"> 152</span>  <a class="code" href="../../d4/d71/st_8c.html#a311df13f4d458054df7d87ca22782ab2">ST_DEFAULT_INIT_TABLE_SIZE</a>,</div><div class="line"><a name="l00153"></a><span class="lineno"> 153</span>  <a class="code" href="../../d4/d71/st_8c.html#af968643d33d8ca4088601fdad8783913">ST_DEFAULT_SECOND_TABLE_SIZE</a>,</div><div class="line"><a name="l00154"></a><span class="lineno"> 154</span>  32 + 5,</div><div class="line"><a name="l00155"></a><span class="lineno"> 155</span>  64 + 3,</div><div class="line"><a name="l00156"></a><span class="lineno"> 156</span>  128 + 3,</div><div class="line"><a name="l00157"></a><span class="lineno"> 157</span>  256 + 27,</div><div class="line"><a name="l00158"></a><span class="lineno"> 158</span>  512 + 9,</div><div class="line"><a name="l00159"></a><span class="lineno"> 159</span>  1024 + 9,</div><div class="line"><a name="l00160"></a><span class="lineno"> 160</span>  2048 + 5,</div><div class="line"><a name="l00161"></a><span class="lineno"> 161</span>  4096 + 3,</div><div class="line"><a name="l00162"></a><span class="lineno"> 162</span>  8192 + 27,</div><div class="line"><a name="l00163"></a><span class="lineno"> 163</span>  16384 + 43,</div><div class="line"><a name="l00164"></a><span class="lineno"> 164</span>  32768 + 3,</div><div class="line"><a name="l00165"></a><span class="lineno"> 165</span>  65536 + 45,</div><div class="line"><a name="l00166"></a><span class="lineno"> 166</span>  131072 + 29,</div><div class="line"><a name="l00167"></a><span class="lineno"> 167</span>  262144 + 3,</div><div class="line"><a name="l00168"></a><span class="lineno"> 168</span>  524288 + 21,</div><div class="line"><a name="l00169"></a><span class="lineno"> 169</span>  1048576 + 7,</div><div class="line"><a name="l00170"></a><span class="lineno"> 170</span>  2097152 + 17,</div><div class="line"><a name="l00171"></a><span class="lineno"> 171</span>  4194304 + 15,</div><div class="line"><a name="l00172"></a><span class="lineno"> 172</span>  8388608 + 9,</div><div class="line"><a name="l00173"></a><span class="lineno"> 173</span>  16777216 + 43,</div><div class="line"><a name="l00174"></a><span class="lineno"> 174</span>  33554432 + 35,</div><div class="line"><a name="l00175"></a><span class="lineno"> 175</span>  67108864 + 15,</div><div class="line"><a name="l00176"></a><span class="lineno"> 176</span>  134217728 + 29,</div><div class="line"><a name="l00177"></a><span class="lineno"> 177</span>  268435456 + 3,</div><div class="line"><a name="l00178"></a><span class="lineno"> 178</span>  536870912 + 11,</div><div class="line"><a name="l00179"></a><span class="lineno"> 179</span>  1073741824 + 85,</div><div class="line"><a name="l00180"></a><span class="lineno"> 180</span>  0</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> </div><div class="line"><a name="l00183"></a><span class="lineno"> 183</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="l00184"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a"> 184</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="l00185"></a><span class="lineno"> 185</span> {</div><div class="line"><a name="l00186"></a><span class="lineno"> 186</span>  <span class="keywordtype">int</span> i;</div><div class="line"><a name="l00187"></a><span class="lineno"> 187</span> </div><div class="line"><a name="l00188"></a><span class="lineno"> 188</span> <span class="preprocessor">#if 0</span></div><div class="line"><a name="l00189"></a><span class="lineno"> 189</span>  <span class="keywordflow">for</span> (i=3; i<31; i++) {</div><div class="line"><a name="l00190"></a><span class="lineno"> 190</span>  <span class="keywordflow">if</span> ((1<<i) > <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>) <span class="keywordflow">return</span> 1<<i;</div><div class="line"><a name="l00191"></a><span class="lineno"> 191</span>  }</div><div class="line"><a name="l00192"></a><span class="lineno"> 192</span>  <span class="keywordflow">return</span> -1;</div><div class="line"><a name="l00193"></a><span class="lineno"> 193</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l00194"></a><span class="lineno"> 194</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> newsize;</div><div class="line"><a name="l00195"></a><span class="lineno"> 195</span> </div><div class="line"><a name="l00196"></a><span class="lineno"> 196</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="l00197"></a><span class="lineno"> 197</span>  <span class="keywordflow">if</span> (newsize > <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>) <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#afa0b3f5a7c236c57525153e59dd3c608">primes</a>[i];</div><div class="line"><a name="l00198"></a><span class="lineno"> 198</span>  }</div><div class="line"><a name="l00199"></a><span class="lineno"> 199</span>  <span class="comment">/* Ran out of primes */</span></div><div class="line"><a name="l00200"></a><span class="lineno"> 200</span> <span class="preprocessor">#ifndef NOT_RUBY</span></div><div class="line"><a name="l00201"></a><span class="lineno"> 201</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="l00202"></a><span class="lineno"> 202</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l00203"></a><span class="lineno"> 203</span>  <span class="keywordflow">return</span> -1; <span class="comment">/* should raise exception */</span></div><div class="line"><a name="l00204"></a><span class="lineno"> 204</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l00205"></a><span class="lineno"> 205</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="preprocessor">#ifdef HASH_LOG</span></div><div class="line"><a name="l00208"></a><span class="lineno"> 208</span> <span class="preprocessor">#ifdef HAVE_UNISTD_H</span></div><div class="line"><a name="l00209"></a><span class="lineno"> 209</span> <span class="preprocessor">#include <<a class="code" href="../../da/d6f/unistd_8h.html">unistd.h</a>></span></div><div class="line"><a name="l00210"></a><span class="lineno"> 210</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l00211"></a><span class="lineno"> 211</span> <span class="keyword">static</span> <span class="keyword">struct </span>{</div><div class="line"><a name="l00212"></a><span class="lineno"> 212</span>  <span class="keywordtype">int</span> all, total, num, str, strcase;</div><div class="line"><a name="l00213"></a><span class="lineno"> 213</span> } collision;</div><div class="line"><a name="l00214"></a><span class="lineno"> 214</span> <span class="keyword">static</span> <span class="keywordtype">int</span> init_st = 0;</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> <span class="keyword">static</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00217"></a><span class="lineno"> 217</span> stat_col(<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="keywordtype">char</span> fname[10+<span class="keyword">sizeof</span>(long)*3];</div><div class="line"><a name="l00220"></a><span class="lineno"> 220</span>  <a class="code" href="../../db/ddf/struct____s_f_i_l_e.html">FILE</a> *<a class="code" href="../../d9/d2d/sprintf_8c.html#a7a51ed112e9b79f89e3e70beb8db8bf5">f</a> = 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="l00221"></a><span class="lineno"> 221</span>  fprintf(<a class="code" href="../../d9/d2d/sprintf_8c.html#a7a51ed112e9b79f89e3e70beb8db8bf5">f</a>, <span class="stringliteral">"collision: %d / %d (%6.2f)\n"</span>, collision.all, collision.total,</div><div class="line"><a name="l00222"></a><span class="lineno"> 222</span>  ((<span class="keywordtype">double</span>)collision.all / (collision.total)) * 100);</div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span>  fprintf(<a class="code" href="../../d9/d2d/sprintf_8c.html#a7a51ed112e9b79f89e3e70beb8db8bf5">f</a>, <span class="stringliteral">"num: %d, str: %d, strcase: %d\n"</span>, collision.num, collision.str, collision.strcase);</div><div class="line"><a name="l00224"></a><span class="lineno"> 224</span>  fclose(<a class="code" href="../../d9/d2d/sprintf_8c.html#a7a51ed112e9b79f89e3e70beb8db8bf5">f</a>);</div><div class="line"><a name="l00225"></a><span class="lineno"> 225</span> }</div><div class="line"><a name="l00226"></a><span class="lineno"> 226</span> <span class="preprocessor">#endif</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#aa5f47e0af563e177e8b559073f454625"> 229</a></span> <a class="code" href="../../d4/d71/st_8c.html#aa5f47e0af563e177e8b559073f454625">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="l00230"></a><span class="lineno"> 230</span> {</div><div class="line"><a name="l00231"></a><span class="lineno"> 231</span>  <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *tbl;</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> <span class="preprocessor">#ifdef HASH_LOG</span></div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span> <span class="preprocessor"># if HASH_LOG+0 < 0</span></div><div class="line"><a name="l00235"></a><span class="lineno"> 235</span>  {</div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span>  <span class="keyword">const</span> <span class="keywordtype">char</span> *e = <a class="code" href="../../d5/df2/win32_8c.html#a0b6e1d2007fab7ae5d69c0b6e8162846">getenv</a>(<span class="stringliteral">"ST_HASH_LOG"</span>);</div><div class="line"><a name="l00237"></a><span class="lineno"> 237</span>  <span class="keywordflow">if</span> (!e || !*e) init_st = 1;</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> <span class="preprocessor"># endif</span></div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>  <span class="keywordflow">if</span> (init_st == 0) {</div><div class="line"><a name="l00241"></a><span class="lineno"> 241</span>  init_st = 1;</div><div class="line"><a name="l00242"></a><span class="lineno"> 242</span>  atexit(stat_col);</div><div class="line"><a name="l00243"></a><span class="lineno"> 243</span>  }</div><div class="line"><a name="l00244"></a><span class="lineno"> 244</span> <span class="preprocessor">#endif</span></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> </div><div class="line"><a name="l00247"></a><span class="lineno"> 247</span>  tbl = <a class="code" href="../../d4/d71/st_8c.html#a4bfcb3c7be49d9acd35fa21e8372cd41">st_alloc_table</a>();</div><div class="line"><a name="l00248"></a><span class="lineno"> 248</span>  tbl-><a class="code" href="../../d0/ddd/structst__table.html#a82ed3f0c0cf62aacdeec296678726cdf">type</a> = <a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a>;</div><div class="line"><a name="l00249"></a><span class="lineno"> 249</span>  tbl-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = 0;</div><div class="line"><a name="l00250"></a><span class="lineno"> 250</span>  tbl-><a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a> = <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a> <= <a class="code" href="../../d4/d71/st_8c.html#a2e84b634e97a0834e9f03658d1cb202f">MAX_PACKED_HASH</a>;</div><div class="line"><a name="l00251"></a><span class="lineno"> 251</span>  <span class="keywordflow">if</span> (tbl-><a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div><div class="line"><a name="l00252"></a><span class="lineno"> 252</span>  <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a> = <a class="code" href="../../d4/d71/st_8c.html#ab1314d055fd90b84911a9ec5e802edf7">ST_DEFAULT_PACKED_TABLE_SIZE</a>;</div><div class="line"><a name="l00253"></a><span class="lineno"> 253</span>  }</div><div class="line"><a name="l00254"></a><span class="lineno"> 254</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00255"></a><span class="lineno"> 255</span>  <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a> = <a class="code" href="../../d4/d71/st_8c.html#a24df014296a421392679e4dd79101e7a">new_size</a>(<a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>); <span class="comment">/* round up to prime number */</span></div><div class="line"><a name="l00256"></a><span class="lineno"> 256</span>  }</div><div class="line"><a name="l00257"></a><span class="lineno"> 257</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="l00258"></a><span class="lineno"> 258</span>  tbl-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> = <a class="code" href="../../d4/d71/st_8c.html#ae3ba2172909b8e58e5abfdef7642155b">st_alloc_bins</a>(<a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>);</div><div class="line"><a name="l00259"></a><span class="lineno"> 259</span>  tbl-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a> = 0;</div><div class="line"><a name="l00260"></a><span class="lineno"> 260</span>  tbl-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = 0;</div><div class="line"><a name="l00261"></a><span class="lineno"> 261</span> </div><div class="line"><a name="l00262"></a><span class="lineno"> 262</span>  <span class="keywordflow">return</span> tbl;</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> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div><div class="line"><a name="l00266"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a9b0fdfc1b68819f2d666f74187f90b4a"> 266</a></span> <a class="code" href="../../d4/d71/st_8c.html#a9b0fdfc1b68819f2d666f74187f90b4a">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="l00267"></a><span class="lineno"> 267</span> {</div><div class="line"><a name="l00268"></a><span class="lineno"> 268</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#aa5f47e0af563e177e8b559073f454625">st_init_table_with_size</a>(<a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a>, 0);</div><div class="line"><a name="l00269"></a><span class="lineno"> 269</span> }</div><div class="line"><a name="l00270"></a><span class="lineno"> 270</span> </div><div class="line"><a name="l00271"></a><span class="lineno"> 271</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div><div class="line"><a name="l00272"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a955c6e936b9681649ab9ffa4aa741949"> 272</a></span> <a class="code" href="../../d4/d71/st_8c.html#a955c6e936b9681649ab9ffa4aa741949">st_init_numtable</a>(<span class="keywordtype">void</span>)</div><div class="line"><a name="l00273"></a><span class="lineno"> 273</span> {</div><div class="line"><a name="l00274"></a><span class="lineno"> 274</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a9b0fdfc1b68819f2d666f74187f90b4a">st_init_table</a>(&<a class="code" href="../../d4/d71/st_8c.html#a0a1a5e64d8833b9da51b96d02562593d">type_numhash</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> </div><div class="line"><a name="l00277"></a><span class="lineno"> 277</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div><div class="line"><a name="l00278"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a8a0fa825221e5025911fd93c6c30f3dd"> 278</a></span> <a class="code" href="../../d4/d71/st_8c.html#a8a0fa825221e5025911fd93c6c30f3dd">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="l00279"></a><span class="lineno"> 279</span> {</div><div class="line"><a name="l00280"></a><span class="lineno"> 280</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#aa5f47e0af563e177e8b559073f454625">st_init_table_with_size</a>(&<a class="code" href="../../d4/d71/st_8c.html#a0a1a5e64d8833b9da51b96d02562593d">type_numhash</a>, <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</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> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div><div class="line"><a name="l00284"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aaca0d6a6f8e07dd6ad3265872d7b1f81"> 284</a></span> <a class="code" href="../../d4/d71/st_8c.html#aaca0d6a6f8e07dd6ad3265872d7b1f81">st_init_strtable</a>(<span class="keywordtype">void</span>)</div><div class="line"><a name="l00285"></a><span class="lineno"> 285</span> {</div><div class="line"><a name="l00286"></a><span class="lineno"> 286</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a9b0fdfc1b68819f2d666f74187f90b4a">st_init_table</a>(&<a class="code" href="../../d4/d71/st_8c.html#af83cfc72d5d16b336475bf69c3a95133">type_strhash</a>);</div><div class="line"><a name="l00287"></a><span class="lineno"> 287</span> }</div><div class="line"><a name="l00288"></a><span class="lineno"> 288</span> </div><div class="line"><a name="l00289"></a><span class="lineno"> 289</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div><div class="line"><a name="l00290"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a92f0cb21ae7d4d53e0f57efcd158d80f"> 290</a></span> <a class="code" href="../../d4/d71/st_8c.html#a92f0cb21ae7d4d53e0f57efcd158d80f">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="l00291"></a><span class="lineno"> 291</span> {</div><div class="line"><a name="l00292"></a><span class="lineno"> 292</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#aa5f47e0af563e177e8b559073f454625">st_init_table_with_size</a>(&<a class="code" href="../../d4/d71/st_8c.html#af83cfc72d5d16b336475bf69c3a95133">type_strhash</a>, <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>);</div><div class="line"><a name="l00293"></a><span class="lineno"> 293</span> }</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> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div><div class="line"><a name="l00296"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a60f14cceadd837db51e110881258944a"> 296</a></span> <a class="code" href="../../d4/d71/st_8c.html#a60f14cceadd837db51e110881258944a">st_init_strcasetable</a>(<span class="keywordtype">void</span>)</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">return</span> <a class="code" href="../../d4/d71/st_8c.html#a9b0fdfc1b68819f2d666f74187f90b4a">st_init_table</a>(&<a class="code" href="../../d4/d71/st_8c.html#a028396ceb63492536a3609e4e824d148">type_strcasehash</a>);</div><div class="line"><a name="l00299"></a><span class="lineno"> 299</span> }</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> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div><div class="line"><a name="l00302"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4c12b0bc4cb64bc0ebc40a3536e0198a"> 302</a></span> <a class="code" href="../../d4/d71/st_8c.html#a4c12b0bc4cb64bc0ebc40a3536e0198a">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="l00303"></a><span class="lineno"> 303</span> {</div><div class="line"><a name="l00304"></a><span class="lineno"> 304</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#aa5f47e0af563e177e8b559073f454625">st_init_table_with_size</a>(&<a class="code" href="../../d4/d71/st_8c.html#a028396ceb63492536a3609e4e824d148">type_strcasehash</a>, <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>);</div><div class="line"><a name="l00305"></a><span class="lineno"> 305</span> }</div><div class="line"><a name="l00306"></a><span class="lineno"> 306</span> </div><div class="line"><a name="l00307"></a><span class="lineno"> 307</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00308"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a9b0256b6986265c09661636af78fcb74"> 308</a></span> <a class="code" href="../../d4/d71/st_8c.html#a9b0256b6986265c09661636af78fcb74">st_clear</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table)</div><div class="line"><a name="l00309"></a><span class="lineno"> 309</span> {</div><div class="line"><a name="l00310"></a><span class="lineno"> 310</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr, *next;</div><div class="line"><a name="l00311"></a><span class="lineno"> 311</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i;</div><div class="line"><a name="l00312"></a><span class="lineno"> 312</span> </div><div class="line"><a name="l00313"></a><span class="lineno"> 313</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="l00314"></a><span class="lineno"> 314</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = 0;</div><div class="line"><a name="l00315"></a><span class="lineno"> 315</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a> = 0;</div><div class="line"><a name="l00316"></a><span class="lineno"> 316</span>  <span class="keywordflow">return</span>;</div><div class="line"><a name="l00317"></a><span class="lineno"> 317</span>  }</div><div class="line"><a name="l00318"></a><span class="lineno"> 318</span> </div><div class="line"><a name="l00319"></a><span class="lineno"> 319</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="l00320"></a><span class="lineno"> 320</span>  ptr = table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i];</div><div class="line"><a name="l00321"></a><span class="lineno"> 321</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i] = 0;</div><div class="line"><a name="l00322"></a><span class="lineno"> 322</span>  <span class="keywordflow">while</span> (ptr != 0) {</div><div class="line"><a name="l00323"></a><span class="lineno"> 323</span>  next = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l00324"></a><span class="lineno"> 324</span>  <a class="code" href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b">st_free_entry</a>(ptr);</div><div class="line"><a name="l00325"></a><span class="lineno"> 325</span>  ptr = next;</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>  }</div><div class="line"><a name="l00328"></a><span class="lineno"> 328</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = 0;</div><div class="line"><a name="l00329"></a><span class="lineno"> 329</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a> = 0;</div><div class="line"><a name="l00330"></a><span class="lineno"> 330</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = 0;</div><div class="line"><a name="l00331"></a><span class="lineno"> 331</span> }</div><div class="line"><a name="l00332"></a><span class="lineno"> 332</span> </div><div class="line"><a name="l00333"></a><span class="lineno"> 333</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00334"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a93394fd99c5fa4fbcce2be9717abee45"> 334</a></span> <a class="code" href="../../d4/d71/st_8c.html#a93394fd99c5fa4fbcce2be9717abee45">st_free_table</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table)</div><div class="line"><a name="l00335"></a><span class="lineno"> 335</span> {</div><div class="line"><a name="l00336"></a><span class="lineno"> 336</span>  <a class="code" href="../../d4/d71/st_8c.html#a9b0256b6986265c09661636af78fcb74">st_clear</a>(table);</div><div class="line"><a name="l00337"></a><span class="lineno"> 337</span>  <a class="code" href="../../d4/d71/st_8c.html#ad9d5f8f4ebdb3e9b80ea1e37ca4d234d">st_free_bins</a>(table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div><div class="line"><a name="l00338"></a><span class="lineno"> 338</span>  <a class="code" href="../../d4/d71/st_8c.html#af2207ffbfcc7d6db423a059634117edb">st_dealloc_table</a>(table);</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> <span class="keywordtype">size_t</span></div><div class="line"><a name="l00342"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a9c7d882a34165813cbf64b5fd68b8570"> 342</a></span> <a class="code" href="../../d4/d71/st_8c.html#a9c7d882a34165813cbf64b5fd68b8570">st_memsize</a>(<span class="keyword">const</span> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table)</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> (table-><a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div><div class="line"><a name="l00345"></a><span class="lineno"> 345</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="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">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="l00349"></a><span class="lineno"> 349</span>  }</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"><a class="line" href="../../d4/d71/st_8c.html#a349734f8cc08a7685ec22c76d31d0d87"> 352</a></span> <span class="preprocessor">#define PTR_NOT_EQUAL(table, ptr, hash_val, key) \</span></div><div class="line"><a name="l00353"></a><span class="lineno"> 353</span> <span class="preprocessor">((ptr) != 0 && ((ptr)->hash != (hash_val) || !EQUAL((table), (key), (ptr)->key)))</span></div><div class="line"><a name="l00354"></a><span class="lineno"> 354</span> </div><div class="line"><a name="l00355"></a><span class="lineno"> 355</span> <span class="preprocessor">#ifdef HASH_LOG</span></div><div class="line"><a name="l00356"></a><span class="lineno"> 356</span> <span class="keyword">static</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00357"></a><span class="lineno"> 357</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="l00358"></a><span class="lineno"> 358</span> {</div><div class="line"><a name="l00359"></a><span class="lineno"> 359</span>  collision.all++;</div><div class="line"><a name="l00360"></a><span class="lineno"> 360</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a> == &<a class="code" href="../../d4/d71/st_8c.html#a0a1a5e64d8833b9da51b96d02562593d">type_numhash</a>) {</div><div class="line"><a name="l00361"></a><span class="lineno"> 361</span>  collision.num++;</div><div class="line"><a name="l00362"></a><span class="lineno"> 362</span>  }</div><div class="line"><a name="l00363"></a><span class="lineno"> 363</span>  <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a> == &<a class="code" href="../../d4/d71/st_8c.html#af83cfc72d5d16b336475bf69c3a95133">type_strhash</a>) {</div><div class="line"><a name="l00364"></a><span class="lineno"> 364</span>  collision.strcase++;</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>  <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="../../d5/d9d/tcltklib_8c.html#ac765329451135abec74c45e1897abf26">type</a> == &<a class="code" href="../../d4/d71/st_8c.html#a028396ceb63492536a3609e4e824d148">type_strcasehash</a>) {</div><div class="line"><a name="l00367"></a><span class="lineno"> 367</span>  collision.str++;</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> <span class="preprocessor">#define COLLISION (collision_check ? count_collision(table->type) : (void)0)</span></div><div class="line"><a name="l00371"></a><span class="lineno"> 371</span> <span class="preprocessor">#define FOUND_ENTRY (collision_check ? collision.total++ : (void)0)</span></div><div class="line"><a name="l00372"></a><span class="lineno"> 372</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l00373"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aafd826a123a41fd03a9c88842387a821"> 373</a></span> <span class="preprocessor">#define COLLISION</span></div><div class="line"><a name="l00374"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a3b3d5a648505e3a2db3d4d4504b13c0e"> 374</a></span> <span class="preprocessor">#define FOUND_ENTRY</span></div><div class="line"><a name="l00375"></a><span class="lineno"> 375</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l00376"></a><span class="lineno"> 376</span> </div><div class="line"><a name="l00377"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62"> 377</a></span> <span class="preprocessor">#define FIND_ENTRY(table, ptr, hash_val, bin_pos) \</span></div><div class="line"><a name="l00378"></a><span class="lineno"> 378</span> <span class="preprocessor"> ((ptr) = find_entry((table), key, (hash_val), ((bin_pos) = (hash_val)%(table)->num_bins)))</span></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> <span class="keyword">static</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *</div><div class="line"><a name="l00381"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#abc2f0cf0d3883db5db318210cd7cbd13"> 381</a></span> <a class="code" href="../../d4/d71/st_8c.html#abc2f0cf0d3883db5db318210cd7cbd13">find_entry</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> bin_pos)</div><div class="line"><a name="l00382"></a><span class="lineno"> 382</span> {</div><div class="line"><a name="l00383"></a><span class="lineno"> 383</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr = table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[bin_pos];</div><div class="line"><a name="l00384"></a><span class="lineno"> 384</span>  <a class="code" href="../../d4/d71/st_8c.html#a3b3d5a648505e3a2db3d4d4504b13c0e">FOUND_ENTRY</a>;</div><div class="line"><a name="l00385"></a><span class="lineno"> 385</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#a349734f8cc08a7685ec22c76d31d0d87">PTR_NOT_EQUAL</a>(table, ptr, hash_val, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>)) {</div><div class="line"><a name="l00386"></a><span class="lineno"> 386</span>  <a class="code" href="../../d4/d71/st_8c.html#aafd826a123a41fd03a9c88842387a821">COLLISION</a>;</div><div class="line"><a name="l00387"></a><span class="lineno"> 387</span>  <span class="keywordflow">while</span> (<a class="code" href="../../d4/d71/st_8c.html#a349734f8cc08a7685ec22c76d31d0d87">PTR_NOT_EQUAL</a>(table, ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>, hash_val, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>)) {</div><div class="line"><a name="l00388"></a><span class="lineno"> 388</span>  ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l00389"></a><span class="lineno"> 389</span>  }</div><div class="line"><a name="l00390"></a><span class="lineno"> 390</span>  ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l00391"></a><span class="lineno"> 391</span>  }</div><div class="line"><a name="l00392"></a><span class="lineno"> 392</span>  <span class="keywordflow">return</span> ptr;</div><div class="line"><a name="l00393"></a><span class="lineno"> 393</span> }</div><div class="line"><a name="l00394"></a><span class="lineno"> 394</span> </div><div class="line"><a name="l00395"></a><span class="lineno"> 395</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="l00396"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a77325ab6bf8e5f0cc3d02efc4a790bf2"> 396</a></span> <a class="code" href="../../d4/d71/st_8c.html#a77325ab6bf8e5f0cc3d02efc4a790bf2">find_packed_index_from</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i)</div><div class="line"><a name="l00397"></a><span class="lineno"> 397</span> {</div><div class="line"><a name="l00398"></a><span class="lineno"> 398</span>  <span class="keywordflow">while</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a> &&</div><div class="line"><a name="l00399"></a><span class="lineno"> 399</span>  (<a class="code" href="../../d4/d71/st_8c.html#a51731773e02649913e2a8d91d6ca4ad1">PHASH</a>(table, i) != hash_val || !<a class="code" href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867">EQUAL</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i)))) {</div><div class="line"><a name="l00400"></a><span class="lineno"> 400</span>  i++;</div><div class="line"><a name="l00401"></a><span class="lineno"> 401</span>  }</div><div class="line"><a name="l00402"></a><span class="lineno"> 402</span>  <span class="keywordflow">return</span> i;</div><div class="line"><a name="l00403"></a><span class="lineno"> 403</span> }</div><div class="line"><a name="l00404"></a><span class="lineno"> 404</span> </div><div class="line"><a name="l00405"></a><span class="lineno"> 405</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="l00406"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5"> 406</a></span> <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>)</div><div class="line"><a name="l00407"></a><span class="lineno"> 407</span> {</div><div class="line"><a name="l00408"></a><span class="lineno"> 408</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a77325ab6bf8e5f0cc3d02efc4a790bf2">find_packed_index_from</a>(table, hash_val, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, 0);</div><div class="line"><a name="l00409"></a><span class="lineno"> 409</span> }</div><div class="line"><a name="l00410"></a><span class="lineno"> 410</span> </div><div class="line"><a name="l00411"></a><span class="lineno"> 411</span> <span class="preprocessor">#define collision_check 0</span></div><div class="line"><a name="l00412"></a><span class="lineno"> 412</span> </div><div class="line"><a name="l00413"></a><span class="lineno"> 413</span> <span class="keywordtype">int</span></div><div class="line"><a name="l00414"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#af526fb7d918a9a5ceadadc087e79aa1c"> 414</a></span> <a class="code" href="../../d4/d71/st_8c.html#af526fb7d918a9a5ceadadc087e79aa1c">st_lookup</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *value)</div><div class="line"><a name="l00415"></a><span class="lineno"> 415</span> {</div><div class="line"><a name="l00416"></a><span class="lineno"> 416</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div><div class="line"><a name="l00417"></a><span class="lineno"> 417</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr;</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>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, table);</div><div class="line"><a name="l00420"></a><span class="lineno"> 420</span> </div><div class="line"><a name="l00421"></a><span class="lineno"> 421</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="l00422"></a><span class="lineno"> 422</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(table, hash_val, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00423"></a><span class="lineno"> 423</span>  <span class="keywordflow">if</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a>) {</div><div class="line"><a name="l00424"></a><span class="lineno"> 424</span>  <span class="keywordflow">if</span> (value != 0) *value = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, i);</div><div class="line"><a name="l00425"></a><span class="lineno"> 425</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00426"></a><span class="lineno"> 426</span>  }</div><div class="line"><a name="l00427"></a><span class="lineno"> 427</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00428"></a><span class="lineno"> 428</span>  }</div><div class="line"><a name="l00429"></a><span class="lineno"> 429</span> </div><div class="line"><a name="l00430"></a><span class="lineno"> 430</span>  ptr = <a class="code" href="../../d4/d71/st_8c.html#abc2f0cf0d3883db5db318210cd7cbd13">find_entry</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, hash_val, hash_val % table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div><div class="line"><a name="l00431"></a><span class="lineno"> 431</span> </div><div class="line"><a name="l00432"></a><span class="lineno"> 432</span>  <span class="keywordflow">if</span> (ptr == 0) {</div><div class="line"><a name="l00433"></a><span class="lineno"> 433</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00434"></a><span class="lineno"> 434</span>  }</div><div class="line"><a name="l00435"></a><span class="lineno"> 435</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00436"></a><span class="lineno"> 436</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="l00437"></a><span class="lineno"> 437</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00438"></a><span class="lineno"> 438</span>  }</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> </div><div class="line"><a name="l00441"></a><span class="lineno"> 441</span> <span class="keywordtype">int</span></div><div class="line"><a name="l00442"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae666ef5798c3d30a0533bd91054ec1f3"> 442</a></span> <a class="code" href="../../d4/d71/st_8c.html#ae666ef5798c3d30a0533bd91054ec1f3">st_get_key</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *<a class="code" href="../../d8/d90/nkf_8c.html#a5ea5ac7abf5cce39283e422add1067d5">result</a>)</div><div class="line"><a name="l00443"></a><span class="lineno"> 443</span> {</div><div class="line"><a name="l00444"></a><span class="lineno"> 444</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div><div class="line"><a name="l00445"></a><span class="lineno"> 445</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr;</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>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, table);</div><div class="line"><a name="l00448"></a><span class="lineno"> 448</span> </div><div class="line"><a name="l00449"></a><span class="lineno"> 449</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="l00450"></a><span class="lineno"> 450</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(table, hash_val, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00451"></a><span class="lineno"> 451</span>  <span class="keywordflow">if</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a>) {</div><div class="line"><a name="l00452"></a><span class="lineno"> 452</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d8/d90/nkf_8c.html#a5ea5ac7abf5cce39283e422add1067d5">result</a> != 0) *<a class="code" href="../../d8/d90/nkf_8c.html#a5ea5ac7abf5cce39283e422add1067d5">result</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l00453"></a><span class="lineno"> 453</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00454"></a><span class="lineno"> 454</span>  }</div><div class="line"><a name="l00455"></a><span class="lineno"> 455</span>  <span class="keywordflow">return</span> 0;</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>  ptr = <a class="code" href="../../d4/d71/st_8c.html#abc2f0cf0d3883db5db318210cd7cbd13">find_entry</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, hash_val, hash_val % table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div><div class="line"><a name="l00459"></a><span class="lineno"> 459</span> </div><div class="line"><a name="l00460"></a><span class="lineno"> 460</span>  <span class="keywordflow">if</span> (ptr == 0) {</div><div class="line"><a name="l00461"></a><span class="lineno"> 461</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00462"></a><span class="lineno"> 462</span>  }</div><div class="line"><a name="l00463"></a><span class="lineno"> 463</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00464"></a><span class="lineno"> 464</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d8/d90/nkf_8c.html#a5ea5ac7abf5cce39283e422add1067d5">result</a> != 0) *<a class="code" href="../../d8/d90/nkf_8c.html#a5ea5ac7abf5cce39283e422add1067d5">result</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div><div class="line"><a name="l00465"></a><span class="lineno"> 465</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00466"></a><span class="lineno"> 466</span>  }</div><div class="line"><a name="l00467"></a><span class="lineno"> 467</span> }</div><div class="line"><a name="l00468"></a><span class="lineno"> 468</span> </div><div class="line"><a name="l00469"></a><span class="lineno"> 469</span> <span class="preprocessor">#undef collision_check</span></div><div class="line"><a name="l00470"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae1c51589b76ef357bffa24d929c165e5"> 470</a></span> <span class="preprocessor">#define collision_check 1</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="keyword">static</span> <span class="keyword">inline</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *</div><div class="line"><a name="l00473"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ac1c04331d2aef8182cd58605fcc2fb25"> 473</a></span> <a class="code" href="../../d4/d71/st_8c.html#ac1c04331d2aef8182cd58605fcc2fb25">new_entry</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> * table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> value,</div><div class="line"><a name="l00474"></a><span class="lineno"> 474</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> bin_pos)</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>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *entry = <a class="code" href="../../d4/d71/st_8c.html#aa9053dd461189a7780f276bfac62194c">st_alloc_entry</a>();</div><div class="line"><a name="l00477"></a><span class="lineno"> 477</span> </div><div class="line"><a name="l00478"></a><span class="lineno"> 478</span>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a> = table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[bin_pos];</div><div class="line"><a name="l00479"></a><span class="lineno"> 479</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[bin_pos] = entry;</div><div class="line"><a name="l00480"></a><span class="lineno"> 480</span>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> = hash_val;</div><div class="line"><a name="l00481"></a><span class="lineno"> 481</span>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a> = <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>;</div><div class="line"><a name="l00482"></a><span class="lineno"> 482</span>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a> = value;</div><div class="line"><a name="l00483"></a><span class="lineno"> 483</span> </div><div class="line"><a name="l00484"></a><span class="lineno"> 484</span>  <span class="keywordflow">return</span> entry;</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="keyword">static</span> <span class="keyword">inline</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00488"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#acc0ef6968908283247217a06840c6d8c"> 488</a></span> <a class="code" href="../../d4/d71/st_8c.html#acc0ef6968908283247217a06840c6d8c">add_direct</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> value,</div><div class="line"><a name="l00489"></a><span class="lineno"> 489</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val, <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> bin_pos)</div><div class="line"><a name="l00490"></a><span class="lineno"> 490</span> {</div><div class="line"><a name="l00491"></a><span class="lineno"> 491</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *entry;</div><div class="line"><a name="l00492"></a><span class="lineno"> 492</span>  <span class="keywordflow">if</span> (table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> > <a class="code" href="../../d4/d71/st_8c.html#a4f884be75490db2c92e409a0209fdbcb">ST_DEFAULT_MAX_DENSITY</a> * table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>) {</div><div class="line"><a name="l00493"></a><span class="lineno"> 493</span>  <a class="code" href="../../d4/d71/st_8c.html#ae79a2e19d2287b6ac8d9a82f5c423a1c">rehash</a>(table);</div><div class="line"><a name="l00494"></a><span class="lineno"> 494</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="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>  entry = <a class="code" href="../../d4/d71/st_8c.html#ac1c04331d2aef8182cd58605fcc2fb25">new_entry</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val, bin_pos);</div><div class="line"><a name="l00498"></a><span class="lineno"> 498</span> </div><div class="line"><a name="l00499"></a><span class="lineno"> 499</span>  <span class="keywordflow">if</span> (table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a> != 0) {</div><div class="line"><a name="l00500"></a><span class="lineno"> 500</span>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a> = 0;</div><div class="line"><a name="l00501"></a><span class="lineno"> 501</span>  (entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a> = table-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a>)-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a> = entry;</div><div class="line"><a name="l00502"></a><span class="lineno"> 502</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = entry;</div><div class="line"><a name="l00503"></a><span class="lineno"> 503</span>  }</div><div class="line"><a name="l00504"></a><span class="lineno"> 504</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00505"></a><span class="lineno"> 505</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a> = table-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = entry;</div><div class="line"><a name="l00506"></a><span class="lineno"> 506</span>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a> = entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a> = 0;</div><div class="line"><a name="l00507"></a><span class="lineno"> 507</span>  }</div><div class="line"><a name="l00508"></a><span class="lineno"> 508</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>++;</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> <span class="keyword">static</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00512"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#abd2051b6b857de0a4b8aec12043fe005"> 512</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> *table)</div><div class="line"><a name="l00513"></a><span class="lineno"> 513</span> {</div><div class="line"><a name="l00514"></a><span class="lineno"> 514</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i;</div><div class="line"><a name="l00515"></a><span class="lineno"> 515</span>  <a class="code" href="../../d8/ddd/structst__packed__entry.html">st_packed_entry</a> packed_bins[<a class="code" href="../../d4/d71/st_8c.html#a2e84b634e97a0834e9f03658d1cb202f">MAX_PACKED_HASH</a>];</div><div class="line"><a name="l00516"></a><span class="lineno"> 516</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *entry, *preventry = 0, **chain;</div><div class="line"><a name="l00517"></a><span class="lineno"> 517</span>  <a class="code" href="../../d0/ddd/structst__table.html">st_table</a> tmp_table = *table;</div><div class="line"><a name="l00518"></a><span class="lineno"> 518</span> </div><div class="line"><a name="l00519"></a><span class="lineno"> 519</span>  <a class="code" href="../../de/de6/ruby_2ruby_8h.html#a04ab67335215e8362c63ed27ae2d1c40">MEMCPY</a>(packed_bins, <a class="code" href="../../d4/d71/st_8c.html#a79bb3acd36ef8b09877de02e883ea92c">PACKED_BINS</a>(table), <a class="code" href="../../d8/ddd/structst__packed__entry.html">st_packed_entry</a>, <a class="code" href="../../d4/d71/st_8c.html#a2e84b634e97a0834e9f03658d1cb202f">MAX_PACKED_HASH</a>);</div><div class="line"><a name="l00520"></a><span class="lineno"> 520</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#acd6cc341ae261d08a1dbaa8de03e2bd4">as</a>.<a class="code" href="../../d0/ddd/structst__table.html#a22a80745213b612a72093b1a461a5711">packed</a>.entries = packed_bins;</div><div class="line"><a name="l00521"></a><span class="lineno"> 521</span>  tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a> = 0;</div><div class="line"><a name="l00522"></a><span class="lineno"> 522</span> <span class="preprocessor">#if ST_DEFAULT_INIT_TABLE_SIZE == ST_DEFAULT_PACKED_TABLE_SIZE</span></div><div class="line"><a name="l00523"></a><span class="lineno"> 523</span>  <a class="code" href="../../de/de6/ruby_2ruby_8h.html#a56d620b94b668ed7665d1616b2c54e48">MEMZERO</a>(tmp_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>*, tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div><div class="line"><a name="l00524"></a><span class="lineno"> 524</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l00525"></a><span class="lineno"> 525</span>  tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> = <a class="code" href="../../d4/d71/st_8c.html#a4fc94afd44187992a916a7a4608481d4">st_realloc_bins</a>(tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, <a class="code" href="../../d4/d71/st_8c.html#a311df13f4d458054df7d87ca22782ab2">ST_DEFAULT_INIT_TABLE_SIZE</a>, tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div><div class="line"><a name="l00526"></a><span class="lineno"> 526</span>  tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a> = <a class="code" href="../../d4/d71/st_8c.html#a311df13f4d458054df7d87ca22782ab2">ST_DEFAULT_INIT_TABLE_SIZE</a>;</div><div class="line"><a name="l00527"></a><span class="lineno"> 527</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l00528"></a><span class="lineno"> 528</span>  i = 0;</div><div class="line"><a name="l00529"></a><span class="lineno"> 529</span>  chain = &tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>;</div><div class="line"><a name="l00530"></a><span class="lineno"> 530</span>  <span class="keywordflow">do</span> {</div><div class="line"><a name="l00531"></a><span class="lineno"> 531</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = packed_bins[i].<a class="code" href="../../d8/ddd/structst__packed__entry.html#ad82c9cdfeaa161b28652002eeaf1999c">key</a>;</div><div class="line"><a name="l00532"></a><span class="lineno"> 532</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../df/d38/vm__exec_8c.html">val</a> = packed_bins[i].<a class="code" href="../../d8/ddd/structst__packed__entry.html#a709049731ea4672ec675de3585e97c31">val</a>;</div><div class="line"><a name="l00533"></a><span class="lineno"> 533</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a> = packed_bins[i].<a class="code" href="../../d8/ddd/structst__packed__entry.html#a35a714a0761f0319735d1ce91298328b">hash</a>;</div><div class="line"><a name="l00534"></a><span class="lineno"> 534</span>  entry = <a class="code" href="../../d4/d71/st_8c.html#ac1c04331d2aef8182cd58605fcc2fb25">new_entry</a>(&tmp_table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../df/d38/vm__exec_8c.html">val</a>, <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a>,</div><div class="line"><a name="l00535"></a><span class="lineno"> 535</span>  <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a> % <a class="code" href="../../d4/d71/st_8c.html#a311df13f4d458054df7d87ca22782ab2">ST_DEFAULT_INIT_TABLE_SIZE</a>);</div><div class="line"><a name="l00536"></a><span class="lineno"> 536</span>  *chain = entry;</div><div class="line"><a name="l00537"></a><span class="lineno"> 537</span>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a> = preventry;</div><div class="line"><a name="l00538"></a><span class="lineno"> 538</span>  preventry = entry;</div><div class="line"><a name="l00539"></a><span class="lineno"> 539</span>  chain = &entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div><div class="line"><a name="l00540"></a><span class="lineno"> 540</span>  } <span class="keywordflow">while</span> (++i < <a class="code" href="../../d4/d71/st_8c.html#a2e84b634e97a0834e9f03658d1cb202f">MAX_PACKED_HASH</a>);</div><div class="line"><a name="l00541"></a><span class="lineno"> 541</span>  *chain = <a class="code" href="../../d4/db0/__sdbm_8c.html#a070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;</div><div class="line"><a name="l00542"></a><span class="lineno"> 542</span>  tmp_table.<a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = entry;</div><div class="line"><a name="l00543"></a><span class="lineno"> 543</span>  *table = tmp_table;</div><div class="line"><a name="l00544"></a><span class="lineno"> 544</span> }</div><div class="line"><a name="l00545"></a><span class="lineno"> 545</span> </div><div class="line"><a name="l00546"></a><span class="lineno"> 546</span> <span class="keyword">static</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00547"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a331ffe3f89d8c0f929d2c5e8967cc1db"> 547</a></span> <a class="code" href="../../d4/d71/st_8c.html#a331ffe3f89d8c0f929d2c5e8967cc1db">add_packed_direct</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> value, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val)</div><div class="line"><a name="l00548"></a><span class="lineno"> 548</span> {</div><div class="line"><a name="l00549"></a><span class="lineno"> 549</span>  <span class="keywordflow">if</span> (table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a> < <a class="code" href="../../d4/d71/st_8c.html#a2e84b634e97a0834e9f03658d1cb202f">MAX_PACKED_HASH</a>) {</div><div class="line"><a name="l00550"></a><span class="lineno"> 550</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>++;</div><div class="line"><a name="l00551"></a><span class="lineno"> 551</span>  <a class="code" href="../../d4/d71/st_8c.html#ab0f310ebc69f2456e8608a505662e139">PKEY_SET</a>(table, i, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00552"></a><span class="lineno"> 552</span>  <a class="code" href="../../d4/d71/st_8c.html#ab2607640960e5c6916c5164be9a3646b">PVAL_SET</a>(table, i, value);</div><div class="line"><a name="l00553"></a><span class="lineno"> 553</span>  <a class="code" href="../../d4/d71/st_8c.html#a7ae8f8630077956a99c2fb7966beae3d">PHASH_SET</a>(table, i, hash_val);</div><div class="line"><a name="l00554"></a><span class="lineno"> 554</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>++;</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>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00557"></a><span class="lineno"> 557</span>  <a class="code" href="../../d4/d71/st_8c.html#abd2051b6b857de0a4b8aec12043fe005">unpack_entries</a>(table);</div><div class="line"><a name="l00558"></a><span class="lineno"> 558</span>  <a class="code" href="../../d4/d71/st_8c.html#acc0ef6968908283247217a06840c6d8c">add_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val, hash_val % table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</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> }</div><div class="line"><a name="l00561"></a><span class="lineno"> 561</span> </div><div class="line"><a name="l00562"></a><span class="lineno"> 562</span> </div><div class="line"><a name="l00563"></a><span class="lineno"> 563</span> <span class="keywordtype">int</span></div><div class="line"><a name="l00564"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a068ebca65df8733df9e368b4d6dd82ca"> 564</a></span> <a class="code" href="../../d4/d71/st_8c.html#a068ebca65df8733df9e368b4d6dd82ca">st_insert</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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> value)</div><div class="line"><a name="l00565"></a><span class="lineno"> 565</span> {</div><div class="line"><a name="l00566"></a><span class="lineno"> 566</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div><div class="line"><a name="l00567"></a><span class="lineno"> 567</span>  <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> bin_pos;</div><div class="line"><a name="l00568"></a><span class="lineno"> 568</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr;</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>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, table);</div><div class="line"><a name="l00571"></a><span class="lineno"> 571</span> </div><div class="line"><a name="l00572"></a><span class="lineno"> 572</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="l00573"></a><span class="lineno"> 573</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(table, hash_val, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00574"></a><span class="lineno"> 574</span>  <span class="keywordflow">if</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a>) {</div><div class="line"><a name="l00575"></a><span class="lineno"> 575</span>  <a class="code" href="../../d4/d71/st_8c.html#ab2607640960e5c6916c5164be9a3646b">PVAL_SET</a>(table, i, value);</div><div class="line"><a name="l00576"></a><span class="lineno"> 576</span>  <span class="keywordflow">return</span> 1;</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>  <a class="code" href="../../d4/d71/st_8c.html#a331ffe3f89d8c0f929d2c5e8967cc1db">add_packed_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val);</div><div class="line"><a name="l00579"></a><span class="lineno"> 579</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00580"></a><span class="lineno"> 580</span>  }</div><div class="line"><a name="l00581"></a><span class="lineno"> 581</span> </div><div class="line"><a name="l00582"></a><span class="lineno"> 582</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="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 == 0) {</div><div class="line"><a name="l00585"></a><span class="lineno"> 585</span>  <a class="code" href="../../d4/d71/st_8c.html#acc0ef6968908283247217a06840c6d8c">add_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val, bin_pos);</div><div class="line"><a name="l00586"></a><span class="lineno"> 586</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00587"></a><span class="lineno"> 587</span>  }</div><div class="line"><a name="l00588"></a><span class="lineno"> 588</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00589"></a><span class="lineno"> 589</span>  ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a> = value;</div><div class="line"><a name="l00590"></a><span class="lineno"> 590</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00591"></a><span class="lineno"> 591</span>  }</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> </div><div class="line"><a name="l00594"></a><span class="lineno"> 594</span> <span class="keywordtype">int</span></div><div class="line"><a name="l00595"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1000e3d262482cebe00e98bf21696749"> 595</a></span> <a class="code" href="../../d4/d71/st_8c.html#a1000e3d262482cebe00e98bf21696749">st_insert2</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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> value,</div><div class="line"><a name="l00596"></a><span class="lineno"> 596</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> (*<a class="code" href="../../dc/dd1/ossl__ssl_8c.html#a86771351f4ef469ab9c94739a64fd7ea">func</a>)(<a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a>))</div><div class="line"><a name="l00597"></a><span class="lineno"> 597</span> {</div><div class="line"><a name="l00598"></a><span class="lineno"> 598</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div><div class="line"><a name="l00599"></a><span class="lineno"> 599</span>  <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> bin_pos;</div><div class="line"><a name="l00600"></a><span class="lineno"> 600</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr;</div><div class="line"><a name="l00601"></a><span class="lineno"> 601</span> </div><div class="line"><a name="l00602"></a><span class="lineno"> 602</span>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, table);</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">if</span> (table-><a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div><div class="line"><a name="l00605"></a><span class="lineno"> 605</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(table, hash_val, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00606"></a><span class="lineno"> 606</span>  <span class="keywordflow">if</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a>) {</div><div class="line"><a name="l00607"></a><span class="lineno"> 607</span>  <a class="code" href="../../d4/d71/st_8c.html#ab2607640960e5c6916c5164be9a3646b">PVAL_SET</a>(table, i, value);</div><div class="line"><a name="l00608"></a><span class="lineno"> 608</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00609"></a><span class="lineno"> 609</span>  }</div><div class="line"><a name="l00610"></a><span class="lineno"> 610</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = (*func)(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00611"></a><span class="lineno"> 611</span>  <a class="code" href="../../d4/d71/st_8c.html#a331ffe3f89d8c0f929d2c5e8967cc1db">add_packed_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val);</div><div class="line"><a name="l00612"></a><span class="lineno"> 612</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00613"></a><span class="lineno"> 613</span>  }</div><div class="line"><a name="l00614"></a><span class="lineno"> 614</span> </div><div class="line"><a name="l00615"></a><span class="lineno"> 615</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="l00616"></a><span class="lineno"> 616</span> </div><div class="line"><a name="l00617"></a><span class="lineno"> 617</span>  <span class="keywordflow">if</span> (ptr == 0) {</div><div class="line"><a name="l00618"></a><span class="lineno"> 618</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = (*func)(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00619"></a><span class="lineno"> 619</span>  <a class="code" href="../../d4/d71/st_8c.html#acc0ef6968908283247217a06840c6d8c">add_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val, bin_pos);</div><div class="line"><a name="l00620"></a><span class="lineno"> 620</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00621"></a><span class="lineno"> 621</span>  }</div><div class="line"><a name="l00622"></a><span class="lineno"> 622</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00623"></a><span class="lineno"> 623</span>  ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a> = value;</div><div class="line"><a name="l00624"></a><span class="lineno"> 624</span>  <span class="keywordflow">return</span> 1;</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> }</div><div class="line"><a name="l00627"></a><span class="lineno"> 627</span> </div><div class="line"><a name="l00628"></a><span class="lineno"> 628</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00629"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a6c727f5a38e3e21fea2d0b8468813d87"> 629</a></span> <a class="code" href="../../d4/d71/st_8c.html#a6c727f5a38e3e21fea2d0b8468813d87">st_add_direct</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> value)</div><div class="line"><a name="l00630"></a><span class="lineno"> 630</span> {</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> hash_val;</div><div class="line"><a name="l00632"></a><span class="lineno"> 632</span> </div><div class="line"><a name="l00633"></a><span class="lineno"> 633</span>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, table);</div><div class="line"><a name="l00634"></a><span class="lineno"> 634</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="l00635"></a><span class="lineno"> 635</span>  <a class="code" href="../../d4/d71/st_8c.html#a331ffe3f89d8c0f929d2c5e8967cc1db">add_packed_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val);</div><div class="line"><a name="l00636"></a><span class="lineno"> 636</span>  <span class="keywordflow">return</span>;</div><div class="line"><a name="l00637"></a><span class="lineno"> 637</span>  }</div><div class="line"><a name="l00638"></a><span class="lineno"> 638</span> </div><div class="line"><a name="l00639"></a><span class="lineno"> 639</span>  <a class="code" href="../../d4/d71/st_8c.html#acc0ef6968908283247217a06840c6d8c">add_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val, hash_val % table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</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> </div><div class="line"><a name="l00642"></a><span class="lineno"> 642</span> <span class="keyword">static</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00643"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a78898e934706b6d8fb8ffc7b598a0408"> 643</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="l00644"></a><span class="lineno"> 644</span> {</div><div class="line"><a name="l00645"></a><span class="lineno"> 645</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr, **new_bins;</div><div class="line"><a name="l00646"></a><span class="lineno"> 646</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> new_num_bins, hash_val;</div><div class="line"><a name="l00647"></a><span class="lineno"> 647</span> </div><div class="line"><a name="l00648"></a><span class="lineno"> 648</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="l00649"></a><span class="lineno"> 649</span>  new_bins = <a class="code" href="../../d4/d71/st_8c.html#a4fc94afd44187992a916a7a4608481d4">st_realloc_bins</a>(table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>, new_num_bins, table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div><div class="line"><a name="l00650"></a><span class="lineno"> 650</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a> = new_num_bins;</div><div class="line"><a name="l00651"></a><span class="lineno"> 651</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> = new_bins;</div><div class="line"><a name="l00652"></a><span class="lineno"> 652</span> </div><div class="line"><a name="l00653"></a><span class="lineno"> 653</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="l00654"></a><span class="lineno"> 654</span>  <span class="keywordflow">do</span> {</div><div class="line"><a name="l00655"></a><span class="lineno"> 655</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="l00656"></a><span class="lineno"> 656</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="l00657"></a><span class="lineno"> 657</span>  new_bins[hash_val] = ptr;</div><div class="line"><a name="l00658"></a><span class="lineno"> 658</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="l00659"></a><span class="lineno"> 659</span>  }</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> <a class="code" href="../../d0/ddd/structst__table.html">st_table</a>*</div><div class="line"><a name="l00663"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1fe53fe235ae6db0c7abe49413785363"> 663</a></span> <a class="code" href="../../d4/d71/st_8c.html#a1fe53fe235ae6db0c7abe49413785363">st_copy</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *old_table)</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="../../d0/ddd/structst__table.html">st_table</a> *new_table;</div><div class="line"><a name="l00666"></a><span class="lineno"> 666</span>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr, *entry, *prev, **tailp;</div><div class="line"><a name="l00667"></a><span class="lineno"> 667</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="l00668"></a><span class="lineno"> 668</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div><div class="line"><a name="l00669"></a><span class="lineno"> 669</span> </div><div class="line"><a name="l00670"></a><span class="lineno"> 670</span>  new_table = <a class="code" href="../../d4/d71/st_8c.html#a4bfcb3c7be49d9acd35fa21e8372cd41">st_alloc_table</a>();</div><div class="line"><a name="l00671"></a><span class="lineno"> 671</span>  <span class="keywordflow">if</span> (new_table == 0) {</div><div class="line"><a name="l00672"></a><span class="lineno"> 672</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00673"></a><span class="lineno"> 673</span>  }</div><div class="line"><a name="l00674"></a><span class="lineno"> 674</span> </div><div class="line"><a name="l00675"></a><span class="lineno"> 675</span>  *new_table = *old_table;</div><div class="line"><a name="l00676"></a><span class="lineno"> 676</span>  new_table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a> = <a class="code" href="../../d4/d71/st_8c.html#ae3ba2172909b8e58e5abfdef7642155b">st_alloc_bins</a>(num_bins);</div><div class="line"><a name="l00677"></a><span class="lineno"> 677</span> </div><div class="line"><a name="l00678"></a><span class="lineno"> 678</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="l00679"></a><span class="lineno"> 679</span>  <a class="code" href="../../d4/d71/st_8c.html#af2207ffbfcc7d6db423a059634117edb">st_dealloc_table</a>(new_table);</div><div class="line"><a name="l00680"></a><span class="lineno"> 680</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00681"></a><span class="lineno"> 681</span>  }</div><div class="line"><a name="l00682"></a><span class="lineno"> 682</span> </div><div class="line"><a name="l00683"></a><span class="lineno"> 683</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="l00684"></a><span class="lineno"> 684</span>  <a class="code" href="../../de/de6/ruby_2ruby_8h.html#a04ab67335215e8362c63ed27ae2d1c40">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>, <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="l00685"></a><span class="lineno"> 685</span>  <span class="keywordflow">return</span> new_table;</div><div class="line"><a name="l00686"></a><span class="lineno"> 686</span>  }</div><div class="line"><a name="l00687"></a><span class="lineno"> 687</span> </div><div class="line"><a name="l00688"></a><span class="lineno"> 688</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="l00689"></a><span class="lineno"> 689</span>  prev = 0;</div><div class="line"><a name="l00690"></a><span class="lineno"> 690</span>  tailp = &new_table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>;</div><div class="line"><a name="l00691"></a><span class="lineno"> 691</span>  <span class="keywordflow">do</span> {</div><div class="line"><a name="l00692"></a><span class="lineno"> 692</span>  entry = <a class="code" href="../../d4/d71/st_8c.html#aa9053dd461189a7780f276bfac62194c">st_alloc_entry</a>();</div><div class="line"><a name="l00693"></a><span class="lineno"> 693</span>  <span class="keywordflow">if</span> (entry == 0) {</div><div class="line"><a name="l00694"></a><span class="lineno"> 694</span>  <a class="code" href="../../d4/d71/st_8c.html#a93394fd99c5fa4fbcce2be9717abee45">st_free_table</a>(new_table);</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>  *entry = *ptr;</div><div class="line"><a name="l00698"></a><span class="lineno"> 698</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="l00699"></a><span class="lineno"> 699</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="l00700"></a><span class="lineno"> 700</span>  new_table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val] = entry;</div><div class="line"><a name="l00701"></a><span class="lineno"> 701</span>  entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a> = prev;</div><div class="line"><a name="l00702"></a><span class="lineno"> 702</span>  *tailp = prev = entry;</div><div class="line"><a name="l00703"></a><span class="lineno"> 703</span>  tailp = &entry-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div><div class="line"><a name="l00704"></a><span class="lineno"> 704</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="l00705"></a><span class="lineno"> 705</span>  new_table-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = prev;</div><div class="line"><a name="l00706"></a><span class="lineno"> 706</span>  }</div><div class="line"><a name="l00707"></a><span class="lineno"> 707</span> </div><div class="line"><a name="l00708"></a><span class="lineno"> 708</span>  <span class="keywordflow">return</span> new_table;</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> </div><div class="line"><a name="l00711"></a><span class="lineno"> 711</span> <span class="keyword">static</span> <span class="keyword">inline</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00712"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970"> 712</a></span> <a class="code" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr)</div><div class="line"><a name="l00713"></a><span class="lineno"> 713</span> {</div><div class="line"><a name="l00714"></a><span class="lineno"> 714</span>  <span class="keywordflow">if</span> (ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a> == 0 && ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a> == 0) {</div><div class="line"><a name="l00715"></a><span class="lineno"> 715</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a> = 0;</div><div class="line"><a name="l00716"></a><span class="lineno"> 716</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = 0;</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>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00719"></a><span class="lineno"> 719</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> = ptr-><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> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div><div class="line"><a name="l00720"></a><span class="lineno"> 720</span>  <span class="keywordflow">if</span> (<a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</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> = <a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div><div class="line"><a name="l00721"></a><span class="lineno"> 721</span>  <span class="keywordflow">if</span> (<a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>) <a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a> = <a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</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>) table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a> = <a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div><div class="line"><a name="l00723"></a><span class="lineno"> 723</span>  <span class="keywordflow">if</span> (ptr == table-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a>) table-><a class="code" href="../../d0/ddd/structst__table.html#aee1c61d83bbbf2f176255a8a903a92ed">tail</a> = <a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div><div class="line"><a name="l00724"></a><span class="lineno"> 724</span>  }</div><div class="line"><a name="l00725"></a><span class="lineno"> 725</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div><div class="line"><a name="l00726"></a><span class="lineno"> 726</span> }</div><div class="line"><a name="l00727"></a><span class="lineno"> 727</span> </div><div class="line"><a name="l00728"></a><span class="lineno"> 728</span> <span class="keywordtype">int</span></div><div class="line"><a name="l00729"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a376a6db1416fd2edb1ce72ad624ff109"> 729</a></span> <a class="code" href="../../d4/d71/st_8c.html#a376a6db1416fd2edb1ce72ad624ff109">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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *value)</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>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div><div class="line"><a name="l00732"></a><span class="lineno"> 732</span>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> **prev;</div><div class="line"><a name="l00733"></a><span class="lineno"> 733</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr;</div><div class="line"><a name="l00734"></a><span class="lineno"> 734</span> </div><div class="line"><a name="l00735"></a><span class="lineno"> 735</span>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(*<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, table);</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="keywordflow">if</span> (table-><a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div><div class="line"><a name="l00738"></a><span class="lineno"> 738</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(table, hash_val, *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00739"></a><span class="lineno"> 739</span>  <span class="keywordflow">if</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a>) {</div><div class="line"><a name="l00740"></a><span class="lineno"> 740</span>  <span class="keywordflow">if</span> (value != 0) *value = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, i);</div><div class="line"><a name="l00741"></a><span class="lineno"> 741</span>  *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l00742"></a><span class="lineno"> 742</span>  <a class="code" href="../../d4/d71/st_8c.html#a0fccb1100278656a74bdfd5d7c3f9913">remove_packed_entry</a>(table, i);</div><div class="line"><a name="l00743"></a><span class="lineno"> 743</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00744"></a><span class="lineno"> 744</span>  }</div><div class="line"><a name="l00745"></a><span class="lineno"> 745</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div><div class="line"><a name="l00746"></a><span class="lineno"> 746</span>  <span class="keywordflow">return</span> 0;</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> </div><div class="line"><a name="l00749"></a><span class="lineno"> 749</span>  prev = &table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val % table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>];</div><div class="line"><a name="l00750"></a><span class="lineno"> 750</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="l00751"></a><span class="lineno"> 751</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#ab5676cd1fb91981de326030c5b15c867">EQUAL</a>(table, *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>)) {</div><div class="line"><a name="l00752"></a><span class="lineno"> 752</span>  *prev = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l00753"></a><span class="lineno"> 753</span>  <a class="code" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a>(table, ptr);</div><div class="line"><a name="l00754"></a><span class="lineno"> 754</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="l00755"></a><span class="lineno"> 755</span>  *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div><div class="line"><a name="l00756"></a><span class="lineno"> 756</span>  <a class="code" href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b">st_free_entry</a>(ptr);</div><div class="line"><a name="l00757"></a><span class="lineno"> 757</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00758"></a><span class="lineno"> 758</span>  }</div><div class="line"><a name="l00759"></a><span class="lineno"> 759</span>  }</div><div class="line"><a name="l00760"></a><span class="lineno"> 760</span> </div><div class="line"><a name="l00761"></a><span class="lineno"> 761</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div><div class="line"><a name="l00762"></a><span class="lineno"> 762</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00763"></a><span class="lineno"> 763</span> }</div><div class="line"><a name="l00764"></a><span class="lineno"> 764</span> </div><div class="line"><a name="l00765"></a><span class="lineno"> 765</span> <span class="keywordtype">int</span></div><div class="line"><a name="l00766"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aaafeee841b664f0ea14b28e7e1b1a71a"> 766</a></span> <a class="code" href="../../d4/d71/st_8c.html#aaafeee841b664f0ea14b28e7e1b1a71a">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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *value, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> never)</div><div class="line"><a name="l00767"></a><span class="lineno"> 767</span> {</div><div class="line"><a name="l00768"></a><span class="lineno"> 768</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hash_val;</div><div class="line"><a name="l00769"></a><span class="lineno"> 769</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr;</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>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(*<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, table);</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="keywordflow">if</span> (table-><a class="code" href="../../d0/ddd/structst__table.html#af86c7c8652d8c86d356b6dc620a56efb">entries_packed</a>) {</div><div class="line"><a name="l00774"></a><span class="lineno"> 774</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(table, hash_val, *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00775"></a><span class="lineno"> 775</span>  <span class="keywordflow">if</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a>) {</div><div class="line"><a name="l00776"></a><span class="lineno"> 776</span>  <span class="keywordflow">if</span> (value != 0) *value = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, i);</div><div class="line"><a name="l00777"></a><span class="lineno"> 777</span>  *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l00778"></a><span class="lineno"> 778</span>  <a class="code" href="../../d4/d71/st_8c.html#ab663e132c2bb344be9d0763540c23509">remove_safe_packed_entry</a>(table, i, never);</div><div class="line"><a name="l00779"></a><span class="lineno"> 779</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00780"></a><span class="lineno"> 780</span>  }</div><div class="line"><a name="l00781"></a><span class="lineno"> 781</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div><div class="line"><a name="l00782"></a><span class="lineno"> 782</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00783"></a><span class="lineno"> 783</span>  }</div><div class="line"><a name="l00784"></a><span class="lineno"> 784</span> </div><div class="line"><a name="l00785"></a><span class="lineno"> 785</span>  ptr = table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[hash_val % table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>];</div><div class="line"><a name="l00786"></a><span class="lineno"> 786</span> </div><div class="line"><a name="l00787"></a><span class="lineno"> 787</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="l00788"></a><span class="lineno"> 788</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>, *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>)) {</div><div class="line"><a name="l00789"></a><span class="lineno"> 789</span>  <a class="code" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a>(table, ptr);</div><div class="line"><a name="l00790"></a><span class="lineno"> 790</span>  *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div><div class="line"><a name="l00791"></a><span class="lineno"> 791</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="l00792"></a><span class="lineno"> 792</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="l00793"></a><span class="lineno"> 793</span>  <span class="keywordflow">return</span> 1;</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>  }</div><div class="line"><a name="l00796"></a><span class="lineno"> 796</span> </div><div class="line"><a name="l00797"></a><span class="lineno"> 797</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div><div class="line"><a name="l00798"></a><span class="lineno"> 798</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00799"></a><span class="lineno"> 799</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="keywordtype">int</span></div><div class="line"><a name="l00802"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aa98339af92fd08445ea0683805843bd9"> 802</a></span> <a class="code" href="../../d4/d71/st_8c.html#aa98339af92fd08445ea0683805843bd9">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="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *value)</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>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> **prev;</div><div class="line"><a name="l00805"></a><span class="lineno"> 805</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr;</div><div class="line"><a name="l00806"></a><span class="lineno"> 806</span> </div><div class="line"><a name="l00807"></a><span class="lineno"> 807</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="l00808"></a><span class="lineno"> 808</span>  <span class="keywordflow">if</span> (value != 0) *value = 0;</div><div class="line"><a name="l00809"></a><span class="lineno"> 809</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00810"></a><span class="lineno"> 810</span>  }</div><div class="line"><a name="l00811"></a><span class="lineno"> 811</span> </div><div class="line"><a name="l00812"></a><span class="lineno"> 812</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="l00813"></a><span class="lineno"> 813</span>  <span class="keywordflow">if</span> (value != 0) *value = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, 0);</div><div class="line"><a name="l00814"></a><span class="lineno"> 814</span>  *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, 0);</div><div class="line"><a name="l00815"></a><span class="lineno"> 815</span>  <a class="code" href="../../d4/d71/st_8c.html#a0fccb1100278656a74bdfd5d7c3f9913">remove_packed_entry</a>(table, 0);</div><div class="line"><a name="l00816"></a><span class="lineno"> 816</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00817"></a><span class="lineno"> 817</span>  }</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>  prev = &table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>-><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="l00820"></a><span class="lineno"> 820</span>  <span class="keywordflow">while</span> ((ptr = *prev) != table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>) prev = &ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l00821"></a><span class="lineno"> 821</span>  *prev = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l00822"></a><span class="lineno"> 822</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="l00823"></a><span class="lineno"> 823</span>  *<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div><div class="line"><a name="l00824"></a><span class="lineno"> 824</span>  <a class="code" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a>(table, ptr);</div><div class="line"><a name="l00825"></a><span class="lineno"> 825</span>  <a class="code" href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b">st_free_entry</a>(ptr);</div><div class="line"><a name="l00826"></a><span class="lineno"> 826</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l00827"></a><span class="lineno"> 827</span> }</div><div class="line"><a name="l00828"></a><span class="lineno"> 828</span> </div><div class="line"><a name="l00829"></a><span class="lineno"> 829</span> <span class="keywordtype">void</span></div><div class="line"><a name="l00830"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a3fde5a76b3fc28787b7350eaf790676b"> 830</a></span> <a class="code" href="../../d4/d71/st_8c.html#a3fde5a76b3fc28787b7350eaf790676b">st_cleanup_safe</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> never)</div><div class="line"><a name="l00831"></a><span class="lineno"> 831</span> {</div><div class="line"><a name="l00832"></a><span class="lineno"> 832</span>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr, **<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>, *tmp;</div><div class="line"><a name="l00833"></a><span class="lineno"> 833</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i;</div><div class="line"><a name="l00834"></a><span class="lineno"> 834</span> </div><div class="line"><a name="l00835"></a><span class="lineno"> 835</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="l00836"></a><span class="lineno"> 836</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="l00837"></a><span class="lineno"> 837</span>  <span class="keywordflow">while</span> (<a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i) != never) {</div><div class="line"><a name="l00838"></a><span class="lineno"> 838</span>  <span class="keywordflow">if</span> (i++ == table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>) <span class="keywordflow">return</span>;</div><div class="line"><a name="l00839"></a><span class="lineno"> 839</span>  }</div><div class="line"><a name="l00840"></a><span class="lineno"> 840</span>  <span class="keywordflow">for</span> (j = i; ++i < table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>;) {</div><div class="line"><a name="l00841"></a><span class="lineno"> 841</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i) == never) <span class="keywordflow">continue</span>;</div><div class="line"><a name="l00842"></a><span class="lineno"> 842</span>  <a class="code" href="../../d4/d71/st_8c.html#a438ae9ef62bab55aac6d75766e76d553">PACKED_ENT</a>(table, j) = <a class="code" href="../../d4/d71/st_8c.html#a438ae9ef62bab55aac6d75766e76d553">PACKED_ENT</a>(table, i);</div><div class="line"><a name="l00843"></a><span class="lineno"> 843</span>  j++;</div><div class="line"><a name="l00844"></a><span class="lineno"> 844</span>  }</div><div class="line"><a name="l00845"></a><span class="lineno"> 845</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a> = j;</div><div class="line"><a name="l00846"></a><span class="lineno"> 846</span>  <span class="comment">/* table->num_entries really should be equal j at this moment, but let set it anyway */</span></div><div class="line"><a name="l00847"></a><span class="lineno"> 847</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a> = j;</div><div class="line"><a name="l00848"></a><span class="lineno"> 848</span>  <span class="keywordflow">return</span>;</div><div class="line"><a name="l00849"></a><span class="lineno"> 849</span>  }</div><div class="line"><a name="l00850"></a><span class="lineno"> 850</span> </div><div class="line"><a name="l00851"></a><span class="lineno"> 851</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="l00852"></a><span class="lineno"> 852</span>  ptr = *(<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[i]);</div><div class="line"><a name="l00853"></a><span class="lineno"> 853</span>  <span class="keywordflow">while</span> (ptr != 0) {</div><div class="line"><a name="l00854"></a><span class="lineno"> 854</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="l00855"></a><span class="lineno"> 855</span>  tmp = ptr;</div><div class="line"><a name="l00856"></a><span class="lineno"> 856</span>  *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l00857"></a><span class="lineno"> 857</span>  <a class="code" href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b">st_free_entry</a>(tmp);</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">else</span> {</div><div class="line"><a name="l00860"></a><span class="lineno"> 860</span>  ptr = *(<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>);</div><div class="line"><a name="l00861"></a><span class="lineno"> 861</span>  }</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> }</div><div class="line"><a name="l00865"></a><span class="lineno"> 865</span> </div><div class="line"><a name="l00866"></a><span class="lineno"> 866</span> <span class="keywordtype">int</span></div><div class="line"><a name="l00867"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a5a026e0f0fbb0375b83056f0124889ee"> 867</a></span> <a class="code" href="../../d4/d71/st_8c.html#a5a026e0f0fbb0375b83056f0124889ee">st_update</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../dd/d24/st_8h.html#ab68dfde3b434381a536b6909c519e535">st_update_callback_func</a> *<a class="code" href="../../dc/dd1/ossl__ssl_8c.html#a86771351f4ef469ab9c94739a64fd7ea">func</a>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> arg)</div><div class="line"><a name="l00868"></a><span class="lineno"> 868</span> {</div><div class="line"><a name="l00869"></a><span class="lineno"> 869</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="l00870"></a><span class="lineno"> 870</span>  <span class="keyword">register</span> <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr, **<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>, *tmp;</div><div class="line"><a name="l00871"></a><span class="lineno"> 871</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> value = 0;</div><div class="line"><a name="l00872"></a><span class="lineno"> 872</span>  <span class="keywordtype">int</span> retval, existing = 0;</div><div class="line"><a name="l00873"></a><span class="lineno"> 873</span> </div><div class="line"><a name="l00874"></a><span class="lineno"> 874</span>  hash_val = <a class="code" href="../../d4/d71/st_8c.html#a8719b25fa2e849ad268f0bb382bae21c">do_hash</a>(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, table);</div><div class="line"><a name="l00875"></a><span class="lineno"> 875</span> </div><div class="line"><a name="l00876"></a><span class="lineno"> 876</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="l00877"></a><span class="lineno"> 877</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i = <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(table, hash_val, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00878"></a><span class="lineno"> 878</span>  <span class="keywordflow">if</span> (i < table-><a class="code" href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a>) {</div><div class="line"><a name="l00879"></a><span class="lineno"> 879</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l00880"></a><span class="lineno"> 880</span>  value = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, i);</div><div class="line"><a name="l00881"></a><span class="lineno"> 881</span>  existing = 1;</div><div class="line"><a name="l00882"></a><span class="lineno"> 882</span>  }</div><div class="line"><a name="l00883"></a><span class="lineno"> 883</span>  {</div><div class="line"><a name="l00884"></a><span class="lineno"> 884</span>  retval = (*func)(&<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, &value, arg, existing);</div><div class="line"><a name="l00885"></a><span class="lineno"> 885</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="l00886"></a><span class="lineno"> 886</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="l00887"></a><span class="lineno"> 887</span>  <span class="keywordflow">goto</span> unpacked;</div><div class="line"><a name="l00888"></a><span class="lineno"> 888</span>  }</div><div class="line"><a name="l00889"></a><span class="lineno"> 889</span>  <span class="keywordflow">switch</span> (retval) {</div><div class="line"><a name="l00890"></a><span class="lineno"> 890</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</a>:</div><div class="line"><a name="l00891"></a><span class="lineno"> 891</span>  <span class="keywordflow">if</span> (!existing) {</div><div class="line"><a name="l00892"></a><span class="lineno"> 892</span>  <a class="code" href="../../d4/d71/st_8c.html#a331ffe3f89d8c0f929d2c5e8967cc1db">add_packed_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val);</div><div class="line"><a name="l00893"></a><span class="lineno"> 893</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l00894"></a><span class="lineno"> 894</span>  }</div><div class="line"><a name="l00895"></a><span class="lineno"> 895</span>  <a class="code" href="../../d4/d71/st_8c.html#ab2607640960e5c6916c5164be9a3646b">PVAL_SET</a>(table, i, value);</div><div class="line"><a name="l00896"></a><span class="lineno"> 896</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l00897"></a><span class="lineno"> 897</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="l00898"></a><span class="lineno"> 898</span>  <span class="keywordflow">if</span> (!existing) <span class="keywordflow">break</span>;</div><div class="line"><a name="l00899"></a><span class="lineno"> 899</span>  <a class="code" href="../../d4/d71/st_8c.html#a0fccb1100278656a74bdfd5d7c3f9913">remove_packed_entry</a>(table, i);</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> existing;</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>  <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="l00906"></a><span class="lineno"> 906</span> </div><div class="line"><a name="l00907"></a><span class="lineno"> 907</span>  <span class="keywordflow">if</span> (ptr != 0) {</div><div class="line"><a name="l00908"></a><span class="lineno"> 908</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div><div class="line"><a name="l00909"></a><span class="lineno"> 909</span>  value = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>;</div><div class="line"><a name="l00910"></a><span class="lineno"> 910</span>  existing = 1;</div><div class="line"><a name="l00911"></a><span class="lineno"> 911</span>  }</div><div class="line"><a name="l00912"></a><span class="lineno"> 912</span>  {</div><div class="line"><a name="l00913"></a><span class="lineno"> 913</span>  retval = (*func)(&<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, &value, arg, existing);</div><div class="line"><a name="l00914"></a><span class="lineno"> 914</span>  unpacked:</div><div class="line"><a name="l00915"></a><span class="lineno"> 915</span>  <span class="keywordflow">switch</span> (retval) {</div><div class="line"><a name="l00916"></a><span class="lineno"> 916</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</a>:</div><div class="line"><a name="l00917"></a><span class="lineno"> 917</span>  <span class="keywordflow">if</span> (!existing) {</div><div class="line"><a name="l00918"></a><span class="lineno"> 918</span>  <a class="code" href="../../d4/d71/st_8c.html#acc0ef6968908283247217a06840c6d8c">add_direct</a>(table, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, value, hash_val, hash_val % table-><a class="code" href="../../d0/ddd/structst__table.html#a03f11a1fe0b82094d6acb038fa8118c3">num_bins</a>);</div><div class="line"><a name="l00919"></a><span class="lineno"> 919</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l00920"></a><span class="lineno"> 920</span>  }</div><div class="line"><a name="l00921"></a><span class="lineno"> 921</span>  ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a> = value;</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#a0c6a172fd99de7928916e65034ed8b1fa64ab176f8e8b9719bcd9b5297ccda9c7">ST_DELETE</a>:</div><div class="line"><a name="l00924"></a><span class="lineno"> 924</span>  <span class="keywordflow">if</span> (!existing) <span class="keywordflow">break</span>;</div><div class="line"><a name="l00925"></a><span class="lineno"> 925</span>  <a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &table-><a class="code" href="../../d0/ddd/structst__table.html#ae05091dd67490761fee653130e12c997">bins</a>[bin_pos];</div><div class="line"><a name="l00926"></a><span class="lineno"> 926</span>  <span class="keywordflow">for</span> (; (tmp = *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>) != 0; <a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &tmp-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div><div class="line"><a name="l00927"></a><span class="lineno"> 927</span>  <span class="keywordflow">if</span> (ptr == tmp) {</div><div class="line"><a name="l00928"></a><span class="lineno"> 928</span>  tmp = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div><div class="line"><a name="l00929"></a><span class="lineno"> 929</span>  *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l00930"></a><span class="lineno"> 930</span>  <a class="code" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a>(table, ptr);</div><div class="line"><a name="l00931"></a><span class="lineno"> 931</span>  <a class="code" href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b">st_free_entry</a>(ptr);</div><div class="line"><a name="l00932"></a><span class="lineno"> 932</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l00933"></a><span class="lineno"> 933</span>  }</div><div class="line"><a name="l00934"></a><span class="lineno"> 934</span>  }</div><div class="line"><a name="l00935"></a><span class="lineno"> 935</span>  <span class="keywordflow">break</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>  <span class="keywordflow">return</span> existing;</div><div class="line"><a name="l00938"></a><span class="lineno"> 938</span>  }</div><div class="line"><a name="l00939"></a><span class="lineno"> 939</span> }</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="keywordtype">int</span></div><div class="line"><a name="l00942"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a97be08dc6dad83bd7da3ff39ccbef462"> 942</a></span> <a class="code" href="../../d4/d71/st_8c.html#a97be08dc6dad83bd7da3ff39ccbef462">st_foreach_check</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#a86771351f4ef469ab9c94739a64fd7ea">func</a>)(<a class="code" href="../../d8/db0/defines_8h.html#af4fd7cbafda9af704310f78516042dfb">ANYARGS</a>), <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> arg, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> never)</div><div class="line"><a name="l00943"></a><span class="lineno"> 943</span> {</div><div class="line"><a name="l00944"></a><span class="lineno"> 944</span>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr, **<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>, *tmp;</div><div class="line"><a name="l00945"></a><span class="lineno"> 945</span>  <span class="keyword">enum</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1f">st_retval</a> retval;</div><div class="line"><a name="l00946"></a><span class="lineno"> 946</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i;</div><div class="line"><a name="l00947"></a><span class="lineno"> 947</span> </div><div class="line"><a name="l00948"></a><span class="lineno"> 948</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="l00949"></a><span class="lineno"> 949</span>  <span class="keywordflow">for</span> (i = 0; i < table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>; i++) {</div><div class="line"><a name="l00950"></a><span class="lineno"> 950</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../df/d38/vm__exec_8c.html">val</a>;</div><div class="line"><a name="l00951"></a><span class="lineno"> 951</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a>;</div><div class="line"><a name="l00952"></a><span class="lineno"> 952</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l00953"></a><span class="lineno"> 953</span>  <a class="code" href="../../df/d38/vm__exec_8c.html">val</a> = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, i);</div><div class="line"><a name="l00954"></a><span class="lineno"> 954</span>  <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a> = <a class="code" href="../../d4/d71/st_8c.html#a51731773e02649913e2a8d91d6ca4ad1">PHASH</a>(table, i);</div><div class="line"><a name="l00955"></a><span class="lineno"> 955</span>  <span class="keywordflow">if</span> (<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> == never) <span class="keywordflow">continue</span>;</div><div class="line"><a name="l00956"></a><span class="lineno"> 956</span>  retval = (*func)(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../df/d38/vm__exec_8c.html">val</a>, arg, 0);</div><div class="line"><a name="l00957"></a><span class="lineno"> 957</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="l00958"></a><span class="lineno"> 958</span>  <a class="code" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">FIND_ENTRY</a>(table, ptr, <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a>, i);</div><div class="line"><a name="l00959"></a><span class="lineno"> 959</span>  <span class="keywordflow">if</span> (retval == <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69">ST_CHECK</a>) {</div><div class="line"><a name="l00960"></a><span class="lineno"> 960</span>  <span class="keywordflow">if</span> (!ptr) <span class="keywordflow">goto</span> deleted;</div><div class="line"><a name="l00961"></a><span class="lineno"> 961</span>  <span class="keywordflow">goto</span> unpacked_continue;</div><div class="line"><a name="l00962"></a><span class="lineno"> 962</span>  }</div><div class="line"><a name="l00963"></a><span class="lineno"> 963</span>  <span class="keywordflow">goto</span> unpacked;</div><div class="line"><a name="l00964"></a><span class="lineno"> 964</span>  }</div><div class="line"><a name="l00965"></a><span class="lineno"> 965</span>  <span class="keywordflow">switch</span> (retval) {</div><div class="line"><a name="l00966"></a><span class="lineno"> 966</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69">ST_CHECK</a>: <span class="comment">/* check if hash is modified during iteration */</span></div><div class="line"><a name="l00967"></a><span class="lineno"> 967</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#a51731773e02649913e2a8d91d6ca4ad1">PHASH</a>(table, i) == 0 && <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i) == never) {</div><div class="line"><a name="l00968"></a><span class="lineno"> 968</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l00969"></a><span class="lineno"> 969</span>  }</div><div class="line"><a name="l00970"></a><span class="lineno"> 970</span>  i = <a class="code" href="../../d4/d71/st_8c.html#a77325ab6bf8e5f0cc3d02efc4a790bf2">find_packed_index_from</a>(table, <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a>, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, i);</div><div class="line"><a name="l00971"></a><span class="lineno"> 971</span>  <span class="keywordflow">if</span> (i >= table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>) {</div><div class="line"><a name="l00972"></a><span class="lineno"> 972</span>  i = <a class="code" href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a>(table, <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a>, <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>);</div><div class="line"><a name="l00973"></a><span class="lineno"> 973</span>  <span class="keywordflow">if</span> (i >= table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>) <span class="keywordflow">goto</span> deleted;</div><div class="line"><a name="l00974"></a><span class="lineno"> 974</span>  }</div><div class="line"><a name="l00975"></a><span class="lineno"> 975</span>  <span class="comment">/* fall through */</span></div><div class="line"><a name="l00976"></a><span class="lineno"> 976</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</a>:</div><div class="line"><a name="l00977"></a><span class="lineno"> 977</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l00978"></a><span class="lineno"> 978</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="l00979"></a><span class="lineno"> 979</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00980"></a><span class="lineno"> 980</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="l00981"></a><span class="lineno"> 981</span>  <a class="code" href="../../d4/d71/st_8c.html#ab663e132c2bb344be9d0763540c23509">remove_safe_packed_entry</a>(table, i, never);</div><div class="line"><a name="l00982"></a><span class="lineno"> 982</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l00983"></a><span class="lineno"> 983</span>  }</div><div class="line"><a name="l00984"></a><span class="lineno"> 984</span>  }</div><div class="line"><a name="l00985"></a><span class="lineno"> 985</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l00986"></a><span class="lineno"> 986</span>  }</div><div class="line"><a name="l00987"></a><span class="lineno"> 987</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l00988"></a><span class="lineno"> 988</span>  ptr = table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>;</div><div class="line"><a name="l00989"></a><span class="lineno"> 989</span>  }</div><div class="line"><a name="l00990"></a><span class="lineno"> 990</span> </div><div class="line"><a name="l00991"></a><span class="lineno"> 991</span>  <span class="keywordflow">if</span> (ptr != 0) {</div><div class="line"><a name="l00992"></a><span class="lineno"> 992</span>  <span class="keywordflow">do</span> {</div><div class="line"><a name="l00993"></a><span class="lineno"> 993</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="l00994"></a><span class="lineno"> 994</span>  <span class="keywordflow">goto</span> unpacked_continue;</div><div class="line"><a name="l00995"></a><span class="lineno"> 995</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="l00996"></a><span class="lineno"> 996</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>, arg, 0);</div><div class="line"><a name="l00997"></a><span class="lineno"> 997</span>  unpacked:</div><div class="line"><a name="l00998"></a><span class="lineno"> 998</span>  <span class="keywordflow">switch</span> (retval) {</div><div class="line"><a name="l00999"></a><span class="lineno"> 999</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69">ST_CHECK</a>: <span class="comment">/* check if hash is modified during iteration */</span></div><div class="line"><a name="l01000"></a><span class="lineno"> 1000</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="l01001"></a><span class="lineno"> 1001</span>  <span class="keywordflow">if</span> (!tmp) {</div><div class="line"><a name="l01002"></a><span class="lineno"> 1002</span>  deleted:</div><div class="line"><a name="l01003"></a><span class="lineno"> 1003</span>  <span class="comment">/* call func with error notice */</span></div><div class="line"><a name="l01004"></a><span class="lineno"> 1004</span>  retval = (*func)(0, 0, arg, 1);</div><div class="line"><a name="l01005"></a><span class="lineno"> 1005</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l01006"></a><span class="lineno"> 1006</span>  }</div><div class="line"><a name="l01007"></a><span class="lineno"> 1007</span>  }</div><div class="line"><a name="l01008"></a><span class="lineno"> 1008</span>  <span class="comment">/* fall through */</span></div><div class="line"><a name="l01009"></a><span class="lineno"> 1009</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</a>:</div><div class="line"><a name="l01010"></a><span class="lineno"> 1010</span>  unpacked_continue:</div><div class="line"><a name="l01011"></a><span class="lineno"> 1011</span>  ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div><div class="line"><a name="l01012"></a><span class="lineno"> 1012</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l01013"></a><span class="lineno"> 1013</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="l01014"></a><span class="lineno"> 1014</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01015"></a><span class="lineno"> 1015</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="l01016"></a><span class="lineno"> 1016</span>  <a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &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="l01017"></a><span class="lineno"> 1017</span>  <span class="keywordflow">for</span> (; (tmp = *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>) != 0; <a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &tmp-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div><div class="line"><a name="l01018"></a><span class="lineno"> 1018</span>  <span class="keywordflow">if</span> (ptr == tmp) {</div><div class="line"><a name="l01019"></a><span class="lineno"> 1019</span>  tmp = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div><div class="line"><a name="l01020"></a><span class="lineno"> 1020</span>  <a class="code" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a>(table, ptr);</div><div class="line"><a name="l01021"></a><span class="lineno"> 1021</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="l01022"></a><span class="lineno"> 1022</span>  ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4054ac2ac0f2065f541246bd665c6c7d">hash</a> = 0;</div><div class="line"><a name="l01023"></a><span class="lineno"> 1023</span>  ptr = tmp;</div><div class="line"><a name="l01024"></a><span class="lineno"> 1024</span>  <span class="keywordflow">break</span>;</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>  }</div><div class="line"><a name="l01027"></a><span class="lineno"> 1027</span>  }</div><div class="line"><a name="l01028"></a><span class="lineno"> 1028</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="l01029"></a><span class="lineno"> 1029</span>  }</div><div class="line"><a name="l01030"></a><span class="lineno"> 1030</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01031"></a><span class="lineno"> 1031</span> }</div><div class="line"><a name="l01032"></a><span class="lineno"> 1032</span> </div><div class="line"><a name="l01033"></a><span class="lineno"> 1033</span> <span class="keywordtype">int</span></div><div class="line"><a name="l01034"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#accc02c609f11fe0cad4061ff19f09b9a"> 1034</a></span> <a class="code" href="../../d4/d71/st_8c.html#accc02c609f11fe0cad4061ff19f09b9a">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#a86771351f4ef469ab9c94739a64fd7ea">func</a>)(<a class="code" href="../../d8/db0/defines_8h.html#af4fd7cbafda9af704310f78516042dfb">ANYARGS</a>), <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> arg)</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>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr, **<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>, *tmp;</div><div class="line"><a name="l01037"></a><span class="lineno"> 1037</span>  <span class="keyword">enum</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1f">st_retval</a> retval;</div><div class="line"><a name="l01038"></a><span class="lineno"> 1038</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i;</div><div class="line"><a name="l01039"></a><span class="lineno"> 1039</span> </div><div class="line"><a name="l01040"></a><span class="lineno"> 1040</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="l01041"></a><span class="lineno"> 1041</span>  <span class="keywordflow">for</span> (i = 0; i < table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>; i++) {</div><div class="line"><a name="l01042"></a><span class="lineno"> 1042</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../df/d38/vm__exec_8c.html">val</a>, <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a>;</div><div class="line"><a name="l01043"></a><span class="lineno"> 1043</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l01044"></a><span class="lineno"> 1044</span>  <a class="code" href="../../df/d38/vm__exec_8c.html">val</a> = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, i);</div><div class="line"><a name="l01045"></a><span class="lineno"> 1045</span>  <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a> = <a class="code" href="../../d4/d71/st_8c.html#a51731773e02649913e2a8d91d6ca4ad1">PHASH</a>(table, i);</div><div class="line"><a name="l01046"></a><span class="lineno"> 1046</span>  retval = (*func)(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../df/d38/vm__exec_8c.html">val</a>, arg, 0);</div><div class="line"><a name="l01047"></a><span class="lineno"> 1047</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="l01048"></a><span class="lineno"> 1048</span>  <a class="code" href="../../d4/d71/st_8c.html#ade1811eeadef04915e40f72df282fa62">FIND_ENTRY</a>(table, ptr, <a class="code" href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a>, i);</div><div class="line"><a name="l01049"></a><span class="lineno"> 1049</span>  <span class="keywordflow">if</span> (!ptr) <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01050"></a><span class="lineno"> 1050</span>  <span class="keywordflow">goto</span> unpacked;</div><div class="line"><a name="l01051"></a><span class="lineno"> 1051</span>  }</div><div class="line"><a name="l01052"></a><span class="lineno"> 1052</span>  <span class="keywordflow">switch</span> (retval) {</div><div class="line"><a name="l01053"></a><span class="lineno"> 1053</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</a>:</div><div class="line"><a name="l01054"></a><span class="lineno"> 1054</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l01055"></a><span class="lineno"> 1055</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69">ST_CHECK</a>:</div><div class="line"><a name="l01056"></a><span class="lineno"> 1056</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="l01057"></a><span class="lineno"> 1057</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01058"></a><span class="lineno"> 1058</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="l01059"></a><span class="lineno"> 1059</span>  <a class="code" href="../../d4/d71/st_8c.html#a0fccb1100278656a74bdfd5d7c3f9913">remove_packed_entry</a>(table, i);</div><div class="line"><a name="l01060"></a><span class="lineno"> 1060</span>  i--;</div><div class="line"><a name="l01061"></a><span class="lineno"> 1061</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l01062"></a><span class="lineno"> 1062</span>  }</div><div class="line"><a name="l01063"></a><span class="lineno"> 1063</span>  }</div><div class="line"><a name="l01064"></a><span class="lineno"> 1064</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01065"></a><span class="lineno"> 1065</span>  }</div><div class="line"><a name="l01066"></a><span class="lineno"> 1066</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l01067"></a><span class="lineno"> 1067</span>  ptr = table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>;</div><div class="line"><a name="l01068"></a><span class="lineno"> 1068</span>  }</div><div class="line"><a name="l01069"></a><span class="lineno"> 1069</span> </div><div class="line"><a name="l01070"></a><span class="lineno"> 1070</span>  <span class="keywordflow">if</span> (ptr != 0) {</div><div class="line"><a name="l01071"></a><span class="lineno"> 1071</span>  <span class="keywordflow">do</span> {</div><div class="line"><a name="l01072"></a><span class="lineno"> 1072</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="l01073"></a><span class="lineno"> 1073</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>, arg, 0);</div><div class="line"><a name="l01074"></a><span class="lineno"> 1074</span>  unpacked:</div><div class="line"><a name="l01075"></a><span class="lineno"> 1075</span>  <span class="keywordflow">switch</span> (retval) {</div><div class="line"><a name="l01076"></a><span class="lineno"> 1076</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</a>:</div><div class="line"><a name="l01077"></a><span class="lineno"> 1077</span>  ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div><div class="line"><a name="l01078"></a><span class="lineno"> 1078</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l01079"></a><span class="lineno"> 1079</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69">ST_CHECK</a>:</div><div class="line"><a name="l01080"></a><span class="lineno"> 1080</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="l01081"></a><span class="lineno"> 1081</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01082"></a><span class="lineno"> 1082</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="l01083"></a><span class="lineno"> 1083</span>  <a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &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="l01084"></a><span class="lineno"> 1084</span>  <span class="keywordflow">for</span> (; (tmp = *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>) != 0; <a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &tmp-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div><div class="line"><a name="l01085"></a><span class="lineno"> 1085</span>  <span class="keywordflow">if</span> (ptr == tmp) {</div><div class="line"><a name="l01086"></a><span class="lineno"> 1086</span>  tmp = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>;</div><div class="line"><a name="l01087"></a><span class="lineno"> 1087</span>  *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l01088"></a><span class="lineno"> 1088</span>  <a class="code" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a>(table, ptr);</div><div class="line"><a name="l01089"></a><span class="lineno"> 1089</span>  <a class="code" href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b">st_free_entry</a>(ptr);</div><div class="line"><a name="l01090"></a><span class="lineno"> 1090</span>  ptr = tmp;</div><div class="line"><a name="l01091"></a><span class="lineno"> 1091</span>  <span class="keywordflow">break</span>;</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>  }</div><div class="line"><a name="l01094"></a><span class="lineno"> 1094</span>  }</div><div class="line"><a name="l01095"></a><span class="lineno"> 1095</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="l01096"></a><span class="lineno"> 1096</span>  }</div><div class="line"><a name="l01097"></a><span class="lineno"> 1097</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01098"></a><span class="lineno"> 1098</span> }</div><div class="line"><a name="l01099"></a><span class="lineno"> 1099</span> </div><div class="line"><a name="l01100"></a><span class="lineno"> 1100</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="l01101"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a6fa3f871a2c35f21497cbc12deceeced"> 1101</a></span> <a class="code" href="../../d4/d71/st_8c.html#a6fa3f871a2c35f21497cbc12deceeced">get_keys</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *keys, <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>, <span class="keywordtype">int</span> check, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> never)</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>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>;</div><div class="line"><a name="l01104"></a><span class="lineno"> 1104</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *keys_start = keys;</div><div class="line"><a name="l01105"></a><span class="lineno"> 1105</span> </div><div class="line"><a name="l01106"></a><span class="lineno"> 1106</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="l01107"></a><span class="lineno"> 1107</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i;</div><div class="line"><a name="l01108"></a><span class="lineno"> 1108</span> </div><div class="line"><a name="l01109"></a><span class="lineno"> 1109</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a> > table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>) <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a> = table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>;</div><div class="line"><a name="l01110"></a><span class="lineno"> 1110</span>  <span class="keywordflow">for</span> (i = 0; i < <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>; i++) {</div><div class="line"><a name="l01111"></a><span class="lineno"> 1111</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l01112"></a><span class="lineno"> 1112</span>  <span class="keywordflow">if</span> (check && <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> == never) <span class="keywordflow">continue</span>;</div><div class="line"><a name="l01113"></a><span class="lineno"> 1113</span>  *keys++ = <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>;</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>  }</div><div class="line"><a name="l01116"></a><span class="lineno"> 1116</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l01117"></a><span class="lineno"> 1117</span>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr = table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>;</div><div class="line"><a name="l01118"></a><span class="lineno"> 1118</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *keys_end = keys + <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>;</div><div class="line"><a name="l01119"></a><span class="lineno"> 1119</span>  <span class="keywordflow">for</span> (; ptr && keys < keys_end; ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>) {</div><div class="line"><a name="l01120"></a><span class="lineno"> 1120</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div><div class="line"><a name="l01121"></a><span class="lineno"> 1121</span>  <span class="keywordflow">if</span> (check && <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> == never) <span class="keywordflow">continue</span>;</div><div class="line"><a name="l01122"></a><span class="lineno"> 1122</span>  *keys++ = <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>;</div><div class="line"><a name="l01123"></a><span class="lineno"> 1123</span>  }</div><div class="line"><a name="l01124"></a><span class="lineno"> 1124</span>  }</div><div class="line"><a name="l01125"></a><span class="lineno"> 1125</span> </div><div class="line"><a name="l01126"></a><span class="lineno"> 1126</span>  <span class="keywordflow">return</span> keys - keys_start;</div><div class="line"><a name="l01127"></a><span class="lineno"> 1127</span> }</div><div class="line"><a name="l01128"></a><span class="lineno"> 1128</span> </div><div class="line"><a name="l01129"></a><span class="lineno"> 1129</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01130"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a966180fce1e2e11911a57c9abae6a39b"> 1130</a></span> <a class="code" href="../../d4/d71/st_8c.html#a966180fce1e2e11911a57c9abae6a39b">st_keys</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *keys, <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="l01131"></a><span class="lineno"> 1131</span> {</div><div class="line"><a name="l01132"></a><span class="lineno"> 1132</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a6fa3f871a2c35f21497cbc12deceeced">get_keys</a>(table, keys, <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>, 0, 0);</div><div class="line"><a name="l01133"></a><span class="lineno"> 1133</span> }</div><div class="line"><a name="l01134"></a><span class="lineno"> 1134</span> </div><div class="line"><a name="l01135"></a><span class="lineno"> 1135</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"><a class="line" href="../../d4/d71/st_8c.html#ac88dda6f84d1db8c5654cade389c0f78"> 1136</a></span> <a class="code" href="../../d4/d71/st_8c.html#ac88dda6f84d1db8c5654cade389c0f78">st_keys_check</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *keys, <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>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> never)</div><div class="line"><a name="l01137"></a><span class="lineno"> 1137</span> {</div><div class="line"><a name="l01138"></a><span class="lineno"> 1138</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a6fa3f871a2c35f21497cbc12deceeced">get_keys</a>(table, keys, <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>, 1, never);</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> </div><div class="line"><a name="l01141"></a><span class="lineno"> 1141</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="l01142"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a144e9d9892980a6c762d7d19b55536e6"> 1142</a></span> <a class="code" href="../../d4/d71/st_8c.html#a144e9d9892980a6c762d7d19b55536e6">get_values</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *values, <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>, <span class="keywordtype">int</span> check, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> never)</div><div class="line"><a name="l01143"></a><span class="lineno"> 1143</span> {</div><div class="line"><a name="l01144"></a><span class="lineno"> 1144</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>;</div><div class="line"><a name="l01145"></a><span class="lineno"> 1145</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *values_start = values;</div><div class="line"><a name="l01146"></a><span class="lineno"> 1146</span> </div><div class="line"><a name="l01147"></a><span class="lineno"> 1147</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="l01148"></a><span class="lineno"> 1148</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> i;</div><div class="line"><a name="l01149"></a><span class="lineno"> 1149</span> </div><div class="line"><a name="l01150"></a><span class="lineno"> 1150</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a> > table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>) <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a> = table-><a class="code" href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">real_entries</a>;</div><div class="line"><a name="l01151"></a><span class="lineno"> 1151</span>  <span class="keywordflow">for</span> (i = 0; i < <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>; i++) {</div><div class="line"><a name="l01152"></a><span class="lineno"> 1152</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l01153"></a><span class="lineno"> 1153</span>  <span class="keywordflow">if</span> (check && <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> == never) <span class="keywordflow">continue</span>;</div><div class="line"><a name="l01154"></a><span class="lineno"> 1154</span>  *values++ = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, i);</div><div class="line"><a name="l01155"></a><span class="lineno"> 1155</span>  }</div><div class="line"><a name="l01156"></a><span class="lineno"> 1156</span>  }</div><div class="line"><a name="l01157"></a><span class="lineno"> 1157</span>  <span class="keywordflow">else</span> {</div><div class="line"><a name="l01158"></a><span class="lineno"> 1158</span>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr = table-><a class="code" href="../../d0/ddd/structst__table.html#aedc787fe0df08aff2d4079255a246878">head</a>;</div><div class="line"><a name="l01159"></a><span class="lineno"> 1159</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *values_end = values + <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>;</div><div class="line"><a name="l01160"></a><span class="lineno"> 1160</span>  <span class="keywordflow">for</span> (; ptr && values < values_end; ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a4f0048fd99145b5a1558da33c145ead3">fore</a>) {</div><div class="line"><a name="l01161"></a><span class="lineno"> 1161</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a7c3f404248d6b3ed3235c49425c2b899">key</a>;</div><div class="line"><a name="l01162"></a><span class="lineno"> 1162</span>  <span class="keywordflow">if</span> (check && <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> == never) <span class="keywordflow">continue</span>;</div><div class="line"><a name="l01163"></a><span class="lineno"> 1163</span>  *values++ = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a78379c2ee6cf57370697a50ff7971b17">record</a>;</div><div class="line"><a name="l01164"></a><span class="lineno"> 1164</span>  }</div><div class="line"><a name="l01165"></a><span class="lineno"> 1165</span>  }</div><div class="line"><a name="l01166"></a><span class="lineno"> 1166</span> </div><div class="line"><a name="l01167"></a><span class="lineno"> 1167</span>  <span class="keywordflow">return</span> values - values_start;</div><div class="line"><a name="l01168"></a><span class="lineno"> 1168</span> }</div><div class="line"><a name="l01169"></a><span class="lineno"> 1169</span> </div><div class="line"><a name="l01170"></a><span class="lineno"> 1170</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01171"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ac467af858b7f771bed79544c1c710a65"> 1171</a></span> <a class="code" href="../../d4/d71/st_8c.html#ac467af858b7f771bed79544c1c710a65">st_values</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *values, <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="l01172"></a><span class="lineno"> 1172</span> {</div><div class="line"><a name="l01173"></a><span class="lineno"> 1173</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a144e9d9892980a6c762d7d19b55536e6">get_values</a>(table, values, <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>, 0, 0);</div><div class="line"><a name="l01174"></a><span class="lineno"> 1174</span> }</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> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01177"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a31a34db9e9147ea35102754a6509f2bd"> 1177</a></span> <a class="code" href="../../d4/d71/st_8c.html#a31a34db9e9147ea35102754a6509f2bd">st_values_check</a>(<a class="code" href="../../d0/ddd/structst__table.html">st_table</a> *table, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> *values, <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>, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> never)</div><div class="line"><a name="l01178"></a><span class="lineno"> 1178</span> {</div><div class="line"><a name="l01179"></a><span class="lineno"> 1179</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.html#a144e9d9892980a6c762d7d19b55536e6">get_values</a>(table, values, <a class="code" href="../../d5/db5/encoding_8c.html#a439227feff9d7f55384e8780cfc2eb82">size</a>, 1, never);</div><div class="line"><a name="l01180"></a><span class="lineno"> 1180</span> }</div><div class="line"><a name="l01181"></a><span class="lineno"> 1181</span> </div><div class="line"><a name="l01182"></a><span class="lineno"> 1182</span> <span class="preprocessor">#if 0 </span><span class="comment">/* unused right now */</span><span class="preprocessor"></span></div><div class="line"><a name="l01183"></a><span class="lineno"> 1183</span> <span class="keywordtype">int</span></div><div class="line"><a name="l01184"></a><span class="lineno"> 1184</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#a86771351f4ef469ab9c94739a64fd7ea">func</a>)(<a class="code" href="../../d8/db0/defines_8h.html#af4fd7cbafda9af704310f78516042dfb">ANYARGS</a>), <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> arg)</div><div class="line"><a name="l01185"></a><span class="lineno"> 1185</span> {</div><div class="line"><a name="l01186"></a><span class="lineno"> 1186</span>  <a class="code" href="../../df/dfb/structst__table__entry.html">st_table_entry</a> *ptr, **<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>, *tmp;</div><div class="line"><a name="l01187"></a><span class="lineno"> 1187</span>  <span class="keyword">enum</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1f">st_retval</a> retval;</div><div class="line"><a name="l01188"></a><span class="lineno"> 1188</span>  <span class="keywordtype">int</span> i;</div><div class="line"><a name="l01189"></a><span class="lineno"> 1189</span> </div><div class="line"><a name="l01190"></a><span class="lineno"> 1190</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="l01191"></a><span class="lineno"> 1191</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="l01192"></a><span class="lineno"> 1192</span>  <span class="keywordtype">int</span> j;</div><div class="line"><a name="l01193"></a><span class="lineno"> 1193</span>  <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../df/d38/vm__exec_8c.html">val</a>;</div><div class="line"><a name="l01194"></a><span class="lineno"> 1194</span>  <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a> = <a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, i);</div><div class="line"><a name="l01195"></a><span class="lineno"> 1195</span>  <a class="code" href="../../df/d38/vm__exec_8c.html">val</a> = <a class="code" href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a>(table, i);</div><div class="line"><a name="l01196"></a><span class="lineno"> 1196</span>  retval = (*func)(<a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>, <a class="code" href="../../df/d38/vm__exec_8c.html">val</a>, arg, 0);</div><div class="line"><a name="l01197"></a><span class="lineno"> 1197</span>  <span class="keywordflow">switch</span> (retval) {</div><div class="line"><a name="l01198"></a><span class="lineno"> 1198</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69">ST_CHECK</a>: <span class="comment">/* check if hash is modified during iteration */</span></div><div class="line"><a name="l01199"></a><span class="lineno"> 1199</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="l01200"></a><span class="lineno"> 1200</span>  <span class="keywordflow">if</span> (<a class="code" href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a>(table, j) == <a class="code" href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a>)</div><div class="line"><a name="l01201"></a><span class="lineno"> 1201</span>  <span class="keywordflow">break</span>;</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">if</span> (j == table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>) {</div><div class="line"><a name="l01204"></a><span class="lineno"> 1204</span>  <span class="comment">/* call func with error notice */</span></div><div class="line"><a name="l01205"></a><span class="lineno"> 1205</span>  retval = (*func)(0, 0, arg, 1);</div><div class="line"><a name="l01206"></a><span class="lineno"> 1206</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l01207"></a><span class="lineno"> 1207</span>  }</div><div class="line"><a name="l01208"></a><span class="lineno"> 1208</span>  <span class="comment">/* fall through */</span></div><div class="line"><a name="l01209"></a><span class="lineno"> 1209</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</a>:</div><div class="line"><a name="l01210"></a><span class="lineno"> 1210</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l01211"></a><span class="lineno"> 1211</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="l01212"></a><span class="lineno"> 1212</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01213"></a><span class="lineno"> 1213</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="l01214"></a><span class="lineno"> 1214</span>  <a class="code" href="../../d4/d71/st_8c.html#a0fccb1100278656a74bdfd5d7c3f9913">remove_packed_entry</a>(table, i);</div><div class="line"><a name="l01215"></a><span class="lineno"> 1215</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l01216"></a><span class="lineno"> 1216</span>  }</div><div class="line"><a name="l01217"></a><span class="lineno"> 1217</span>  }</div><div class="line"><a name="l01218"></a><span class="lineno"> 1218</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01219"></a><span class="lineno"> 1219</span>  }</div><div class="line"><a name="l01220"></a><span class="lineno"> 1220</span> </div><div class="line"><a name="l01221"></a><span class="lineno"> 1221</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="l01222"></a><span class="lineno"> 1222</span>  ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div><div class="line"><a name="l01223"></a><span class="lineno"> 1223</span>  <span class="keywordflow">do</span> {</div><div class="line"><a name="l01224"></a><span class="lineno"> 1224</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>, arg, 0);</div><div class="line"><a name="l01225"></a><span class="lineno"> 1225</span>  <span class="keywordflow">switch</span> (retval) {</div><div class="line"><a name="l01226"></a><span class="lineno"> 1226</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69">ST_CHECK</a>: <span class="comment">/* check if hash is modified during iteration */</span></div><div class="line"><a name="l01227"></a><span class="lineno"> 1227</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="l01228"></a><span class="lineno"> 1228</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="l01229"></a><span class="lineno"> 1229</span>  <span class="keywordflow">if</span> (!tmp) {</div><div class="line"><a name="l01230"></a><span class="lineno"> 1230</span>  <span class="comment">/* call func with error notice */</span></div><div class="line"><a name="l01231"></a><span class="lineno"> 1231</span>  retval = (*func)(0, 0, arg, 1);</div><div class="line"><a name="l01232"></a><span class="lineno"> 1232</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l01233"></a><span class="lineno"> 1233</span>  }</div><div class="line"><a name="l01234"></a><span class="lineno"> 1234</span>  }</div><div class="line"><a name="l01235"></a><span class="lineno"> 1235</span>  <span class="comment">/* fall through */</span></div><div class="line"><a name="l01236"></a><span class="lineno"> 1236</span>  <span class="keywordflow">case</span> <a class="code" href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</a>:</div><div class="line"><a name="l01237"></a><span class="lineno"> 1237</span>  ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div><div class="line"><a name="l01238"></a><span class="lineno"> 1238</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l01239"></a><span class="lineno"> 1239</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="l01240"></a><span class="lineno"> 1240</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01241"></a><span class="lineno"> 1241</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="l01242"></a><span class="lineno"> 1242</span>  <a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &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="l01243"></a><span class="lineno"> 1243</span>  <span class="keywordflow">for</span> (; (tmp = *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a>) != 0; <a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = &tmp-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>) {</div><div class="line"><a name="l01244"></a><span class="lineno"> 1244</span>  <span class="keywordflow">if</span> (ptr == tmp) {</div><div class="line"><a name="l01245"></a><span class="lineno"> 1245</span>  tmp = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a2cd684cc9d44752fa7de8946e10e0c13">back</a>;</div><div class="line"><a name="l01246"></a><span class="lineno"> 1246</span>  *<a class="code" href="../../d6/da0/nkf-utf8_2nkf_8c.html#ab0b853bc4e4e9658036bf7e604f398ad">last</a> = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l01247"></a><span class="lineno"> 1247</span>  <a class="code" href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a>(table, ptr);</div><div class="line"><a name="l01248"></a><span class="lineno"> 1248</span>  <a class="code" href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b">st_free_entry</a>(ptr);</div><div class="line"><a name="l01249"></a><span class="lineno"> 1249</span>  ptr = tmp;</div><div class="line"><a name="l01250"></a><span class="lineno"> 1250</span>  <span class="keywordflow">break</span>;</div><div class="line"><a name="l01251"></a><span class="lineno"> 1251</span>  }</div><div class="line"><a name="l01252"></a><span class="lineno"> 1252</span>  }</div><div class="line"><a name="l01253"></a><span class="lineno"> 1253</span>  ptr = ptr-><a class="code" href="../../df/dfb/structst__table__entry.html#a8c7fef89f13d76633cd71d595d39181d">next</a>;</div><div class="line"><a name="l01254"></a><span class="lineno"> 1254</span>  <a class="code" href="../../d4/d71/st_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a>(tmp);</div><div class="line"><a name="l01255"></a><span class="lineno"> 1255</span>  table-><a class="code" href="../../d0/ddd/structst__table.html#aa593a5229fc7d02d628a4518f56f71b6">num_entries</a>--;</div><div class="line"><a name="l01256"></a><span class="lineno"> 1256</span>  }</div><div class="line"><a name="l01257"></a><span class="lineno"> 1257</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="l01258"></a><span class="lineno"> 1258</span>  }</div><div class="line"><a name="l01259"></a><span class="lineno"> 1259</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01260"></a><span class="lineno"> 1260</span> }</div><div class="line"><a name="l01261"></a><span class="lineno"> 1261</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01262"></a><span class="lineno"> 1262</span> </div><div class="line"><a name="l01263"></a><span class="lineno"> 1263</span> <span class="comment">/*</span></div><div class="line"><a name="l01264"></a><span class="lineno"> 1264</span> <span class="comment"> * hash_32 - 32 bit Fowler/Noll/Vo FNV-1a hash code</span></div><div class="line"><a name="l01265"></a><span class="lineno"> 1265</span> <span class="comment"> *</span></div><div class="line"><a name="l01266"></a><span class="lineno"> 1266</span> <span class="comment"> * @(#) $Hash32: Revision: 1.1 $</span></div><div class="line"><a name="l01267"></a><span class="lineno"> 1267</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="l01268"></a><span class="lineno"> 1268</span> <span class="comment"> * @(#) $Hash32: Source: /usr/local/src/cmd/fnv/RCS/hash_32a.c,v $</span></div><div class="line"><a name="l01269"></a><span class="lineno"> 1269</span> <span class="comment"> *</span></div><div class="line"><a name="l01270"></a><span class="lineno"> 1270</span> <span class="comment"> ***</span></div><div class="line"><a name="l01271"></a><span class="lineno"> 1271</span> <span class="comment"> *</span></div><div class="line"><a name="l01272"></a><span class="lineno"> 1272</span> <span class="comment"> * Fowler/Noll/Vo hash</span></div><div class="line"><a name="l01273"></a><span class="lineno"> 1273</span> <span class="comment"> *</span></div><div class="line"><a name="l01274"></a><span class="lineno"> 1274</span> <span class="comment"> * The basis of this hash algorithm was taken from an idea sent</span></div><div class="line"><a name="l01275"></a><span class="lineno"> 1275</span> <span class="comment"> * as reviewer comments to the IEEE POSIX P1003.2 committee by:</span></div><div class="line"><a name="l01276"></a><span class="lineno"> 1276</span> <span class="comment"> *</span></div><div class="line"><a name="l01277"></a><span class="lineno"> 1277</span> <span class="comment"> * Phong Vo (http://www.research.att.com/info/kpv/)</span></div><div class="line"><a name="l01278"></a><span class="lineno"> 1278</span> <span class="comment"> * Glenn Fowler (http://www.research.att.com/~gsf/)</span></div><div class="line"><a name="l01279"></a><span class="lineno"> 1279</span> <span class="comment"> *</span></div><div class="line"><a name="l01280"></a><span class="lineno"> 1280</span> <span class="comment"> * In a subsequent ballot round:</span></div><div class="line"><a name="l01281"></a><span class="lineno"> 1281</span> <span class="comment"> *</span></div><div class="line"><a name="l01282"></a><span class="lineno"> 1282</span> <span class="comment"> * Landon Curt Noll (http://www.isthe.com/chongo/)</span></div><div class="line"><a name="l01283"></a><span class="lineno"> 1283</span> <span class="comment"> *</span></div><div class="line"><a name="l01284"></a><span class="lineno"> 1284</span> <span class="comment"> * improved on their algorithm. Some people tried this hash</span></div><div class="line"><a name="l01285"></a><span class="lineno"> 1285</span> <span class="comment"> * and found that it worked rather well. In an EMail message</span></div><div class="line"><a name="l01286"></a><span class="lineno"> 1286</span> <span class="comment"> * to Landon, they named it the ``Fowler/Noll/Vo'' or FNV hash.</span></div><div class="line"><a name="l01287"></a><span class="lineno"> 1287</span> <span class="comment"> *</span></div><div class="line"><a name="l01288"></a><span class="lineno"> 1288</span> <span class="comment"> * FNV hashes are designed to be fast while maintaining a low</span></div><div class="line"><a name="l01289"></a><span class="lineno"> 1289</span> <span class="comment"> * collision rate. The FNV speed allows one to quickly hash lots</span></div><div class="line"><a name="l01290"></a><span class="lineno"> 1290</span> <span class="comment"> * of data while maintaining a reasonable collision rate. See:</span></div><div class="line"><a name="l01291"></a><span class="lineno"> 1291</span> <span class="comment"> *</span></div><div class="line"><a name="l01292"></a><span class="lineno"> 1292</span> <span class="comment"> * http://www.isthe.com/chongo/tech/comp/fnv/index.html</span></div><div class="line"><a name="l01293"></a><span class="lineno"> 1293</span> <span class="comment"> *</span></div><div class="line"><a name="l01294"></a><span class="lineno"> 1294</span> <span class="comment"> * for more details as well as other forms of the FNV hash.</span></div><div class="line"><a name="l01295"></a><span class="lineno"> 1295</span> <span class="comment"> ***</span></div><div class="line"><a name="l01296"></a><span class="lineno"> 1296</span> <span class="comment"> *</span></div><div class="line"><a name="l01297"></a><span class="lineno"> 1297</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="l01298"></a><span class="lineno"> 1298</span> <span class="comment"> * Fnv32_t hashval argument to fnv_32a_buf() or fnv_32a_str().</span></div><div class="line"><a name="l01299"></a><span class="lineno"> 1299</span> <span class="comment"> *</span></div><div class="line"><a name="l01300"></a><span class="lineno"> 1300</span> <span class="comment"> ***</span></div><div class="line"><a name="l01301"></a><span class="lineno"> 1301</span> <span class="comment"> *</span></div><div class="line"><a name="l01302"></a><span class="lineno"> 1302</span> <span class="comment"> * Please do not copyright this code. This code is in the public domain.</span></div><div class="line"><a name="l01303"></a><span class="lineno"> 1303</span> <span class="comment"> *</span></div><div class="line"><a name="l01304"></a><span class="lineno"> 1304</span> <span class="comment"> * LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,</span></div><div class="line"><a name="l01305"></a><span class="lineno"> 1305</span> <span class="comment"> * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO</span></div><div class="line"><a name="l01306"></a><span class="lineno"> 1306</span> <span class="comment"> * EVENT SHALL LANDON CURT NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR</span></div><div class="line"><a name="l01307"></a><span class="lineno"> 1307</span> <span class="comment"> * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF</span></div><div class="line"><a name="l01308"></a><span class="lineno"> 1308</span> <span class="comment"> * USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR</span></div><div class="line"><a name="l01309"></a><span class="lineno"> 1309</span> <span class="comment"> * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR</span></div><div class="line"><a name="l01310"></a><span class="lineno"> 1310</span> <span class="comment"> * PERFORMANCE OF THIS SOFTWARE.</span></div><div class="line"><a name="l01311"></a><span class="lineno"> 1311</span> <span class="comment"> *</span></div><div class="line"><a name="l01312"></a><span class="lineno"> 1312</span> <span class="comment"> * By:</span></div><div class="line"><a name="l01313"></a><span class="lineno"> 1313</span> <span class="comment"> * chongo <Landon Curt Noll> /\oo/\</span></div><div class="line"><a name="l01314"></a><span class="lineno"> 1314</span> <span class="comment"> * http://www.isthe.com/chongo/</span></div><div class="line"><a name="l01315"></a><span class="lineno"> 1315</span> <span class="comment"> *</span></div><div class="line"><a name="l01316"></a><span class="lineno"> 1316</span> <span class="comment"> * Share and Enjoy! :-)</span></div><div class="line"><a name="l01317"></a><span class="lineno"> 1317</span> <span class="comment"> */</span></div><div class="line"><a name="l01318"></a><span class="lineno"> 1318</span> </div><div class="line"><a name="l01319"></a><span class="lineno"> 1319</span> <span class="comment">/*</span></div><div class="line"><a name="l01320"></a><span class="lineno"> 1320</span> <span class="comment"> * 32 bit FNV-1 and FNV-1a non-zero initial basis</span></div><div class="line"><a name="l01321"></a><span class="lineno"> 1321</span> <span class="comment"> *</span></div><div class="line"><a name="l01322"></a><span class="lineno"> 1322</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="l01323"></a><span class="lineno"> 1323</span> <span class="comment"> *</span></div><div class="line"><a name="l01324"></a><span class="lineno"> 1324</span> <span class="comment"> * chongo <Landon Curt Noll> /\../\</span></div><div class="line"><a name="l01325"></a><span class="lineno"> 1325</span> <span class="comment"> *</span></div><div class="line"><a name="l01326"></a><span class="lineno"> 1326</span> <span class="comment"> * NOTE: The \'s above are not back-slashing escape characters.</span></div><div class="line"><a name="l01327"></a><span class="lineno"> 1327</span> <span class="comment"> * They are literal ASCII backslash 0x5c characters.</span></div><div class="line"><a name="l01328"></a><span class="lineno"> 1328</span> <span class="comment"> *</span></div><div class="line"><a name="l01329"></a><span class="lineno"> 1329</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="l01330"></a><span class="lineno"> 1330</span> <span class="comment"> */</span></div><div class="line"><a name="l01331"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a40a142ccb9ca21d50ea9f6ed8589cc96"> 1331</a></span> <span class="preprocessor">#define FNV1_32A_INIT 0x811c9dc5</span></div><div class="line"><a name="l01332"></a><span class="lineno"> 1332</span> </div><div class="line"><a name="l01333"></a><span class="lineno"> 1333</span> <span class="comment">/*</span></div><div class="line"><a name="l01334"></a><span class="lineno"> 1334</span> <span class="comment"> * 32 bit magic FNV-1a prime</span></div><div class="line"><a name="l01335"></a><span class="lineno"> 1335</span> <span class="comment"> */</span></div><div class="line"><a name="l01336"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ae13a6565bea334e9b6fb19033a392857"> 1336</a></span> <span class="preprocessor">#define FNV_32_PRIME 0x01000193</span></div><div class="line"><a name="l01337"></a><span class="lineno"> 1337</span> </div><div class="line"><a name="l01338"></a><span class="lineno"> 1338</span> <span class="preprocessor">#ifdef ST_USE_FNV1</span></div><div class="line"><a name="l01339"></a><span class="lineno"> 1339</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="l01340"></a><span class="lineno"> 1340</span> <a class="code" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7">strhash</a>(<a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> arg)</div><div class="line"><a name="l01341"></a><span class="lineno"> 1341</span> {</div><div class="line"><a name="l01342"></a><span class="lineno"> 1342</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="l01343"></a><span class="lineno"> 1343</span>  <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hval = <a class="code" href="../../d4/d71/st_8c.html#a40a142ccb9ca21d50ea9f6ed8589cc96">FNV1_32A_INIT</a>;</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="comment">/*</span></div><div class="line"><a name="l01346"></a><span class="lineno"> 1346</span> <span class="comment"> * FNV-1a hash each octet in the buffer</span></div><div class="line"><a name="l01347"></a><span class="lineno"> 1347</span> <span class="comment"> */</span></div><div class="line"><a name="l01348"></a><span class="lineno"> 1348</span>  <span class="keywordflow">while</span> (*<span class="keywordtype">string</span>) {</div><div class="line"><a name="l01349"></a><span class="lineno"> 1349</span>  <span class="comment">/* xor the bottom with the current octet */</span></div><div class="line"><a name="l01350"></a><span class="lineno"> 1350</span>  hval ^= (<span class="keywordtype">unsigned</span> int)*<span class="keywordtype">string</span>++;</div><div class="line"><a name="l01351"></a><span class="lineno"> 1351</span> </div><div class="line"><a name="l01352"></a><span class="lineno"> 1352</span>  <span class="comment">/* multiply by the 32 bit FNV magic prime mod 2^32 */</span></div><div class="line"><a name="l01353"></a><span class="lineno"> 1353</span>  hval *= <a class="code" href="../../d4/d71/st_8c.html#ae13a6565bea334e9b6fb19033a392857">FNV_32_PRIME</a>;</div><div class="line"><a name="l01354"></a><span class="lineno"> 1354</span>  }</div><div class="line"><a name="l01355"></a><span class="lineno"> 1355</span>  <span class="keywordflow">return</span> hval;</div><div class="line"><a name="l01356"></a><span class="lineno"> 1356</span> }</div><div class="line"><a name="l01357"></a><span class="lineno"> 1357</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01358"></a><span class="lineno"> 1358</span> </div><div class="line"><a name="l01359"></a><span class="lineno"> 1359</span> <span class="preprocessor">#ifndef UNALIGNED_WORD_ACCESS</span></div><div class="line"><a name="l01360"></a><span class="lineno"> 1360</span> <span class="preprocessor"># if defined(__i386) || defined(__i386__) || defined(_M_IX86) || \</span></div><div class="line"><a name="l01361"></a><span class="lineno"> 1361</span> <span class="preprocessor"> defined(__x86_64) || defined(__x86_64__) || defined(_M_AMD64) || \</span></div><div class="line"><a name="l01362"></a><span class="lineno"> 1362</span> <span class="preprocessor"> defined(__mc68020__)</span></div><div class="line"><a name="l01363"></a><span class="lineno"> 1363</span> <span class="preprocessor"># define UNALIGNED_WORD_ACCESS 1</span></div><div class="line"><a name="l01364"></a><span class="lineno"> 1364</span> <span class="preprocessor"># endif</span></div><div class="line"><a name="l01365"></a><span class="lineno"> 1365</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01366"></a><span class="lineno"> 1366</span> <span class="preprocessor">#ifndef UNALIGNED_WORD_ACCESS</span></div><div class="line"><a name="l01367"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a0383aadd3cd4f433220552852e96568e"> 1367</a></span> <span class="preprocessor"># define UNALIGNED_WORD_ACCESS 0</span></div><div class="line"><a name="l01368"></a><span class="lineno"> 1368</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01369"></a><span class="lineno"> 1369</span> </div><div class="line"><a name="l01370"></a><span class="lineno"> 1370</span> <span class="comment">/* MurmurHash described in http://murmurhash.googlepages.com/ */</span></div><div class="line"><a name="l01371"></a><span class="lineno"> 1371</span> <span class="preprocessor">#ifndef MURMUR</span></div><div class="line"><a name="l01372"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aa92335ab2ca6139b94c65caee53d1627"> 1372</a></span> <span class="preprocessor">#define MURMUR 2</span></div><div class="line"><a name="l01373"></a><span class="lineno"> 1373</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01374"></a><span class="lineno"> 1374</span> </div><div class="line"><a name="l01375"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a923df315411e52498828f7cde38e5c87"> 1375</a></span> <span class="preprocessor">#define MurmurMagic_1 (st_index_t)0xc6a4a793</span></div><div class="line"><a name="l01376"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a99b9e759614d31ea6adc4b777aedd30e"> 1376</a></span> <span class="preprocessor">#define MurmurMagic_2 (st_index_t)0x5bd1e995</span></div><div class="line"><a name="l01377"></a><span class="lineno"> 1377</span> <span class="preprocessor">#if MURMUR == 1</span></div><div class="line"><a name="l01378"></a><span class="lineno"> 1378</span> <span class="preprocessor">#define MurmurMagic MurmurMagic_1</span></div><div class="line"><a name="l01379"></a><span class="lineno"> 1379</span> <span class="preprocessor">#elif MURMUR == 2</span></div><div class="line"><a name="l01380"></a><span class="lineno"> 1380</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T > 4</span></div><div class="line"><a name="l01381"></a><span class="lineno"> 1381</span> <span class="preprocessor">#define MurmurMagic ((MurmurMagic_1 << 32) | MurmurMagic_2)</span></div><div class="line"><a name="l01382"></a><span class="lineno"> 1382</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01383"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd"> 1383</a></span> <span class="preprocessor">#define MurmurMagic MurmurMagic_2</span></div><div class="line"><a name="l01384"></a><span class="lineno"> 1384</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01385"></a><span class="lineno"> 1385</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01386"></a><span class="lineno"> 1386</span> </div><div class="line"><a name="l01387"></a><span class="lineno"> 1387</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="l01388"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a6f8bc2a6eef7714715e56451ed32521c"> 1388</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> r)</div><div class="line"><a name="l01389"></a><span class="lineno"> 1389</span> {</div><div class="line"><a name="l01390"></a><span class="lineno"> 1390</span>  <span class="keyword">const</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> m = <a class="code" href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd">MurmurMagic</a>;</div><div class="line"><a name="l01391"></a><span class="lineno"> 1391</span> <span class="preprocessor">#if MURMUR == 1</span></div><div class="line"><a name="l01392"></a><span class="lineno"> 1392</span>  h += k;</div><div class="line"><a name="l01393"></a><span class="lineno"> 1393</span>  h *= m;</div><div class="line"><a name="l01394"></a><span class="lineno"> 1394</span>  h ^= h >> r;</div><div class="line"><a name="l01395"></a><span class="lineno"> 1395</span> <span class="preprocessor">#elif MURMUR == 2</span></div><div class="line"><a name="l01396"></a><span class="lineno"> 1396</span>  k *= m;</div><div class="line"><a name="l01397"></a><span class="lineno"> 1397</span>  k ^= k >> r;</div><div class="line"><a name="l01398"></a><span class="lineno"> 1398</span>  k *= m;</div><div class="line"><a name="l01399"></a><span class="lineno"> 1399</span> </div><div class="line"><a name="l01400"></a><span class="lineno"> 1400</span>  h *= m;</div><div class="line"><a name="l01401"></a><span class="lineno"> 1401</span>  h ^= k;</div><div class="line"><a name="l01402"></a><span class="lineno"> 1402</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01403"></a><span class="lineno"> 1403</span>  <span class="keywordflow">return</span> h;</div><div class="line"><a name="l01404"></a><span class="lineno"> 1404</span> }</div><div class="line"><a name="l01405"></a><span class="lineno"> 1405</span> </div><div class="line"><a name="l01406"></a><span class="lineno"> 1406</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="l01407"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a7319d13cc614204b9b40b6c022d5f911"> 1407</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="l01408"></a><span class="lineno"> 1408</span> {</div><div class="line"><a name="l01409"></a><span class="lineno"> 1409</span> <span class="preprocessor">#if MURMUR == 1</span></div><div class="line"><a name="l01410"></a><span class="lineno"> 1410</span>  h = <a class="code" href="../../d4/d71/st_8c.html#a6f8bc2a6eef7714715e56451ed32521c">murmur</a>(h, 0, 10);</div><div class="line"><a name="l01411"></a><span class="lineno"> 1411</span>  h = <a class="code" href="../../d4/d71/st_8c.html#a6f8bc2a6eef7714715e56451ed32521c">murmur</a>(h, 0, 17);</div><div class="line"><a name="l01412"></a><span class="lineno"> 1412</span> <span class="preprocessor">#elif MURMUR == 2</span></div><div class="line"><a name="l01413"></a><span class="lineno"> 1413</span>  h ^= h >> 13;</div><div class="line"><a name="l01414"></a><span class="lineno"> 1414</span>  h *= <a class="code" href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd">MurmurMagic</a>;</div><div class="line"><a name="l01415"></a><span class="lineno"> 1415</span>  h ^= h >> 15;</div><div class="line"><a name="l01416"></a><span class="lineno"> 1416</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01417"></a><span class="lineno"> 1417</span>  <span class="keywordflow">return</span> h;</div><div class="line"><a name="l01418"></a><span class="lineno"> 1418</span> }</div><div class="line"><a name="l01419"></a><span class="lineno"> 1419</span> </div><div class="line"><a name="l01420"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538"> 1420</a></span> <span class="preprocessor">#define murmur_step(h, k) murmur((h), (k), 16)</span></div><div class="line"><a name="l01421"></a><span class="lineno"> 1421</span> </div><div class="line"><a name="l01422"></a><span class="lineno"> 1422</span> <span class="preprocessor">#if MURMUR == 1</span></div><div class="line"><a name="l01423"></a><span class="lineno"> 1423</span> <span class="preprocessor">#define murmur1(h) murmur_step((h), 16)</span></div><div class="line"><a name="l01424"></a><span class="lineno"> 1424</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01425"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528"> 1425</a></span> <span class="preprocessor">#define murmur1(h) murmur_step((h), 24)</span></div><div class="line"><a name="l01426"></a><span class="lineno"> 1426</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01427"></a><span class="lineno"> 1427</span> </div><div class="line"><a name="l01428"></a><span class="lineno"> 1428</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01429"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a970b36e65b43e8fcccbea3e3397aeefa"> 1429</a></span> <a class="code" href="../../d4/d71/st_8c.html#a970b36e65b43e8fcccbea3e3397aeefa">st_hash</a>(<span class="keyword">const</span> <span class="keywordtype">void</span> *ptr, <span class="keywordtype">size_t</span> len, <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> h)</div><div class="line"><a name="l01430"></a><span class="lineno"> 1430</span> {</div><div class="line"><a name="l01431"></a><span class="lineno"> 1431</span>  <span class="keyword">const</span> <span class="keywordtype">char</span> *data = ptr;</div><div class="line"><a name="l01432"></a><span class="lineno"> 1432</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> = 0;</div><div class="line"><a name="l01433"></a><span class="lineno"> 1433</span> </div><div class="line"><a name="l01434"></a><span class="lineno"> 1434</span>  h += 0xdeadbeef;</div><div class="line"><a name="l01435"></a><span class="lineno"> 1435</span> </div><div class="line"><a name="l01436"></a><span class="lineno"> 1436</span> <span class="preprocessor">#define data_at(n) (st_index_t)((unsigned char)data[(n)])</span></div><div class="line"><a name="l01437"></a><span class="lineno"> 1437</span> <span class="preprocessor">#define UNALIGNED_ADD_4 UNALIGNED_ADD(2); UNALIGNED_ADD(1); UNALIGNED_ADD(0)</span></div><div class="line"><a name="l01438"></a><span class="lineno"> 1438</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T > 4</span></div><div class="line"><a name="l01439"></a><span class="lineno"> 1439</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="l01440"></a><span class="lineno"> 1440</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T > 8</span></div><div class="line"><a name="l01441"></a><span class="lineno"> 1441</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="l01442"></a><span class="lineno"> 1442</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="l01443"></a><span class="lineno"> 1443</span> <span class="preprocessor">#define UNALIGNED_ADD_ALL UNALIGNED_ADD_16</span></div><div class="line"><a name="l01444"></a><span class="lineno"> 1444</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01445"></a><span class="lineno"> 1445</span> <span class="preprocessor">#define UNALIGNED_ADD_ALL UNALIGNED_ADD_8</span></div><div class="line"><a name="l01446"></a><span class="lineno"> 1446</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01447"></a><span class="lineno"> 1447</span> <span class="preprocessor">#define UNALIGNED_ADD_ALL UNALIGNED_ADD_4</span></div><div class="line"><a name="l01448"></a><span class="lineno"> 1448</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01449"></a><span class="lineno"> 1449</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="l01450"></a><span class="lineno"> 1450</span> <span class="preprocessor">#if !UNALIGNED_WORD_ACCESS</span></div><div class="line"><a name="l01451"></a><span class="lineno"> 1451</span>  <span class="keywordtype">int</span> align = (int)((<a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">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="l01452"></a><span class="lineno"> 1452</span>  <span class="keywordflow">if</span> (align) {</div><div class="line"><a name="l01453"></a><span class="lineno"> 1453</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> d = 0;</div><div class="line"><a name="l01454"></a><span class="lineno"> 1454</span>  <span class="keywordtype">int</span> sl, sr, pack;</div><div class="line"><a name="l01455"></a><span class="lineno"> 1455</span> </div><div class="line"><a name="l01456"></a><span class="lineno"> 1456</span>  <span class="keywordflow">switch</span> (align) {</div><div class="line"><a name="l01457"></a><span class="lineno"> 1457</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div><div class="line"><a name="l01458"></a><span class="lineno"> 1458</span> <span class="preprocessor"># define UNALIGNED_ADD(n) case SIZEOF_ST_INDEX_T - (n) - 1: \</span></div><div class="line"><a name="l01459"></a><span class="lineno"> 1459</span> <span class="preprocessor"> t |= data_at(n) << CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 2)</span></div><div class="line"><a name="l01460"></a><span class="lineno"> 1460</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01461"></a><span class="lineno"> 1461</span> <span class="preprocessor"># define UNALIGNED_ADD(n) case SIZEOF_ST_INDEX_T - (n) - 1: \</span></div><div class="line"><a name="l01462"></a><span class="lineno"> 1462</span> <span class="preprocessor"> t |= data_at(n) << CHAR_BIT*(n)</span></div><div class="line"><a name="l01463"></a><span class="lineno"> 1463</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01464"></a><span class="lineno"> 1464</span>  <a class="code" href="../../d4/d71/st_8c.html#a58449b17c56fb078b9f006f8ab3c5314">UNALIGNED_ADD_ALL</a>;</div><div class="line"><a name="l01465"></a><span class="lineno"> 1465</span> <span class="preprocessor">#undef UNALIGNED_ADD</span></div><div class="line"><a name="l01466"></a><span class="lineno"> 1466</span>  }</div><div class="line"><a name="l01467"></a><span class="lineno"> 1467</span> </div><div class="line"><a name="l01468"></a><span class="lineno"> 1468</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div><div class="line"><a name="l01469"></a><span class="lineno"> 1469</span>  <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> >>= (<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="l01470"></a><span class="lineno"> 1470</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01471"></a><span class="lineno"> 1471</span>  <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> <<= (<a class="code" href="../../de/de6/ruby_2ruby_8h.html#a308d9dd2c0028ddb184b455bbd7865de">CHAR_BIT</a> * align);</div><div class="line"><a name="l01472"></a><span class="lineno"> 1472</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01473"></a><span class="lineno"> 1473</span> </div><div class="line"><a name="l01474"></a><span class="lineno"> 1474</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="l01475"></a><span class="lineno"> 1475</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="l01476"></a><span class="lineno"> 1476</span> </div><div class="line"><a name="l01477"></a><span class="lineno"> 1477</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="l01478"></a><span class="lineno"> 1478</span>  sr = <a class="code" href="../../de/de6/ruby_2ruby_8h.html#a308d9dd2c0028ddb184b455bbd7865de">CHAR_BIT</a> * align;</div><div class="line"><a name="l01479"></a><span class="lineno"> 1479</span> </div><div class="line"><a name="l01480"></a><span class="lineno"> 1480</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="l01481"></a><span class="lineno"> 1481</span>  d = *(<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> *)data;</div><div class="line"><a name="l01482"></a><span class="lineno"> 1482</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div><div class="line"><a name="l01483"></a><span class="lineno"> 1483</span>  <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> = (t << sr) | (d >> sl);</div><div class="line"><a name="l01484"></a><span class="lineno"> 1484</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01485"></a><span class="lineno"> 1485</span>  <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> = (<a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> >> sr) | (d << sl);</div><div class="line"><a name="l01486"></a><span class="lineno"> 1486</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01487"></a><span class="lineno"> 1487</span>  h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a>);</div><div class="line"><a name="l01488"></a><span class="lineno"> 1488</span>  <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> = d;</div><div class="line"><a name="l01489"></a><span class="lineno"> 1489</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="l01490"></a><span class="lineno"> 1490</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="l01491"></a><span class="lineno"> 1491</span>  }</div><div class="line"><a name="l01492"></a><span class="lineno"> 1492</span> </div><div class="line"><a name="l01493"></a><span class="lineno"> 1493</span>  pack = len < (size_t)align ? (<span class="keywordtype">int</span>)len : align;</div><div class="line"><a name="l01494"></a><span class="lineno"> 1494</span>  d = 0;</div><div class="line"><a name="l01495"></a><span class="lineno"> 1495</span>  <span class="keywordflow">switch</span> (pack) {</div><div class="line"><a name="l01496"></a><span class="lineno"> 1496</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div><div class="line"><a name="l01497"></a><span class="lineno"> 1497</span> <span class="preprocessor"># define UNALIGNED_ADD(n) case (n) + 1: \</span></div><div class="line"><a name="l01498"></a><span class="lineno"> 1498</span> <span class="preprocessor"> d |= data_at(n) << CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 1)</span></div><div class="line"><a name="l01499"></a><span class="lineno"> 1499</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01500"></a><span class="lineno"> 1500</span> <span class="preprocessor"># define UNALIGNED_ADD(n) case (n) + 1: \</span></div><div class="line"><a name="l01501"></a><span class="lineno"> 1501</span> <span class="preprocessor"> d |= data_at(n) << CHAR_BIT*(n)</span></div><div class="line"><a name="l01502"></a><span class="lineno"> 1502</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01503"></a><span class="lineno"> 1503</span>  <a class="code" href="../../d4/d71/st_8c.html#a58449b17c56fb078b9f006f8ab3c5314">UNALIGNED_ADD_ALL</a>;</div><div class="line"><a name="l01504"></a><span class="lineno"> 1504</span> <span class="preprocessor">#undef UNALIGNED_ADD</span></div><div class="line"><a name="l01505"></a><span class="lineno"> 1505</span>  }</div><div class="line"><a name="l01506"></a><span class="lineno"> 1506</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div><div class="line"><a name="l01507"></a><span class="lineno"> 1507</span>  <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> = (t << sr) | (d >> sl);</div><div class="line"><a name="l01508"></a><span class="lineno"> 1508</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01509"></a><span class="lineno"> 1509</span>  <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> = (<a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> >> sr) | (d << sl);</div><div class="line"><a name="l01510"></a><span class="lineno"> 1510</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01511"></a><span class="lineno"> 1511</span> </div><div class="line"><a name="l01512"></a><span class="lineno"> 1512</span> <span class="preprocessor">#if MURMUR == 2</span></div><div class="line"><a name="l01513"></a><span class="lineno"> 1513</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="l01514"></a><span class="lineno"> 1514</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01515"></a><span class="lineno"> 1515</span>  h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a>);</div><div class="line"><a name="l01516"></a><span class="lineno"> 1516</span>  data += pack;</div><div class="line"><a name="l01517"></a><span class="lineno"> 1517</span>  len -= pack;</div><div class="line"><a name="l01518"></a><span class="lineno"> 1518</span>  }</div><div class="line"><a name="l01519"></a><span class="lineno"> 1519</span>  <span class="keywordflow">else</span></div><div class="line"><a name="l01520"></a><span class="lineno"> 1520</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01521"></a><span class="lineno"> 1521</span>  {</div><div class="line"><a name="l01522"></a><span class="lineno"> 1522</span>  <span class="keywordflow">do</span> {</div><div class="line"><a name="l01523"></a><span class="lineno"> 1523</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="l01524"></a><span class="lineno"> 1524</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="l01525"></a><span class="lineno"> 1525</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="l01526"></a><span class="lineno"> 1526</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="l01527"></a><span class="lineno"> 1527</span>  }</div><div class="line"><a name="l01528"></a><span class="lineno"> 1528</span>  }</div><div class="line"><a name="l01529"></a><span class="lineno"> 1529</span> </div><div class="line"><a name="l01530"></a><span class="lineno"> 1530</span>  <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a> = 0;</div><div class="line"><a name="l01531"></a><span class="lineno"> 1531</span>  <span class="keywordflow">switch</span> (len) {</div><div class="line"><a name="l01532"></a><span class="lineno"> 1532</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div><div class="line"><a name="l01533"></a><span class="lineno"> 1533</span> <span class="preprocessor"># define UNALIGNED_ADD(n) case (n) + 1: \</span></div><div class="line"><a name="l01534"></a><span class="lineno"> 1534</span> <span class="preprocessor"> t |= data_at(n) << CHAR_BIT*(SIZEOF_ST_INDEX_T - (n) - 1)</span></div><div class="line"><a name="l01535"></a><span class="lineno"> 1535</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l01536"></a><span class="lineno"> 1536</span> <span class="preprocessor"># define UNALIGNED_ADD(n) case (n) + 1: \</span></div><div class="line"><a name="l01537"></a><span class="lineno"> 1537</span> <span class="preprocessor"> t |= data_at(n) << CHAR_BIT*(n)</span></div><div class="line"><a name="l01538"></a><span class="lineno"> 1538</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01539"></a><span class="lineno"> 1539</span>  <a class="code" href="../../d4/d71/st_8c.html#a58449b17c56fb078b9f006f8ab3c5314">UNALIGNED_ADD_ALL</a>;</div><div class="line"><a name="l01540"></a><span class="lineno"> 1540</span> <span class="preprocessor">#undef UNALIGNED_ADD</span></div><div class="line"><a name="l01541"></a><span class="lineno"> 1541</span> <span class="preprocessor">#if MURMUR == 1</span></div><div class="line"><a name="l01542"></a><span class="lineno"> 1542</span>  h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a>);</div><div class="line"><a name="l01543"></a><span class="lineno"> 1543</span> <span class="preprocessor">#elif MURMUR == 2</span></div><div class="line"><a name="l01544"></a><span class="lineno"> 1544</span> <span class="preprocessor"># if !UNALIGNED_WORD_ACCESS</span></div><div class="line"><a name="l01545"></a><span class="lineno"> 1545</span>  skip_tail:</div><div class="line"><a name="l01546"></a><span class="lineno"> 1546</span> <span class="preprocessor"># endif</span></div><div class="line"><a name="l01547"></a><span class="lineno"> 1547</span>  h ^= <a class="code" href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a>;</div><div class="line"><a name="l01548"></a><span class="lineno"> 1548</span>  h *= <a class="code" href="../../d4/d71/st_8c.html#a9bfe95f51203fde86c8dd3fe85d92bcd">MurmurMagic</a>;</div><div class="line"><a name="l01549"></a><span class="lineno"> 1549</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01550"></a><span class="lineno"> 1550</span>  }</div><div class="line"><a name="l01551"></a><span class="lineno"> 1551</span> </div><div class="line"><a name="l01552"></a><span class="lineno"> 1552</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="l01553"></a><span class="lineno"> 1553</span> }</div><div class="line"><a name="l01554"></a><span class="lineno"> 1554</span> </div><div class="line"><a name="l01555"></a><span class="lineno"> 1555</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01556"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a3d78a46cfffcf594047cf492737d7406"> 1556</a></span> <a class="code" href="../../d4/d71/st_8c.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="l01557"></a><span class="lineno"> 1557</span> {</div><div class="line"><a name="l01558"></a><span class="lineno"> 1558</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="l01559"></a><span class="lineno"> 1559</span> }</div><div class="line"><a name="l01560"></a><span class="lineno"> 1560</span> </div><div class="line"><a name="l01561"></a><span class="lineno"> 1561</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01562"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a72b493fcb3ac68760a725d058f1cb5d3"> 1562</a></span> <a class="code" href="../../d4/d71/st_8c.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="l01563"></a><span class="lineno"> 1563</span> {</div><div class="line"><a name="l01564"></a><span class="lineno"> 1564</span>  <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> v = 0;</div><div class="line"><a name="l01565"></a><span class="lineno"> 1565</span>  h += i;</div><div class="line"><a name="l01566"></a><span class="lineno"> 1566</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div><div class="line"><a name="l01567"></a><span class="lineno"> 1567</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 12*8</span></div><div class="line"><a name="l01568"></a><span class="lineno"> 1568</span>  v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 12*8));</div><div class="line"><a name="l01569"></a><span class="lineno"> 1569</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01570"></a><span class="lineno"> 1570</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 8*8</span></div><div class="line"><a name="l01571"></a><span class="lineno"> 1571</span>  v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 8*8));</div><div class="line"><a name="l01572"></a><span class="lineno"> 1572</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01573"></a><span class="lineno"> 1573</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 4*8</span></div><div class="line"><a name="l01574"></a><span class="lineno"> 1574</span>  v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 4*8));</div><div class="line"><a name="l01575"></a><span class="lineno"> 1575</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01576"></a><span class="lineno"> 1576</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01577"></a><span class="lineno"> 1577</span>  v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + h);</div><div class="line"><a name="l01578"></a><span class="lineno"> 1578</span> <span class="preprocessor">#ifndef WORDS_BIGENDIAN</span></div><div class="line"><a name="l01579"></a><span class="lineno"> 1579</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 4*8</span></div><div class="line"><a name="l01580"></a><span class="lineno"> 1580</span>  v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 4*8));</div><div class="line"><a name="l01581"></a><span class="lineno"> 1581</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01582"></a><span class="lineno"> 1582</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 8*8</span></div><div class="line"><a name="l01583"></a><span class="lineno"> 1583</span>  v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 8*8));</div><div class="line"><a name="l01584"></a><span class="lineno"> 1584</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01585"></a><span class="lineno"> 1585</span> <span class="preprocessor">#if SIZEOF_ST_INDEX_T*CHAR_BIT > 12*8</span></div><div class="line"><a name="l01586"></a><span class="lineno"> 1586</span>  v = <a class="code" href="../../d4/d71/st_8c.html#a08e80c200b25893c4c490666ce639528">murmur1</a>(v + (h >> 12*8));</div><div class="line"><a name="l01587"></a><span class="lineno"> 1587</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01588"></a><span class="lineno"> 1588</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01589"></a><span class="lineno"> 1589</span>  <span class="keywordflow">return</span> v;</div><div class="line"><a name="l01590"></a><span class="lineno"> 1590</span> }</div><div class="line"><a name="l01591"></a><span class="lineno"> 1591</span> </div><div class="line"><a name="l01592"></a><span class="lineno"> 1592</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01593"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#aee487969705d500b3308fc5c146fd357"> 1593</a></span> <a class="code" href="../../d4/d71/st_8c.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="l01594"></a><span class="lineno"> 1594</span> {</div><div class="line"><a name="l01595"></a><span class="lineno"> 1595</span>  h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, 10);</div><div class="line"><a name="l01596"></a><span class="lineno"> 1596</span>  h = <a class="code" href="../../d4/d71/st_8c.html#a42fee74992f1efd43ebdfb2d1c2c7538">murmur_step</a>(h, 17);</div><div class="line"><a name="l01597"></a><span class="lineno"> 1597</span>  <span class="keywordflow">return</span> h;</div><div class="line"><a name="l01598"></a><span class="lineno"> 1598</span> }</div><div class="line"><a name="l01599"></a><span class="lineno"> 1599</span> </div><div class="line"><a name="l01600"></a><span class="lineno"> 1600</span> <span class="preprocessor">#undef st_hash_start</span></div><div class="line"><a name="l01601"></a><span class="lineno"> 1601</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01602"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#abd6d8900985779079ec683ece31f6fd7"> 1602</a></span> <a class="code" href="../../d4/d71/st_8c.html#abd6d8900985779079ec683ece31f6fd7">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="l01603"></a><span class="lineno"> 1603</span> {</div><div class="line"><a name="l01604"></a><span class="lineno"> 1604</span>  <span class="keywordflow">return</span> h;</div><div class="line"><a name="l01605"></a><span class="lineno"> 1605</span> }</div><div class="line"><a name="l01606"></a><span class="lineno"> 1606</span> </div><div class="line"><a name="l01607"></a><span class="lineno"> 1607</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="l01608"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7"> 1608</a></span> <a class="code" href="../../d4/d71/st_8c.html#a167297ecc6a15b3e40576309d41e68d7">strhash</a>(<a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> arg)</div><div class="line"><a name="l01609"></a><span class="lineno"> 1609</span> {</div><div class="line"><a name="l01610"></a><span class="lineno"> 1610</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="l01611"></a><span class="lineno"> 1611</span>  <span class="keywordflow">return</span> <a class="code" href="../../d4/d71/st_8c.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="l01612"></a><span class="lineno"> 1612</span> }</div><div class="line"><a name="l01613"></a><span class="lineno"> 1613</span> <span class="preprocessor">#endif</span></div><div class="line"><a name="l01614"></a><span class="lineno"> 1614</span> </div><div class="line"><a name="l01615"></a><span class="lineno"> 1615</span> <span class="keywordtype">int</span></div><div class="line"><a name="l01616"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a2cae14784f5ba5121ab215cb3e1c6a53"> 1616</a></span> <a class="code" href="../../d4/d71/st_8c.html#a2cae14784f5ba5121ab215cb3e1c6a53">st_locale_insensitive_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="l01617"></a><span class="lineno"> 1617</span> {</div><div class="line"><a name="l01618"></a><span class="lineno"> 1618</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> c1, c2;</div><div class="line"><a name="l01619"></a><span class="lineno"> 1619</span> </div><div class="line"><a name="l01620"></a><span class="lineno"> 1620</span>  <span class="keywordflow">while</span> (1) {</div><div class="line"><a name="l01621"></a><span class="lineno"> 1621</span>  c1 = (<span class="keywordtype">unsigned</span> char)*s1++;</div><div class="line"><a name="l01622"></a><span class="lineno"> 1622</span>  c2 = (<span class="keywordtype">unsigned</span> char)*s2++;</div><div class="line"><a name="l01623"></a><span class="lineno"> 1623</span>  <span class="keywordflow">if</span> (c1 == <span class="charliteral">'\0'</span> || c2 == <span class="charliteral">'\0'</span>) {</div><div class="line"><a name="l01624"></a><span class="lineno"> 1624</span>  <span class="keywordflow">if</span> (c1 != <span class="charliteral">'\0'</span>) <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l01625"></a><span class="lineno"> 1625</span>  <span class="keywordflow">if</span> (c2 != <span class="charliteral">'\0'</span>) <span class="keywordflow">return</span> -1;</div><div class="line"><a name="l01626"></a><span class="lineno"> 1626</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01627"></a><span class="lineno"> 1627</span>  }</div><div class="line"><a name="l01628"></a><span class="lineno"> 1628</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="l01629"></a><span class="lineno"> 1629</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="l01630"></a><span class="lineno"> 1630</span>  <span class="keywordflow">if</span> (c1 != c2) {</div><div class="line"><a name="l01631"></a><span class="lineno"> 1631</span>  <span class="keywordflow">if</span> (c1 > c2)</div><div class="line"><a name="l01632"></a><span class="lineno"> 1632</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l01633"></a><span class="lineno"> 1633</span>  <span class="keywordflow">else</span></div><div class="line"><a name="l01634"></a><span class="lineno"> 1634</span>  <span class="keywordflow">return</span> -1;</div><div class="line"><a name="l01635"></a><span class="lineno"> 1635</span>  }</div><div class="line"><a name="l01636"></a><span class="lineno"> 1636</span>  }</div><div class="line"><a name="l01637"></a><span class="lineno"> 1637</span> }</div><div class="line"><a name="l01638"></a><span class="lineno"> 1638</span> </div><div class="line"><a name="l01639"></a><span class="lineno"> 1639</span> <span class="keywordtype">int</span></div><div class="line"><a name="l01640"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#ab59eeb093d2ca63b5a6059a49499d48a"> 1640</a></span> <a class="code" href="../../d4/d71/st_8c.html#ab59eeb093d2ca63b5a6059a49499d48a">st_locale_insensitive_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> n)</div><div class="line"><a name="l01641"></a><span class="lineno"> 1641</span> {</div><div class="line"><a name="l01642"></a><span class="lineno"> 1642</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> c1, c2;</div><div class="line"><a name="l01643"></a><span class="lineno"> 1643</span> </div><div class="line"><a name="l01644"></a><span class="lineno"> 1644</span>  <span class="keywordflow">while</span> (n--) {</div><div class="line"><a name="l01645"></a><span class="lineno"> 1645</span>  c1 = (<span class="keywordtype">unsigned</span> char)*s1++;</div><div class="line"><a name="l01646"></a><span class="lineno"> 1646</span>  c2 = (<span class="keywordtype">unsigned</span> char)*s2++;</div><div class="line"><a name="l01647"></a><span class="lineno"> 1647</span>  <span class="keywordflow">if</span> (c1 == <span class="charliteral">'\0'</span> || c2 == <span class="charliteral">'\0'</span>) {</div><div class="line"><a name="l01648"></a><span class="lineno"> 1648</span>  <span class="keywordflow">if</span> (c1 != <span class="charliteral">'\0'</span>) <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l01649"></a><span class="lineno"> 1649</span>  <span class="keywordflow">if</span> (c2 != <span class="charliteral">'\0'</span>) <span class="keywordflow">return</span> -1;</div><div class="line"><a name="l01650"></a><span class="lineno"> 1650</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01651"></a><span class="lineno"> 1651</span>  }</div><div class="line"><a name="l01652"></a><span class="lineno"> 1652</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="l01653"></a><span class="lineno"> 1653</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="l01654"></a><span class="lineno"> 1654</span>  <span class="keywordflow">if</span> (c1 != c2) {</div><div class="line"><a name="l01655"></a><span class="lineno"> 1655</span>  <span class="keywordflow">if</span> (c1 > c2)</div><div class="line"><a name="l01656"></a><span class="lineno"> 1656</span>  <span class="keywordflow">return</span> 1;</div><div class="line"><a name="l01657"></a><span class="lineno"> 1657</span>  <span class="keywordflow">else</span></div><div class="line"><a name="l01658"></a><span class="lineno"> 1658</span>  <span class="keywordflow">return</span> -1;</div><div class="line"><a name="l01659"></a><span class="lineno"> 1659</span>  }</div><div class="line"><a name="l01660"></a><span class="lineno"> 1660</span>  }</div><div class="line"><a name="l01661"></a><span class="lineno"> 1661</span>  <span class="keywordflow">return</span> 0;</div><div class="line"><a name="l01662"></a><span class="lineno"> 1662</span> }</div><div class="line"><a name="l01663"></a><span class="lineno"> 1663</span> </div><div class="line"><a name="l01664"></a><span class="lineno"> 1664</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="l01665"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48"> 1665</a></span> <a class="code" href="../../d4/d71/st_8c.html#a1a0a643d881cfc8e9def03ff92d49b48">strcasehash</a>(<a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> arg)</div><div class="line"><a name="l01666"></a><span class="lineno"> 1666</span> {</div><div class="line"><a name="l01667"></a><span class="lineno"> 1667</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="l01668"></a><span class="lineno"> 1668</span>  <span class="keyword">register</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a> hval = <a class="code" href="../../d4/d71/st_8c.html#a40a142ccb9ca21d50ea9f6ed8589cc96">FNV1_32A_INIT</a>;</div><div class="line"><a name="l01669"></a><span class="lineno"> 1669</span> </div><div class="line"><a name="l01670"></a><span class="lineno"> 1670</span>  <span class="comment">/*</span></div><div class="line"><a name="l01671"></a><span class="lineno"> 1671</span> <span class="comment"> * FNV-1a hash each octet in the buffer</span></div><div class="line"><a name="l01672"></a><span class="lineno"> 1672</span> <span class="comment"> */</span></div><div class="line"><a name="l01673"></a><span class="lineno"> 1673</span>  <span class="keywordflow">while</span> (*<span class="keywordtype">string</span>) {</div><div class="line"><a name="l01674"></a><span class="lineno"> 1674</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> c = (<span class="keywordtype">unsigned</span> char)*<span class="keywordtype">string</span>++;</div><div class="line"><a name="l01675"></a><span class="lineno"> 1675</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="l01676"></a><span class="lineno"> 1676</span>  hval ^= c;</div><div class="line"><a name="l01677"></a><span class="lineno"> 1677</span> </div><div class="line"><a name="l01678"></a><span class="lineno"> 1678</span>  <span class="comment">/* multiply by the 32 bit FNV magic prime mod 2^32 */</span></div><div class="line"><a name="l01679"></a><span class="lineno"> 1679</span>  hval *= <a class="code" href="../../d4/d71/st_8c.html#ae13a6565bea334e9b6fb19033a392857">FNV_32_PRIME</a>;</div><div class="line"><a name="l01680"></a><span class="lineno"> 1680</span>  }</div><div class="line"><a name="l01681"></a><span class="lineno"> 1681</span>  <span class="keywordflow">return</span> hval;</div><div class="line"><a name="l01682"></a><span class="lineno"> 1682</span> }</div><div class="line"><a name="l01683"></a><span class="lineno"> 1683</span> </div><div class="line"><a name="l01684"></a><span class="lineno"> 1684</span> <span class="keywordtype">int</span></div><div class="line"><a name="l01685"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a4c9a444f4aabb6c83a19c5afacbfdaf6"> 1685</a></span> <a class="code" href="../../d4/d71/st_8c.html#a4c9a444f4aabb6c83a19c5afacbfdaf6">st_numcmp</a>(<a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> x, <a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> y)</div><div class="line"><a name="l01686"></a><span class="lineno"> 1686</span> {</div><div class="line"><a name="l01687"></a><span class="lineno"> 1687</span>  <span class="keywordflow">return</span> x != y;</div><div class="line"><a name="l01688"></a><span class="lineno"> 1688</span> }</div><div class="line"><a name="l01689"></a><span class="lineno"> 1689</span> </div><div class="line"><a name="l01690"></a><span class="lineno"> 1690</span> <a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a></div><div class="line"><a name="l01691"></a><span class="lineno"><a class="line" href="../../d4/d71/st_8c.html#a012fbc7aee9522e01fa622dd6aafbaee"> 1691</a></span> <a class="code" href="../../d4/d71/st_8c.html#a012fbc7aee9522e01fa622dd6aafbaee">st_numhash</a>(<a class="code" href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a> n)</div><div class="line"><a name="l01692"></a><span class="lineno"> 1692</span> {</div><div class="line"><a name="l01693"></a><span class="lineno"> 1693</span>  <span class="keywordflow">return</span> (<a class="code" href="../../dd/d24/st_8h.html#ac214e5cdcf0de6a2108b9643e7fc12e0">st_index_t</a>)n;</div><div class="line"><a name="l01694"></a><span class="lineno"> 1694</span> }</div><div class="ttc" id="st_8c_html_aa7489a5419c00d3900a0f533ed14958a"><div class="ttname"><a href="../../d4/d71/st_8c.html#aa7489a5419c00d3900a0f533ed14958a">PKEY</a></div><div class="ttdeci">#define PKEY(table, i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00114">st.c:114</a></div></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#l00184">st.c:184</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#l01383">st.c:1383</a></div></div> <div class="ttc" id="st_8c_html_a3fde5a76b3fc28787b7350eaf790676b"><div class="ttname"><a href="../../d4/d71/st_8c.html#a3fde5a76b3fc28787b7350eaf790676b">st_cleanup_safe</a></div><div class="ttdeci">void st_cleanup_safe(st_table *table, st_data_t never)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00830">st.c:830</a></div></div> <div class="ttc" id="st_8c_html_ab2607640960e5c6916c5164be9a3646b"><div class="ttname"><a href="../../d4/d71/st_8c.html#ab2607640960e5c6916c5164be9a3646b">PVAL_SET</a></div><div class="ttdeci">#define PVAL_SET(table, i, v)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00118">st.c:118</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="st_8c_html_ac88dda6f84d1db8c5654cade389c0f78"><div class="ttname"><a href="../../d4/d71/st_8c.html#ac88dda6f84d1db8c5654cade389c0f78">st_keys_check</a></div><div class="ttdeci">st_index_t st_keys_check(st_table *table, st_data_t *keys, st_index_t size, st_data_t never)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01136">st.c:1136</a></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#l00069">st.h:69</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="st_8c_html_a3d78a46cfffcf594047cf492737d7406"><div class="ttname"><a href="../../d4/d71/st_8c.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#l01556">st.c:1556</a></div></div> <div class="ttc" id="st_8c_html_a2cae14784f5ba5121ab215cb3e1c6a53"><div class="ttname"><a href="../../d4/d71/st_8c.html#a2cae14784f5ba5121ab215cb3e1c6a53">st_locale_insensitive_strcasecmp</a></div><div class="ttdeci">int st_locale_insensitive_strcasecmp(const char *s1, const char *s2)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01616">st.c:1616</a></div></div> <div class="ttc" id="st_8c_html_a6fa3f871a2c35f21497cbc12deceeced"><div class="ttname"><a href="../../d4/d71/st_8c.html#a6fa3f871a2c35f21497cbc12deceeced">get_keys</a></div><div class="ttdeci">static st_index_t get_keys(st_table *table, st_data_t *keys, st_index_t size, int check, st_data_t never)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01101">st.c:1101</a></div></div> <div class="ttc" id="st_8c_html_ac1c04331d2aef8182cd58605fcc2fb25"><div class="ttname"><a href="../../d4/d71/st_8c.html#ac1c04331d2aef8182cd58605fcc2fb25">new_entry</a></div><div class="ttdeci">static st_table_entry * new_entry(st_table *table, st_data_t key, st_data_t value, st_index_t hash_val, register st_index_t bin_pos)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00473">st.c:473</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_a226470512e2b756ed55264ce13f846c5"><div class="ttname"><a href="../../d4/d71/st_8c.html#a226470512e2b756ed55264ce13f846c5">find_packed_index</a></div><div class="ttdeci">static st_index_t find_packed_index(st_table *table, st_index_t hash_val, st_data_t key)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00406">st.c:406</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#l01336">st.c:1336</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#l00146">st.c:146</a></div></div> <div class="ttc" id="st_8c_html_a5a026e0f0fbb0375b83056f0124889ee"><div class="ttname"><a href="../../d4/d71/st_8c.html#a5a026e0f0fbb0375b83056f0124889ee">st_update</a></div><div class="ttdeci">int st_update(st_table *table, st_data_t key, st_update_callback_func *func, st_data_t arg)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00867">st.c:867</a></div></div> <div class="ttc" id="st_8c_html_a012fbc7aee9522e01fa622dd6aafbaee"><div class="ttname"><a href="../../d4/d71/st_8c.html#a012fbc7aee9522e01fa622dd6aafbaee">st_numhash</a></div><div class="ttdeci">st_index_t st_numhash(st_data_t n)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01691">st.c:1691</a></div></div> <div class="ttc" id="st_8c_html_a157fecaa7d870fdf190ee0f8c073edd1"><div class="ttname"><a href="../../d4/d71/st_8c.html#a157fecaa7d870fdf190ee0f8c073edd1">PACKED_UNIT</a></div><div class="ttdeci">#define PACKED_UNIT</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00039">st.c:39</a></div></div> <div class="ttc" id="st_8h_html_a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139"><div class="ttname"><a href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fac99fc55c7f355bf9071739a4bc2ea139">ST_CONTINUE</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="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#l00071">st.h:71</a></div></div> <div class="ttc" id="st_8c_html_a9b0256b6986265c09661636af78fcb74"><div class="ttname"><a href="../../d4/d71/st_8c.html#a9b0256b6986265c09661636af78fcb74">st_clear</a></div><div class="ttdeci">void st_clear(st_table *table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00308">st.c:308</a></div></div> <div class="ttc" id="ossl__ssl_8c_html_a86771351f4ef469ab9c94739a64fd7ea"><div class="ttname"><a href="../../dc/dd1/ossl__ssl_8c.html#a86771351f4ef469ab9c94739a64fd7ea">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#l00113">ossl_ssl.c:113</a></div></div> <div class="ttc" id="st_8c_html_a4c12b0bc4cb64bc0ebc40a3536e0198a"><div class="ttname"><a href="../../d4/d71/st_8c.html#a4c12b0bc4cb64bc0ebc40a3536e0198a">st_init_strcasetable_with_size</a></div><div class="ttdeci">st_table * st_init_strcasetable_with_size(st_index_t size)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00302">st.c:302</a></div></div> <div class="ttc" id="st_8c_html_af83cfc72d5d16b336475bf69c3a95133"><div class="ttname"><a href="../../d4/d71/st_8c.html#af83cfc72d5d16b336475bf69c3a95133">type_strhash</a></div><div class="ttdeci">static const struct st_hash_type type_strhash</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00063">st.c:63</a></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="st_8c_html_abd6d8900985779079ec683ece31f6fd7"><div class="ttname"><a href="../../d4/d71/st_8c.html#abd6d8900985779079ec683ece31f6fd7">st_hash_start</a></div><div class="ttdeci">st_index_t st_hash_start(st_index_t h)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01602">st.c:1602</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#l01857">error.c:1857</a></div></div> <div class="ttc" id="st_8c_html_a7315baa4d596bcbe6360aed56b63666b"><div class="ttname"><a href="../../d4/d71/st_8c.html#a7315baa4d596bcbe6360aed56b63666b">st_free_entry</a></div><div class="ttdeci">#define st_free_entry(entry)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00092">st.c:92</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="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#l00048">st.h:48</a></div></div> <div class="ttc" id="st_8c_html_aa5f47e0af563e177e8b559073f454625"><div class="ttname"><a href="../../d4/d71/st_8c.html#aa5f47e0af563e177e8b559073f454625">st_init_table_with_size</a></div><div class="ttdeci">st_table * st_init_table_with_size(const struct st_hash_type *type, st_index_t size)</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_a955c6e936b9681649ab9ffa4aa741949"><div class="ttname"><a href="../../d4/d71/st_8c.html#a955c6e936b9681649ab9ffa4aa741949">st_init_numtable</a></div><div class="ttdeci">st_table * st_init_numtable(void)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00272">st.c:272</a></div></div> <div class="ttc" id="st_8c_html_af2207ffbfcc7d6db423a059634117edb"><div class="ttname"><a href="../../d4/d71/st_8c.html#af2207ffbfcc7d6db423a059634117edb">st_dealloc_table</a></div><div class="ttdeci">#define st_dealloc_table(table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00094">st.c:94</a></div></div> <div class="ttc" id="st_8c_html_a331ffe3f89d8c0f929d2c5e8967cc1db"><div class="ttname"><a href="../../d4/d71/st_8c.html#a331ffe3f89d8c0f929d2c5e8967cc1db">add_packed_direct</a></div><div class="ttdeci">static void add_packed_direct(st_table *table, st_data_t key, st_data_t value, st_index_t hash_val)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00547">st.c:547</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#l04310">nkf.c:4310</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#l01425">st.c:1425</a></div></div> <div class="ttc" id="st_8c_html_a4f884be75490db2c92e409a0209fdbcb"><div class="ttname"><a href="../../d4/d71/st_8c.html#a4f884be75490db2c92e409a0209fdbcb">ST_DEFAULT_MAX_DENSITY</a></div><div class="ttdeci">#define ST_DEFAULT_MAX_DENSITY</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00035">st.c:35</a></div></div> <div class="ttc" id="st_8c_html_a2e84b634e97a0834e9f03658d1cb202f"><div class="ttname"><a href="../../d4/d71/st_8c.html#a2e84b634e97a0834e9f03658d1cb202f">MAX_PACKED_HASH</a></div><div class="ttdeci">#define MAX_PACKED_HASH</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00040">st.c:40</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#l00512">st.c:512</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#l00072">st.h:72</a></div></div> <div class="ttc" id="st_8h_html_ae83f60f8022ef1ccdc536b8b43efa06b"><div class="ttname"><a href="../../dd/d24/st_8h.html#ae83f60f8022ef1ccdc536b8b43efa06b">st_data_t</a></div><div class="ttdeci">RUBY_SYMBOL_EXPORT_BEGIN typedef unsigned long st_data_t</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00020">st.h:20</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_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#l00377">st.c:377</a></div></div> <div class="ttc" id="hash_8c_html_afd38f591d634bb21e98b8bc7b0e6ac49"><div class="ttname"><a href="../../d1/d04/hash_8c.html#afd38f591d634bb21e98b8bc7b0e6ac49">st_hashtype_num</a></div><div class="ttdeci">const struct st_hash_type st_hashtype_num</div></div> <div class="ttc" id="structst__packed__entry_html_ad82c9cdfeaa161b28652002eeaf1999c"><div class="ttname"><a href="../../d8/ddd/structst__packed__entry.html#ad82c9cdfeaa161b28652002eeaf1999c">st_packed_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#l00030">st.c:30</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#l00055">st.h:55</a></div></div> <div class="ttc" id="st_8c_html_a92f0cb21ae7d4d53e0f57efcd158d80f"><div class="ttname"><a href="../../d4/d71/st_8c.html#a92f0cb21ae7d4d53e0f57efcd158d80f">st_init_strtable_with_size</a></div><div class="ttdeci">st_table * st_init_strtable_with_size(st_index_t size)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00290">st.c:290</a></div></div> <div class="ttc" id="ruby_2ruby_8h_html_a56d620b94b668ed7665d1616b2c54e48"><div class="ttname"><a href="../../de/de6/ruby_2ruby_8h.html#a56d620b94b668ed7665d1616b2c54e48">MEMZERO</a></div><div class="ttdeci">#define MEMZERO(p, type, n)</div><div class="ttdef"><b>Definition:</b> <a href="../../de/de6/ruby_2ruby_8h_source.html#l01359">ruby.h:1359</a></div></div> <div class="ttc" id="st_8c_html_aaca0d6a6f8e07dd6ad3265872d7b1f81"><div class="ttname"><a href="../../d4/d71/st_8c.html#aaca0d6a6f8e07dd6ad3265872d7b1f81">st_init_strtable</a></div><div class="ttdeci">st_table * st_init_strtable(void)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00284">st.c:284</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#l00053">st.h:53</a></div></div> <div class="ttc" id="st_8c_html_a4bfcb3c7be49d9acd35fa21e8372cd41"><div class="ttname"><a href="../../d4/d71/st_8c.html#a4bfcb3c7be49d9acd35fa21e8372cd41">st_alloc_table</a></div><div class="ttdeci">#define st_alloc_table()</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00093">st.c:93</a></div></div> <div class="ttc" id="openssl_2conftest_8c_html_ad2c584e6472d5514c2fa94aea1697bb7"><div class="ttname"><a href="../../d8/dac/openssl_2conftest_8c.html#ad2c584e6472d5514c2fa94aea1697bb7">t</a></div><div class="ttdeci">int t(void)</div><div class="ttdef"><b>Definition:</b> <a href="../../d8/dac/openssl_2conftest_8c_source.html#l00013">conftest.c:13</a></div></div> <div class="ttc" id="st_8c_html_a60f14cceadd837db51e110881258944a"><div class="ttname"><a href="../../d4/d71/st_8c.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#l00296">st.c:296</a></div></div> <div class="ttc" id="st_8c_html_aee487969705d500b3308fc5c146fd357"><div class="ttname"><a href="../../d4/d71/st_8c.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#l01593">st.c:1593</a></div></div> <div class="ttc" id="vm__exec_8c_html"><div class="ttname"><a href="../../df/d38/vm__exec_8c.html">val</a></div><div class="ttdeci">#define val</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#l00547">error.c:547</a></div></div> <div class="ttc" id="st_8c_html_ae3ba2172909b8e58e5abfdef7642155b"><div class="ttname"><a href="../../d4/d71/st_8c.html#ae3ba2172909b8e58e5abfdef7642155b">st_alloc_bins</a></div><div class="ttdeci">#define st_alloc_bins(size)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00095">st.c:95</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#l01407">st.c:1407</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#l01420">st.c:1420</a></div></div> <div class="ttc" id="st_8c_html_ac92a232279757a1a165f8bff758754d6"><div class="ttname"><a href="../../d4/d71/st_8c.html#ac92a232279757a1a165f8bff758754d6">PVAL</a></div><div class="ttdeci">#define PVAL(table, i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00115">st.c:115</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#l01388">st.c:1388</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="structst__table_html_a22a80745213b612a72093b1a461a5711"><div class="ttname"><a href="../../d0/ddd/structst__table.html#a22a80745213b612a72093b1a461a5711">st_table::packed</a></div><div class="ttdeci">struct st_table::@120::@122 packed</div></div> <div class="ttc" id="st_8c_html_ae666ef5798c3d30a0533bd91054ec1f3"><div class="ttname"><a href="../../d4/d71/st_8c.html#ae666ef5798c3d30a0533bd91054ec1f3">st_get_key</a></div><div class="ttdeci">int st_get_key(st_table *table, register st_data_t key, st_data_t *result)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00442">st.c:442</a></div></div> <div class="ttc" id="st_8c_html_acc0ef6968908283247217a06840c6d8c"><div class="ttname"><a href="../../d4/d71/st_8c.html#acc0ef6968908283247217a06840c6d8c">add_direct</a></div><div class="ttdeci">static void add_direct(st_table *table, st_data_t key, st_data_t value, st_index_t hash_val, register st_index_t bin_pos)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00488">st.c:488</a></div></div> <div class="ttc" id="unistd_8h_html"><div class="ttname"><a href="../../da/d6f/unistd_8h.html">unistd.h</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#l00151">st.c:151</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#l01608">st.c:1608</a></div></div> <div class="ttc" id="st_8c_html_a7ae8f8630077956a99c2fb7966beae3d"><div class="ttname"><a href="../../d4/d71/st_8c.html#a7ae8f8630077956a99c2fb7966beae3d">PHASH_SET</a></div><div class="ttdeci">#define PHASH_SET(table, i, v)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00119">st.c:119</a></div></div> <div class="ttc" id="st_8c_html_a51731773e02649913e2a8d91d6ca4ad1"><div class="ttname"><a href="../../d4/d71/st_8c.html#a51731773e02649913e2a8d91d6ca4ad1">PHASH</a></div><div class="ttdeci">#define PHASH(table, i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00116">st.c:116</a></div></div> <div class="ttc" id="st_8c_html_a376a6db1416fd2edb1ce72ad624ff109"><div class="ttname"><a href="../../d4/d71/st_8c.html#a376a6db1416fd2edb1ce72ad624ff109">st_delete</a></div><div class="ttdeci">int st_delete(register st_table *table, register st_data_t *key, st_data_t *value)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00729">st.c:729</a></div></div> <div class="ttc" id="st_8c_html_abc2f0cf0d3883db5db318210cd7cbd13"><div class="ttname"><a href="../../d4/d71/st_8c.html#abc2f0cf0d3883db5db318210cd7cbd13">find_entry</a></div><div class="ttdeci">static st_table_entry * find_entry(st_table *table, st_data_t key, st_index_t hash_val, st_index_t bin_pos)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00381">st.c:381</a></div></div> <div class="ttc" id="st_8c_html_a7c82a8a77cae6b7a0ad72e9a43e8d0c5"><div class="ttname"><a href="../../d4/d71/st_8c.html#a7c82a8a77cae6b7a0ad72e9a43e8d0c5">STATIC_ASSERT</a></div><div class="ttdeci">#define STATIC_ASSERT(name, expr)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00033">st.c:33</a></div></div> <div class="ttc" id="st_8c_html_a4fc94afd44187992a916a7a4608481d4"><div class="ttname"><a href="../../d4/d71/st_8c.html#a4fc94afd44187992a916a7a4608481d4">st_realloc_bins</a></div><div class="ttdeci">static st_table_entry ** st_realloc_bins(st_table_entry **bins, st_index_t newsize, st_index_t oldsize)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00098">st.c:98</a></div></div> <div class="ttc" id="ruby_2ruby_8h_html_a04ab67335215e8362c63ed27ae2d1c40"><div class="ttname"><a href="../../de/de6/ruby_2ruby_8h.html#a04ab67335215e8362c63ed27ae2d1c40">MEMCPY</a></div><div class="ttdeci">#define MEMCPY(p1, p2, type, n)</div><div class="ttdef"><b>Definition:</b> <a href="../../de/de6/ruby_2ruby_8h_source.html#l01360">ruby.h:1360</a></div></div> <div class="ttc" id="st_8c_html_a77325ab6bf8e5f0cc3d02efc4a790bf2"><div class="ttname"><a href="../../d4/d71/st_8c.html#a77325ab6bf8e5f0cc3d02efc4a790bf2">find_packed_index_from</a></div><div class="ttdeci">static st_index_t find_packed_index_from(st_table *table, st_index_t hash_val, st_data_t key, st_index_t i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00396">st.c:396</a></div></div> <div class="ttc" id="st_8c_html_accc02c609f11fe0cad4061ff19f09b9a"><div class="ttname"><a href="../../d4/d71/st_8c.html#accc02c609f11fe0cad4061ff19f09b9a">st_foreach</a></div><div class="ttdeci">int st_foreach(st_table *table, int(*func)(ANYARGS), st_data_t arg)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01034">st.c:1034</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#l00089">st.h:89</a></div></div> <div class="ttc" id="structst__table_html_acd6cc341ae261d08a1dbaa8de03e2bd4"><div class="ttname"><a href="../../d0/ddd/structst__table.html#acd6cc341ae261d08a1dbaa8de03e2bd4">st_table::as</a></div><div class="ttdeci">union st_table::@120 as</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="st_8c_html_ac467af858b7f771bed79544c1c710a65"><div class="ttname"><a href="../../d4/d71/st_8c.html#ac467af858b7f771bed79544c1c710a65">st_values</a></div><div class="ttdeci">st_index_t st_values(st_table *table, st_data_t *values, st_index_t size)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01171">st.c:1171</a></div></div> <div class="ttc" id="st_8c_html_a1b739878adcdb46fb5d209af7ce79628"><div class="ttname"><a href="../../d4/d71/st_8c.html#a1b739878adcdb46fb5d209af7ce79628">realloc</a></div><div class="ttdeci">#define realloc</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00079">st.c:79</a></div></div> <div class="ttc" id="st_8c_html_a97be08dc6dad83bd7da3ff39ccbef462"><div class="ttname"><a href="../../d4/d71/st_8c.html#a97be08dc6dad83bd7da3ff39ccbef462">st_foreach_check</a></div><div class="ttdeci">int st_foreach_check(st_table *table, int(*func)(ANYARGS), st_data_t arg, st_data_t never)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00942">st.c:942</a></div></div> <div class="ttc" id="st_8c_html_a970b36e65b43e8fcccbea3e3397aeefa"><div class="ttname"><a href="../../d4/d71/st_8c.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#l01429">st.c:1429</a></div></div> <div class="ttc" id="structst__packed__entry_html_a709049731ea4672ec675de3585e97c31"><div class="ttname"><a href="../../d8/ddd/structst__packed__entry.html#a709049731ea4672ec675de3585e97c31">st_packed_entry::val</a></div><div class="ttdeci">st_data_t val</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00030">st.c:30</a></div></div> <div class="ttc" id="st_8c_html_a028396ceb63492536a3609e4e824d148"><div class="ttname"><a href="../../d4/d71/st_8c.html#a028396ceb63492536a3609e4e824d148">type_strcasehash</a></div><div class="ttdeci">static const struct st_hash_type type_strcasehash</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="st_8c_html_a907aa34a01be5677c334e63260bdf3bc"><div class="ttname"><a href="../../d4/d71/st_8c.html#a907aa34a01be5677c334e63260bdf3bc">real_entries</a></div><div class="ttdeci">#define real_entries</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00109">st.c:109</a></div></div> <div class="ttc" id="ruby_2ruby_8h_html_aad09de334c9b8c7f717d314b14679e62"><div class="ttname"><a href="../../de/de6/ruby_2ruby_8h.html#aad09de334c9b8c7f717d314b14679e62">MEMMOVE</a></div><div class="ttdeci">#define MEMMOVE(p1, p2, type, n)</div><div class="ttdef"><b>Definition:</b> <a href="../../de/de6/ruby_2ruby_8h_source.html#l01361">ruby.h:1361</a></div></div> <div class="ttc" id="structst__packed__entry_html"><div class="ttname"><a href="../../d8/ddd/structst__packed__entry.html">st_packed_entry</a></div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00028">st.c:28</a></div></div> <div class="ttc" id="st_8c_html_a31a34db9e9147ea35102754a6509f2bd"><div class="ttname"><a href="../../d4/d71/st_8c.html#a31a34db9e9147ea35102754a6509f2bd">st_values_check</a></div><div class="ttdeci">st_index_t st_values_check(st_table *table, st_data_t *values, st_index_t size, st_data_t never)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01177">st.c:1177</a></div></div> <div class="ttc" id="st_8c_html_ab663e132c2bb344be9d0763540c23509"><div class="ttname"><a href="../../d4/d71/st_8c.html#ab663e132c2bb344be9d0763540c23509">remove_safe_packed_entry</a></div><div class="ttdeci">static void remove_safe_packed_entry(st_table *table, st_index_t i, st_data_t never)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00134">st.c:134</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#l00112">tcltklib.c:112</a></div></div> <div class="ttc" id="st_8c_html_a349734f8cc08a7685ec22c76d31d0d87"><div class="ttname"><a href="../../d4/d71/st_8c.html#a349734f8cc08a7685ec22c76d31d0d87">PTR_NOT_EQUAL</a></div><div class="ttdeci">#define PTR_NOT_EQUAL(table, ptr, hash_val, key)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00352">st.c:352</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#l00088">st.h:88</a></div></div> <div class="ttc" id="nkf_8c_html_a5ea5ac7abf5cce39283e422add1067d5"><div class="ttname"><a href="../../d8/d90/nkf_8c.html#a5ea5ac7abf5cce39283e422add1067d5">result</a></div><div class="ttdeci">static VALUE result</div><div class="ttdef"><b>Definition:</b> <a href="../../d8/d90/nkf_8c_source.html#l00040">nkf.c:40</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#l01331">st.c:1331</a></div></div> <div class="ttc" id="st_8c_html_af968643d33d8ca4088601fdad8783913"><div class="ttname"><a href="../../d4/d71/st_8c.html#af968643d33d8ca4088601fdad8783913">ST_DEFAULT_SECOND_TABLE_SIZE</a></div><div class="ttdeci">#define ST_DEFAULT_SECOND_TABLE_SIZE</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00037">st.c:37</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="st_8c_html_af526fb7d918a9a5ceadadc087e79aa1c"><div class="ttname"><a href="../../d4/d71/st_8c.html#af526fb7d918a9a5ceadadc087e79aa1c">st_lookup</a></div><div class="ttdeci">int st_lookup(st_table *table, register st_data_t key, st_data_t *value)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00414">st.c:414</a></div></div> <div class="ttc" id="st_8c_html_ad9d5f8f4ebdb3e9b80ea1e37ca4d234d"><div class="ttname"><a href="../../d4/d71/st_8c.html#ad9d5f8f4ebdb3e9b80ea1e37ca4d234d">st_free_bins</a></div><div class="ttdeci">#define st_free_bins(bins, size)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00096">st.c:96</a></div></div> <div class="ttc" id="st_8c_html_aa98339af92fd08445ea0683805843bd9"><div class="ttname"><a href="../../d4/d71/st_8c.html#aa98339af92fd08445ea0683805843bd9">st_shift</a></div><div class="ttdeci">int st_shift(register st_table *table, register st_data_t *key, st_data_t *value)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00802">st.c:802</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#l00198">ruby.h:198</a></div></div> <div class="ttc" id="st_8c_html_aaafeee841b664f0ea14b28e7e1b1a71a"><div class="ttname"><a href="../../d4/d71/st_8c.html#aaafeee841b664f0ea14b28e7e1b1a71a">st_delete_safe</a></div><div class="ttdeci">int st_delete_safe(register st_table *table, register st_data_t *key, st_data_t *value, st_data_t never)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00766">st.c:766</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="structst__packed__entry_html_a35a714a0761f0319735d1ce91298328b"><div class="ttname"><a href="../../d8/ddd/structst__packed__entry.html#a35a714a0761f0319735d1ce91298328b">st_packed_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#l00029">st.c:29</a></div></div> <div class="ttc" id="win32_8c_html_a0b6e1d2007fab7ae5d69c0b6e8162846"><div class="ttname"><a href="../../d5/df2/win32_8c.html#a0b6e1d2007fab7ae5d69c0b6e8162846">getenv</a></div><div class="ttdeci">#define getenv(name)</div><div class="ttdef"><b>Definition:</b> <a href="../../d5/df2/win32_8c_source.html#l00066">win32.c:66</a></div></div> <div class="ttc" id="st_8c_html_affb9fc32698fab7f7b36e0cf8e64c83e"><div class="ttname"><a href="../../d4/d71/st_8c.html#affb9fc32698fab7f7b36e0cf8e64c83e">free</a></div><div class="ttdeci">#define free(x)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00080">st.c:80</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#l00049">encoding.c:49</a></div></div> <div class="ttc" id="sprintf_8c_html_a7a51ed112e9b79f89e3e70beb8db8bf5"><div class="ttname"><a href="../../d9/d2d/sprintf_8c.html#a7a51ed112e9b79f89e3e70beb8db8bf5">f</a></div><div class="ttdeci">#define f</div></div> <div class="ttc" id="st_8c_html_a0fccb1100278656a74bdfd5d7c3f9913"><div class="ttname"><a href="../../d4/d71/st_8c.html#a0fccb1100278656a74bdfd5d7c3f9913">remove_packed_entry</a></div><div class="ttdeci">static void remove_packed_entry(st_table *table, st_index_t i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00123">st.c:123</a></div></div> <div class="ttc" id="st_8c_html_a1fe53fe235ae6db0c7abe49413785363"><div class="ttname"><a href="../../d4/d71/st_8c.html#a1fe53fe235ae6db0c7abe49413785363">st_copy</a></div><div class="ttdeci">st_table * st_copy(st_table *old_table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00663">st.c:663</a></div></div> <div class="ttc" id="st_8c_html_a1000e3d262482cebe00e98bf21696749"><div class="ttname"><a href="../../d4/d71/st_8c.html#a1000e3d262482cebe00e98bf21696749">st_insert2</a></div><div class="ttdeci">int st_insert2(register st_table *table, register st_data_t key, st_data_t value, st_data_t(*func)(st_data_t))</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00595">st.c:595</a></div></div> <div class="ttc" id="st_8c_html_a0a1a5e64d8833b9da51b96d02562593d"><div class="ttname"><a href="../../d4/d71/st_8c.html#a0a1a5e64d8833b9da51b96d02562593d">type_numhash</a></div><div class="ttdeci">#define type_numhash</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#l00087">st.c:87</a></div></div> <div class="ttc" id="st_8c_html_a6c727f5a38e3e21fea2d0b8468813d87"><div class="ttname"><a href="../../d4/d71/st_8c.html#a6c727f5a38e3e21fea2d0b8468813d87">st_add_direct</a></div><div class="ttdeci">void st_add_direct(st_table *table, st_data_t key, st_data_t value)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00629">st.c:629</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#l00098">defines.h:98</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#l00085">st.c:85</a></div></div> <div class="ttc" id="st_8c_html_ab1314d055fd90b84911a9ec5e802edf7"><div class="ttname"><a href="../../d4/d71/st_8c.html#ab1314d055fd90b84911a9ec5e802edf7">ST_DEFAULT_PACKED_TABLE_SIZE</a></div><div class="ttdeci">#define ST_DEFAULT_PACKED_TABLE_SIZE</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00038">st.c:38</a></div></div> <div class="ttc" id="random_8c_html_a742229490b6759a90ece7ba82ba129d5"><div class="ttname"><a href="../../dc/de5/random_8c.html#a742229490b6759a90ece7ba82ba129d5">key</a></div><div class="ttdeci">uint8_t key[16]</div><div class="ttdef"><b>Definition:</b> <a href="../../dc/de5/random_8c_source.html#l01250">random.c:1250</a></div></div> <div class="ttc" id="st_8c_html_a144e9d9892980a6c762d7d19b55536e6"><div class="ttname"><a href="../../d4/d71/st_8c.html#a144e9d9892980a6c762d7d19b55536e6">get_values</a></div><div class="ttdeci">static st_index_t get_values(st_table *table, st_data_t *values, st_index_t size, int check, st_data_t never)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01142">st.c:1142</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_ab59eeb093d2ca63b5a6059a49499d48a"><div class="ttname"><a href="../../d4/d71/st_8c.html#ab59eeb093d2ca63b5a6059a49499d48a">st_locale_insensitive_strncasecmp</a></div><div class="ttdeci">int st_locale_insensitive_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#l01640">st.c:1640</a></div></div> <div class="ttc" id="structst__table_html_add6633b1d7a286e5273431a644eb1ea1"><div class="ttname"><a href="../../d0/ddd/structst__table.html#add6633b1d7a286e5273431a644eb1ea1">st_table::real_entries</a></div><div class="ttdeci">st_index_t real_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="structst__table_html_a82ed3f0c0cf62aacdeec296678726cdf"><div class="ttname"><a href="../../d0/ddd/structst__table.html#a82ed3f0c0cf62aacdeec296678726cdf">st_table::type</a></div><div class="ttdeci">const struct st_hash_type * type</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="lex_8c_html_a5541f85ce416df233cce93949f0eeeca"><div class="ttname"><a href="../../d3/deb/lex_8c.html#a5541f85ce416df233cce93949f0eeeca">hash</a></div><div class="ttdeci">static unsigned int hash(const char *str, unsigned int len)</div><div class="ttdef"><b>Definition:</b> <a href="../../d3/deb/lex_8c_source.html#l00056">lex.c:56</a></div></div> <div class="ttc" id="st_8h_html_a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69"><div class="ttname"><a href="../../dd/d24/st_8h.html#a0c6a172fd99de7928916e65034ed8b1fa362d37dd656ca6a08178514d3dd3bf69">ST_CHECK</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_a4c9a444f4aabb6c83a19c5afacbfdaf6"><div class="ttname"><a href="../../d4/d71/st_8c.html#a4c9a444f4aabb6c83a19c5afacbfdaf6">st_numcmp</a></div><div class="ttdeci">int st_numcmp(st_data_t x, st_data_t y)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01685">st.c:1685</a></div></div> <div class="ttc" id="st_8c_html_a311df13f4d458054df7d87ca22782ab2"><div class="ttname"><a href="../../d4/d71/st_8c.html#a311df13f4d458054df7d87ca22782ab2">ST_DEFAULT_INIT_TABLE_SIZE</a></div><div class="ttdeci">#define ST_DEFAULT_INIT_TABLE_SIZE</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00036">st.c:36</a></div></div> <div class="ttc" id="st_8c_html_a79bb3acd36ef8b09877de02e883ea92c"><div class="ttname"><a href="../../d4/d71/st_8c.html#a79bb3acd36ef8b09877de02e883ea92c">PACKED_BINS</a></div><div class="ttdeci">#define PACKED_BINS(table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00112">st.c:112</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_8c_html_aa9053dd461189a7780f276bfac62194c"><div class="ttname"><a href="../../d4/d71/st_8c.html#aa9053dd461189a7780f276bfac62194c">st_alloc_entry</a></div><div class="ttdeci">#define st_alloc_entry()</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00091">st.c:91</a></div></div> <div class="ttc" id="st_8c_html_a733a85dcefc9d237eb5cf9fb38798e42"><div class="ttname"><a href="../../d4/d71/st_8c.html#a733a85dcefc9d237eb5cf9fb38798e42">st_packed_entry</a></div><div class="ttdeci">struct st_packed_entry st_packed_entry</div></div> <div class="ttc" id="st_8c_html_a93394fd99c5fa4fbcce2be9717abee45"><div class="ttname"><a href="../../d4/d71/st_8c.html#a93394fd99c5fa4fbcce2be9717abee45">st_free_table</a></div><div class="ttdeci">void st_free_table(st_table *table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00334">st.c:334</a></div></div> <div class="ttc" id="st_8c_html_ae0b961792c432d4637ada06390832cb7"><div class="ttname"><a href="../../d4/d71/st_8c.html#ae0b961792c432d4637ada06390832cb7">bins</a></div><div class="ttdeci">#define bins</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00106">st.c:106</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#l01665">st.c:1665</a></div></div> <div class="ttc" id="st_8c_html_a9c7d882a34165813cbf64b5fd68b8570"><div class="ttname"><a href="../../d4/d71/st_8c.html#a9c7d882a34165813cbf64b5fd68b8570">st_memsize</a></div><div class="ttdeci">size_t st_memsize(const st_table *table)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00342">st.c:342</a></div></div> <div class="ttc" id="st_8c_html_a3b3d5a648505e3a2db3d4d4504b13c0e"><div class="ttname"><a href="../../d4/d71/st_8c.html#a3b3d5a648505e3a2db3d4d4504b13c0e">FOUND_ENTRY</a></div><div class="ttdeci">#define FOUND_ENTRY</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00374">st.c:374</a></div></div> <div class="ttc" id="__sdbm_8c_html_a070d2ce7b6bb7e5c05602aa8c308d0c4"><div class="ttname"><a href="../../d4/db0/__sdbm_8c.html#a070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a></div><div class="ttdeci">#define NULL</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/db0/__sdbm_8c_source.html#l00102">_sdbm.c:102</a></div></div> <div class="ttc" id="st_8c_html_a72b493fcb3ac68760a725d058f1cb5d3"><div class="ttname"><a href="../../d4/d71/st_8c.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#l01562">st.c:1562</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#l00089">st.h:89</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#l00085">st.h:85</a></div></div> <div class="ttc" id="st_8h_html_ab68dfde3b434381a536b6909c519e535"><div class="ttname"><a href="../../dd/d24/st_8h.html#ab68dfde3b434381a536b6909c519e535">st_update_callback_func</a></div><div class="ttdeci">int st_update_callback_func(st_data_t *key, st_data_t *value, st_data_t arg, int existing)</div><div class="ttdef"><b>Definition:</b> <a href="../../dd/d24/st_8h_source.html#l00117">st.h:117</a></div></div> <div class="ttc" id="st_8c_html_a9b0fdfc1b68819f2d666f74187f90b4a"><div class="ttname"><a href="../../d4/d71/st_8c.html#a9b0fdfc1b68819f2d666f74187f90b4a">st_init_table</a></div><div class="ttdeci">st_table * st_init_table(const struct st_hash_type *type)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00266">st.c:266</a></div></div> <div class="ttc" id="st_8c_html_a1c28169fac175cddf6f5cea1c7056970"><div class="ttname"><a href="../../d4/d71/st_8c.html#a1c28169fac175cddf6f5cea1c7056970">remove_entry</a></div><div class="ttdeci">static void remove_entry(st_table *table, st_table_entry *ptr)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00712">st.c:712</a></div></div> <div class="ttc" id="st_8c_html_a966180fce1e2e11911a57c9abae6a39b"><div class="ttname"><a href="../../d4/d71/st_8c.html#a966180fce1e2e11911a57c9abae6a39b">st_keys</a></div><div class="ttdeci">st_index_t st_keys(st_table *table, st_data_t *keys, st_index_t size)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l01130">st.c:1130</a></div></div> <div class="ttc" id="st_8c_html_a8a0fa825221e5025911fd93c6c30f3dd"><div class="ttname"><a href="../../d4/d71/st_8c.html#a8a0fa825221e5025911fd93c6c30f3dd">st_init_numtable_with_size</a></div><div class="ttdeci">st_table * st_init_numtable_with_size(st_index_t size)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00278">st.c:278</a></div></div> <div class="ttc" id="st_8c_html_aafd826a123a41fd03a9c88842387a821"><div class="ttname"><a href="../../d4/d71/st_8c.html#aafd826a123a41fd03a9c88842387a821">COLLISION</a></div><div class="ttdeci">#define COLLISION</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00373">st.c:373</a></div></div> <div class="ttc" id="st_8c_html_a438ae9ef62bab55aac6d75766e76d553"><div class="ttname"><a href="../../d4/d71/st_8c.html#a438ae9ef62bab55aac6d75766e76d553">PACKED_ENT</a></div><div class="ttdeci">#define PACKED_ENT(table, i)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00113">st.c:113</a></div></div> <div class="ttc" id="st_8c_html_a068ebca65df8733df9e368b4d6dd82ca"><div class="ttname"><a href="../../d4/d71/st_8c.html#a068ebca65df8733df9e368b4d6dd82ca">st_insert</a></div><div class="ttdeci">int st_insert(register st_table *table, register st_data_t key, st_data_t value)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00564">st.c:564</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#l00083">st.c:83</a></div></div> <div class="ttc" id="st_8c_html_ab0f310ebc69f2456e8608a505662e139"><div class="ttname"><a href="../../d4/d71/st_8c.html#ab0f310ebc69f2456e8608a505662e139">PKEY_SET</a></div><div class="ttdeci">#define PKEY_SET(table, i, v)</div><div class="ttdef"><b>Definition:</b> <a href="../../d4/d71/st_8c_source.html#l00117">st.c:117</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.14 </small></address> </body> </html>