You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

linkhash_8h.html 50 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  6. <meta name="generator" content="Doxygen 1.8.8"/>
  7. <title>json-c: linkhash.h File Reference</title>
  8. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  9. <script type="text/javascript" src="jquery.js"></script>
  10. <script type="text/javascript" src="dynsections.js"></script>
  11. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  12. </head>
  13. <body>
  14. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  15. <div id="titlearea">
  16. <table cellspacing="0" cellpadding="0">
  17. <tbody>
  18. <tr style="height: 56px;">
  19. <td style="padding-left: 0.5em;">
  20. <div id="projectname">json-c
  21. &#160;<span id="projectnumber">0.13.1</span>
  22. </div>
  23. </td>
  24. </tr>
  25. </tbody>
  26. </table>
  27. </div>
  28. <!-- end header part -->
  29. <!-- Generated by Doxygen 1.8.8 -->
  30. <div id="navrow1" class="tabs">
  31. <ul class="tablist">
  32. <li><a href="index.html"><span>Main&#160;Page</span></a></li>
  33. <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
  34. <li><a href="annotated.html"><span>Data&#160;Structures</span></a></li>
  35. <li class="current"><a href="files.html"><span>Files</span></a></li>
  36. </ul>
  37. </div>
  38. <div id="navrow2" class="tabs2">
  39. <ul class="tablist">
  40. <li><a href="files.html"><span>File&#160;List</span></a></li>
  41. <li><a href="globals.html"><span>Globals</span></a></li>
  42. </ul>
  43. </div>
  44. </div><!-- top -->
  45. <div class="header">
  46. <div class="summary">
  47. <a href="#nested-classes">Data Structures</a> &#124;
  48. <a href="#define-members">Macros</a> &#124;
  49. <a href="#typedef-members">Typedefs</a> &#124;
  50. <a href="#func-members">Functions</a> </div>
  51. <div class="headertitle">
  52. <div class="title">linkhash.h File Reference</div> </div>
  53. </div><!--header-->
  54. <div class="contents">
  55. <p>Internal methods for working with json_type_object objects. Although this is exposed by the <a class="el" href="json__object_8h.html#a2caa52ae1863bd073444f3737138a4db">json_object_get_object()</a> function and within the <a class="el" href="structjson__object__iter.html">json_object_iter</a> type, it is not recommended for direct use.
  56. <a href="#details">More...</a></p>
  57. <table class="memberdecls">
  58. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="nested-classes"></a>
  59. Data Structures</h2></td></tr>
  60. <tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structlh__entry.html">lh_entry</a></td></tr>
  61. <tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
  62. <tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structlh__table.html">lh_table</a></td></tr>
  63. <tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
  64. </table><table class="memberdecls">
  65. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="define-members"></a>
  66. Macros</h2></td></tr>
  67. <tr class="memitem:a032f1bd115df254dda325437203ce5fb"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a032f1bd115df254dda325437203ce5fb">LH_PRIME</a>&#160;&#160;&#160;0x9e370001UL</td></tr>
  68. <tr class="separator:a032f1bd115df254dda325437203ce5fb"><td class="memSeparator" colspan="2">&#160;</td></tr>
  69. <tr class="memitem:a66b61772c29d85eb52b697e0b0dc0aaf"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a66b61772c29d85eb52b697e0b0dc0aaf">LH_LOAD_FACTOR</a>&#160;&#160;&#160;0.66</td></tr>
  70. <tr class="separator:a66b61772c29d85eb52b697e0b0dc0aaf"><td class="memSeparator" colspan="2">&#160;</td></tr>
  71. <tr class="memitem:a93fad7f8ae44575dc89c9567859972d2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a93fad7f8ae44575dc89c9567859972d2">LH_EMPTY</a>&#160;&#160;&#160;(void*)-1</td></tr>
  72. <tr class="separator:a93fad7f8ae44575dc89c9567859972d2"><td class="memSeparator" colspan="2">&#160;</td></tr>
  73. <tr class="memitem:ac69428f2de0a6fb080b6fb373d506aa7"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#ac69428f2de0a6fb080b6fb373d506aa7">LH_FREED</a>&#160;&#160;&#160;(void*)-2</td></tr>
  74. <tr class="separator:ac69428f2de0a6fb080b6fb373d506aa7"><td class="memSeparator" colspan="2">&#160;</td></tr>
  75. <tr class="memitem:ac32e80138c5be6dd9b0483a9cbcc8799"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#ac32e80138c5be6dd9b0483a9cbcc8799">JSON_C_STR_HASH_DFLT</a>&#160;&#160;&#160;0</td></tr>
  76. <tr class="separator:ac32e80138c5be6dd9b0483a9cbcc8799"><td class="memSeparator" colspan="2">&#160;</td></tr>
  77. <tr class="memitem:a62316f34fd42941b97a8e9a6b6e68faa"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a62316f34fd42941b97a8e9a6b6e68faa">JSON_C_STR_HASH_PERLLIKE</a>&#160;&#160;&#160;1</td></tr>
  78. <tr class="separator:a62316f34fd42941b97a8e9a6b6e68faa"><td class="memSeparator" colspan="2">&#160;</td></tr>
  79. <tr class="memitem:ad7dd67da915065dce2c6f44cb03e2d82"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#ad7dd67da915065dce2c6f44cb03e2d82">lh_foreach</a>(table, entry)&#160;&#160;&#160;for(entry = table-&gt;head; entry; entry = entry-&gt;next)</td></tr>
  80. <tr class="separator:ad7dd67da915065dce2c6f44cb03e2d82"><td class="memSeparator" colspan="2">&#160;</td></tr>
  81. <tr class="memitem:abcbb0df08b4976d0649b826b6bacfca1"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#abcbb0df08b4976d0649b826b6bacfca1">lh_foreach_safe</a>(table, entry, tmp)&#160;&#160;&#160;for(entry = table-&gt;head; entry &amp;&amp; ((tmp = entry-&gt;next) || 1); entry = tmp)</td></tr>
  82. <tr class="separator:abcbb0df08b4976d0649b826b6bacfca1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  83. <tr class="memitem:a77c5cddef96e6f1ab036ccf911783456"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a77c5cddef96e6f1ab036ccf911783456">_LH_INLINE</a>&#160;&#160;&#160;inline</td></tr>
  84. <tr class="separator:a77c5cddef96e6f1ab036ccf911783456"><td class="memSeparator" colspan="2">&#160;</td></tr>
  85. <tr class="memitem:afb856ed4a9bcfd090dde5151fa3ad9ae"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#afb856ed4a9bcfd090dde5151fa3ad9ae">_LH_UNCONST</a>(a)&#160;&#160;&#160;((void *)(uintptr_t)(const void *)(a))</td></tr>
  86. <tr class="separator:afb856ed4a9bcfd090dde5151fa3ad9ae"><td class="memSeparator" colspan="2">&#160;</td></tr>
  87. <tr class="memitem:a7579ce28b8366fc9b8656f14270aa3aa"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a7579ce28b8366fc9b8656f14270aa3aa">lh_entry_k</a>(entry)&#160;&#160;&#160;<a class="el" href="linkhash_8h.html#afb856ed4a9bcfd090dde5151fa3ad9ae">_LH_UNCONST</a>((entry)-&gt;k)</td></tr>
  88. <tr class="separator:a7579ce28b8366fc9b8656f14270aa3aa"><td class="memSeparator" colspan="2">&#160;</td></tr>
  89. <tr class="memitem:a0d4052ccfd8c5d351a9c1d3ba07671b3"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a0d4052ccfd8c5d351a9c1d3ba07671b3">lh_entry_v</a>(entry)&#160;&#160;&#160;<a class="el" href="linkhash_8h.html#afb856ed4a9bcfd090dde5151fa3ad9ae">_LH_UNCONST</a>((entry)-&gt;v)</td></tr>
  90. <tr class="separator:a0d4052ccfd8c5d351a9c1d3ba07671b3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  91. </table><table class="memberdecls">
  92. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="typedef-members"></a>
  93. Typedefs</h2></td></tr>
  94. <tr class="memitem:a671553d0ee3c2a123190ba0f8ed2b635"><td class="memItemLeft" align="right" valign="top">typedef void(&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> )(struct <a class="el" href="structlh__entry.html">lh_entry</a> *e)</td></tr>
  95. <tr class="separator:a671553d0ee3c2a123190ba0f8ed2b635"><td class="memSeparator" colspan="2">&#160;</td></tr>
  96. <tr class="memitem:a38bae27995dcfb6ee3fb109a9be229b2"><td class="memItemLeft" align="right" valign="top">typedef unsigned long(&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a38bae27995dcfb6ee3fb109a9be229b2">lh_hash_fn</a> )(const void *k)</td></tr>
  97. <tr class="separator:a38bae27995dcfb6ee3fb109a9be229b2"><td class="memSeparator" colspan="2">&#160;</td></tr>
  98. <tr class="memitem:a91fd85fc81b0c7c83c62f00e84729091"><td class="memItemLeft" align="right" valign="top">typedef int(&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a91fd85fc81b0c7c83c62f00e84729091">lh_equal_fn</a> )(const void *k1, const void *k2)</td></tr>
  99. <tr class="separator:a91fd85fc81b0c7c83c62f00e84729091"><td class="memSeparator" colspan="2">&#160;</td></tr>
  100. <tr class="memitem:a766e90057496fc6712d6be0da180a21f"><td class="memItemLeft" align="right" valign="top">typedef struct <a class="el" href="structlh__table.html">lh_table</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a766e90057496fc6712d6be0da180a21f">lh_table</a></td></tr>
  101. <tr class="separator:a766e90057496fc6712d6be0da180a21f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  102. </table><table class="memberdecls">
  103. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
  104. Functions</h2></td></tr>
  105. <tr class="memitem:ac8e1d61af44d9c0824d8c7980385bcd3"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#ac8e1d61af44d9c0824d8c7980385bcd3">json_global_set_string_hash</a> (const int h)</td></tr>
  106. <tr class="separator:ac8e1d61af44d9c0824d8c7980385bcd3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  107. <tr class="memitem:a9c4f8a71dbe4d3390d9f7adb331beb0e"><td class="memItemLeft" align="right" valign="top">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a9c4f8a71dbe4d3390d9f7adb331beb0e">lh_table_new</a> (int size, <a class="el" href="linkhash_8h.html#a671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *free_fn, <a class="el" href="linkhash_8h.html#a38bae27995dcfb6ee3fb109a9be229b2">lh_hash_fn</a> *hash_fn, <a class="el" href="linkhash_8h.html#a91fd85fc81b0c7c83c62f00e84729091">lh_equal_fn</a> *equal_fn)</td></tr>
  108. <tr class="separator:a9c4f8a71dbe4d3390d9f7adb331beb0e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  109. <tr class="memitem:a6bf630754affe92612639542a6c49c3f"><td class="memItemLeft" align="right" valign="top">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a6bf630754affe92612639542a6c49c3f">lh_kchar_table_new</a> (int size, <a class="el" href="linkhash_8h.html#a671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *free_fn)</td></tr>
  110. <tr class="separator:a6bf630754affe92612639542a6c49c3f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  111. <tr class="memitem:af8108563b961dbf5471fe2c0e51f40a5"><td class="memItemLeft" align="right" valign="top">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#af8108563b961dbf5471fe2c0e51f40a5">lh_kptr_table_new</a> (int size, <a class="el" href="linkhash_8h.html#a671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *free_fn)</td></tr>
  112. <tr class="separator:af8108563b961dbf5471fe2c0e51f40a5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  113. <tr class="memitem:a81653acf740cf8c9fe672e6cd16df0cf"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a81653acf740cf8c9fe672e6cd16df0cf">lh_table_free</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t)</td></tr>
  114. <tr class="separator:a81653acf740cf8c9fe672e6cd16df0cf"><td class="memSeparator" colspan="2">&#160;</td></tr>
  115. <tr class="memitem:a86c0cd547be1e2c2486a73bd58e1352c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a86c0cd547be1e2c2486a73bd58e1352c">lh_table_insert</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k, const void *v)</td></tr>
  116. <tr class="separator:a86c0cd547be1e2c2486a73bd58e1352c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  117. <tr class="memitem:a4558a9347a422e03a15b0b7a29b82dc3"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a4558a9347a422e03a15b0b7a29b82dc3">lh_table_insert_w_hash</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k, const void *v, const unsigned long h, const unsigned opts)</td></tr>
  118. <tr class="separator:a4558a9347a422e03a15b0b7a29b82dc3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  119. <tr class="memitem:ad3b6ca2d967a6c3021ee6c39e014a918"><td class="memItemLeft" align="right" valign="top">struct <a class="el" href="structlh__entry.html">lh_entry</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#ad3b6ca2d967a6c3021ee6c39e014a918">lh_table_lookup_entry</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k)</td></tr>
  120. <tr class="separator:ad3b6ca2d967a6c3021ee6c39e014a918"><td class="memSeparator" colspan="2">&#160;</td></tr>
  121. <tr class="memitem:a59ecaf34ef59280952f4459b2de63677"><td class="memItemLeft" align="right" valign="top">struct <a class="el" href="structlh__entry.html">lh_entry</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a59ecaf34ef59280952f4459b2de63677">lh_table_lookup_entry_w_hash</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k, const unsigned long h)</td></tr>
  122. <tr class="separator:a59ecaf34ef59280952f4459b2de63677"><td class="memSeparator" colspan="2">&#160;</td></tr>
  123. <tr class="memitem:a49c27f18a174eaf126d1b7953df13cb1"><td class="memItemLeft" align="right" valign="top">const void *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a49c27f18a174eaf126d1b7953df13cb1">lh_table_lookup</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k)</td></tr>
  124. <tr class="separator:a49c27f18a174eaf126d1b7953df13cb1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  125. <tr class="memitem:a81c270bb0dd9d5c8a3e7ae20bc4d67f3"><td class="memItemLeft" align="right" valign="top"><a class="el" href="json__object_8h.html#a81f02022906fafc71eb9197049f07f73">json_bool</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a81c270bb0dd9d5c8a3e7ae20bc4d67f3">lh_table_lookup_ex</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k, void **v)</td></tr>
  126. <tr class="separator:a81c270bb0dd9d5c8a3e7ae20bc4d67f3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  127. <tr class="memitem:ae5885a71c3457190fb1dc2d6e20dde3b"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#ae5885a71c3457190fb1dc2d6e20dde3b">lh_table_delete_entry</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, struct <a class="el" href="structlh__entry.html">lh_entry</a> *e)</td></tr>
  128. <tr class="separator:ae5885a71c3457190fb1dc2d6e20dde3b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  129. <tr class="memitem:a2fed2c78f70d229edb2d00775ffe593c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a2fed2c78f70d229edb2d00775ffe593c">lh_table_delete</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k)</td></tr>
  130. <tr class="separator:a2fed2c78f70d229edb2d00775ffe593c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  131. <tr class="memitem:ac9ba631c91fe80fb905f04c7cd526f2b"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#ac9ba631c91fe80fb905f04c7cd526f2b">lh_table_length</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t)</td></tr>
  132. <tr class="separator:ac9ba631c91fe80fb905f04c7cd526f2b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  133. <tr class="memitem:a1294160fa0e80cee04cd745a401f43a4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a1294160fa0e80cee04cd745a401f43a4">lh_abort</a> (const char *msg,...)</td></tr>
  134. <tr class="separator:a1294160fa0e80cee04cd745a401f43a4"><td class="memSeparator" colspan="2">&#160;</td></tr>
  135. <tr class="memitem:a30c8414e31aeee7669acc938116d933f"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#a30c8414e31aeee7669acc938116d933f">lh_table_resize</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, int new_size)</td></tr>
  136. <tr class="separator:a30c8414e31aeee7669acc938116d933f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  137. </table>
  138. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  139. <div class="textblock"><p>Internal methods for working with json_type_object objects. Although this is exposed by the <a class="el" href="json__object_8h.html#a2caa52ae1863bd073444f3737138a4db">json_object_get_object()</a> function and within the <a class="el" href="structjson__object__iter.html">json_object_iter</a> type, it is not recommended for direct use. </p>
  140. </div><h2 class="groupheader">Macro Definition Documentation</h2>
  141. <a class="anchor" id="a77c5cddef96e6f1ab036ccf911783456"></a>
  142. <div class="memitem">
  143. <div class="memproto">
  144. <table class="memname">
  145. <tr>
  146. <td class="memname">#define _LH_INLINE&#160;&#160;&#160;inline</td>
  147. </tr>
  148. </table>
  149. </div><div class="memdoc">
  150. <dl class="deprecated"><dt><b><a class="el" href="deprecated.html#_deprecated000009">Deprecated:</a></b></dt><dd>Don't use this outside of <a class="el" href="linkhash_8h.html" title="Internal methods for working with json_type_object objects. Although this is exposed by the json_obje...">linkhash.h</a>: </dd></dl>
  151. </div>
  152. </div>
  153. <a class="anchor" id="afb856ed4a9bcfd090dde5151fa3ad9ae"></a>
  154. <div class="memitem">
  155. <div class="memproto">
  156. <table class="memname">
  157. <tr>
  158. <td class="memname">#define _LH_UNCONST</td>
  159. <td>(</td>
  160. <td class="paramtype">&#160;</td>
  161. <td class="paramname">a</td><td>)</td>
  162. <td>&#160;&#160;&#160;((void *)(uintptr_t)(const void *)(a))</td>
  163. </tr>
  164. </table>
  165. </div><div class="memdoc">
  166. <dl class="deprecated"><dt><b><a class="el" href="deprecated.html#_deprecated000010">Deprecated:</a></b></dt><dd>Don't use this outside of <a class="el" href="linkhash_8h.html" title="Internal methods for working with json_type_object objects. Although this is exposed by the json_obje...">linkhash.h</a>: </dd></dl>
  167. </div>
  168. </div>
  169. <a class="anchor" id="ac32e80138c5be6dd9b0483a9cbcc8799"></a>
  170. <div class="memitem">
  171. <div class="memproto">
  172. <table class="memname">
  173. <tr>
  174. <td class="memname">#define JSON_C_STR_HASH_DFLT&#160;&#160;&#160;0</td>
  175. </tr>
  176. </table>
  177. </div><div class="memdoc">
  178. <p>default string hash function </p>
  179. </div>
  180. </div>
  181. <a class="anchor" id="a62316f34fd42941b97a8e9a6b6e68faa"></a>
  182. <div class="memitem">
  183. <div class="memproto">
  184. <table class="memname">
  185. <tr>
  186. <td class="memname">#define JSON_C_STR_HASH_PERLLIKE&#160;&#160;&#160;1</td>
  187. </tr>
  188. </table>
  189. </div><div class="memdoc">
  190. <p>perl-like string hash function </p>
  191. </div>
  192. </div>
  193. <a class="anchor" id="a93fad7f8ae44575dc89c9567859972d2"></a>
  194. <div class="memitem">
  195. <div class="memproto">
  196. <table class="memname">
  197. <tr>
  198. <td class="memname">#define LH_EMPTY&#160;&#160;&#160;(void*)-1</td>
  199. </tr>
  200. </table>
  201. </div><div class="memdoc">
  202. <p>sentinel pointer value for empty slots </p>
  203. </div>
  204. </div>
  205. <a class="anchor" id="a7579ce28b8366fc9b8656f14270aa3aa"></a>
  206. <div class="memitem">
  207. <div class="memproto">
  208. <table class="memname">
  209. <tr>
  210. <td class="memname">#define lh_entry_k</td>
  211. <td>(</td>
  212. <td class="paramtype">&#160;</td>
  213. <td class="paramname">entry</td><td>)</td>
  214. <td>&#160;&#160;&#160;<a class="el" href="linkhash_8h.html#afb856ed4a9bcfd090dde5151fa3ad9ae">_LH_UNCONST</a>((entry)-&gt;k)</td>
  215. </tr>
  216. </table>
  217. </div><div class="memdoc">
  218. <p>Return a non-const version of <a class="el" href="structlh__entry.html#a79d9f1ef0dc444e17105aaeaf167e22c">lh_entry.k</a>.</p>
  219. <p><a class="el" href="structlh__entry.html#a79d9f1ef0dc444e17105aaeaf167e22c">lh_entry.k</a> is const to indicate and help ensure that linkhash itself doesn't modify it, but callers are allowed to do what they want with it. See also <a class="el" href="structlh__entry.html#a14f40cc124c32b03f81151ae7934d2e7">lh_entry.k_is_constant</a> </p>
  220. </div>
  221. </div>
  222. <a class="anchor" id="a0d4052ccfd8c5d351a9c1d3ba07671b3"></a>
  223. <div class="memitem">
  224. <div class="memproto">
  225. <table class="memname">
  226. <tr>
  227. <td class="memname">#define lh_entry_v</td>
  228. <td>(</td>
  229. <td class="paramtype">&#160;</td>
  230. <td class="paramname">entry</td><td>)</td>
  231. <td>&#160;&#160;&#160;<a class="el" href="linkhash_8h.html#afb856ed4a9bcfd090dde5151fa3ad9ae">_LH_UNCONST</a>((entry)-&gt;v)</td>
  232. </tr>
  233. </table>
  234. </div><div class="memdoc">
  235. <p>Return a non-const version of <a class="el" href="structlh__entry.html#a1b676732ab2ad3eeaedf6ec60a6a0835">lh_entry.v</a>.</p>
  236. <p>v is const to indicate and help ensure that linkhash itself doesn't modify it, but callers are allowed to do what they want with it. </p>
  237. </div>
  238. </div>
  239. <a class="anchor" id="ad7dd67da915065dce2c6f44cb03e2d82"></a>
  240. <div class="memitem">
  241. <div class="memproto">
  242. <table class="memname">
  243. <tr>
  244. <td class="memname">#define lh_foreach</td>
  245. <td>(</td>
  246. <td class="paramtype">&#160;</td>
  247. <td class="paramname">table, </td>
  248. </tr>
  249. <tr>
  250. <td class="paramkey"></td>
  251. <td></td>
  252. <td class="paramtype">&#160;</td>
  253. <td class="paramname">entry&#160;</td>
  254. </tr>
  255. <tr>
  256. <td></td>
  257. <td>)</td>
  258. <td></td><td>&#160;&#160;&#160;for(entry = table-&gt;head; entry; entry = entry-&gt;next)</td>
  259. </tr>
  260. </table>
  261. </div><div class="memdoc">
  262. <p>Convenience list iterator. </p>
  263. </div>
  264. </div>
  265. <a class="anchor" id="abcbb0df08b4976d0649b826b6bacfca1"></a>
  266. <div class="memitem">
  267. <div class="memproto">
  268. <table class="memname">
  269. <tr>
  270. <td class="memname">#define lh_foreach_safe</td>
  271. <td>(</td>
  272. <td class="paramtype">&#160;</td>
  273. <td class="paramname">table, </td>
  274. </tr>
  275. <tr>
  276. <td class="paramkey"></td>
  277. <td></td>
  278. <td class="paramtype">&#160;</td>
  279. <td class="paramname">entry, </td>
  280. </tr>
  281. <tr>
  282. <td class="paramkey"></td>
  283. <td></td>
  284. <td class="paramtype">&#160;</td>
  285. <td class="paramname">tmp&#160;</td>
  286. </tr>
  287. <tr>
  288. <td></td>
  289. <td>)</td>
  290. <td></td><td>&#160;&#160;&#160;for(entry = table-&gt;head; entry &amp;&amp; ((tmp = entry-&gt;next) || 1); entry = tmp)</td>
  291. </tr>
  292. </table>
  293. </div><div class="memdoc">
  294. <p>lh_foreach_safe allows calling of deletion routine while iterating.</p>
  295. <dl class="params"><dt>Parameters</dt><dd>
  296. <table class="params">
  297. <tr><td class="paramname">table</td><td>a struct <a class="el" href="structlh__table.html">lh_table</a> * to iterate over </td></tr>
  298. <tr><td class="paramname">entry</td><td>a struct <a class="el" href="structlh__entry.html">lh_entry</a> * variable to hold each element </td></tr>
  299. <tr><td class="paramname">tmp</td><td>a struct <a class="el" href="structlh__entry.html">lh_entry</a> * variable to hold a temporary pointer to the next element </td></tr>
  300. </table>
  301. </dd>
  302. </dl>
  303. </div>
  304. </div>
  305. <a class="anchor" id="ac69428f2de0a6fb080b6fb373d506aa7"></a>
  306. <div class="memitem">
  307. <div class="memproto">
  308. <table class="memname">
  309. <tr>
  310. <td class="memname">#define LH_FREED&#160;&#160;&#160;(void*)-2</td>
  311. </tr>
  312. </table>
  313. </div><div class="memdoc">
  314. <p>sentinel pointer value for freed slots </p>
  315. </div>
  316. </div>
  317. <a class="anchor" id="a66b61772c29d85eb52b697e0b0dc0aaf"></a>
  318. <div class="memitem">
  319. <div class="memproto">
  320. <table class="memname">
  321. <tr>
  322. <td class="memname">#define LH_LOAD_FACTOR&#160;&#160;&#160;0.66</td>
  323. </tr>
  324. </table>
  325. </div><div class="memdoc">
  326. <p>The fraction of filled hash buckets until an insert will cause the table to be resized. This can range from just above 0 up to 1.0. </p>
  327. </div>
  328. </div>
  329. <a class="anchor" id="a032f1bd115df254dda325437203ce5fb"></a>
  330. <div class="memitem">
  331. <div class="memproto">
  332. <table class="memname">
  333. <tr>
  334. <td class="memname">#define LH_PRIME&#160;&#160;&#160;0x9e370001UL</td>
  335. </tr>
  336. </table>
  337. </div><div class="memdoc">
  338. <p>golden prime used in hash functions </p>
  339. </div>
  340. </div>
  341. <h2 class="groupheader">Typedef Documentation</h2>
  342. <a class="anchor" id="a671553d0ee3c2a123190ba0f8ed2b635"></a>
  343. <div class="memitem">
  344. <div class="memproto">
  345. <table class="memname">
  346. <tr>
  347. <td class="memname">typedef void( lh_entry_free_fn)(struct <a class="el" href="structlh__entry.html">lh_entry</a> *e)</td>
  348. </tr>
  349. </table>
  350. </div><div class="memdoc">
  351. <p>callback function prototypes </p>
  352. </div>
  353. </div>
  354. <a class="anchor" id="a91fd85fc81b0c7c83c62f00e84729091"></a>
  355. <div class="memitem">
  356. <div class="memproto">
  357. <table class="memname">
  358. <tr>
  359. <td class="memname">typedef int( lh_equal_fn)(const void *k1, const void *k2)</td>
  360. </tr>
  361. </table>
  362. </div><div class="memdoc">
  363. <p>callback function prototypes </p>
  364. </div>
  365. </div>
  366. <a class="anchor" id="a38bae27995dcfb6ee3fb109a9be229b2"></a>
  367. <div class="memitem">
  368. <div class="memproto">
  369. <table class="memname">
  370. <tr>
  371. <td class="memname">typedef unsigned long( lh_hash_fn)(const void *k)</td>
  372. </tr>
  373. </table>
  374. </div><div class="memdoc">
  375. <p>callback function prototypes </p>
  376. </div>
  377. </div>
  378. <a class="anchor" id="a766e90057496fc6712d6be0da180a21f"></a>
  379. <div class="memitem">
  380. <div class="memproto">
  381. <table class="memname">
  382. <tr>
  383. <td class="memname">typedef struct <a class="el" href="structlh__table.html">lh_table</a> <a class="el" href="structlh__table.html">lh_table</a></td>
  384. </tr>
  385. </table>
  386. </div><div class="memdoc">
  387. </div>
  388. </div>
  389. <h2 class="groupheader">Function Documentation</h2>
  390. <a class="anchor" id="ac8e1d61af44d9c0824d8c7980385bcd3"></a>
  391. <div class="memitem">
  392. <div class="memproto">
  393. <table class="memname">
  394. <tr>
  395. <td class="memname">int json_global_set_string_hash </td>
  396. <td>(</td>
  397. <td class="paramtype">const int&#160;</td>
  398. <td class="paramname"><em>h</em></td><td>)</td>
  399. <td></td>
  400. </tr>
  401. </table>
  402. </div><div class="memdoc">
  403. <p>This function sets the hash function to be used for strings. Must be one of the JSON_C_STR_HASH_* values. </p><dl class="section return"><dt>Returns</dt><dd>0 - ok, -1 if parameter was invalid </dd></dl>
  404. </div>
  405. </div>
  406. <a class="anchor" id="a1294160fa0e80cee04cd745a401f43a4"></a>
  407. <div class="memitem">
  408. <div class="memproto">
  409. <table class="memname">
  410. <tr>
  411. <td class="memname">void lh_abort </td>
  412. <td>(</td>
  413. <td class="paramtype">const char *&#160;</td>
  414. <td class="paramname"><em>msg</em>, </td>
  415. </tr>
  416. <tr>
  417. <td class="paramkey"></td>
  418. <td></td>
  419. <td class="paramtype">&#160;</td>
  420. <td class="paramname"><em>...</em>&#160;</td>
  421. </tr>
  422. <tr>
  423. <td></td>
  424. <td>)</td>
  425. <td></td><td></td>
  426. </tr>
  427. </table>
  428. </div><div class="memdoc">
  429. <p>Prints a message to <code>stdout</code>, then exits the program with an exit code of <code>1</code>.</p>
  430. <dl class="params"><dt>Parameters</dt><dd>
  431. <table class="params">
  432. <tr><td class="paramname">msg</td><td>Message format string, like for <code>printf</code>. </td></tr>
  433. <tr><td class="paramname">...</td><td>Format args.</td></tr>
  434. </table>
  435. </dd>
  436. </dl>
  437. <dl class="deprecated"><dt><b><a class="el" href="deprecated.html#_deprecated000008">Deprecated:</a></b></dt><dd>Since it is not a good idea to exit the entire program because of an internal library failure, json-c will no longer use this function internally. However, because its interface is public, it will remain part of the API on the off chance of legacy software using it externally. </dd></dl>
  438. </div>
  439. </div>
  440. <a class="anchor" id="a6bf630754affe92612639542a6c49c3f"></a>
  441. <div class="memitem">
  442. <div class="memproto">
  443. <table class="memname">
  444. <tr>
  445. <td class="memname">struct <a class="el" href="structlh__table.html">lh_table</a>* lh_kchar_table_new </td>
  446. <td>(</td>
  447. <td class="paramtype">int&#160;</td>
  448. <td class="paramname"><em>size</em>, </td>
  449. </tr>
  450. <tr>
  451. <td class="paramkey"></td>
  452. <td></td>
  453. <td class="paramtype"><a class="el" href="linkhash_8h.html#a671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *&#160;</td>
  454. <td class="paramname"><em>free_fn</em>&#160;</td>
  455. </tr>
  456. <tr>
  457. <td></td>
  458. <td>)</td>
  459. <td></td><td></td>
  460. </tr>
  461. </table>
  462. </div><div class="memdoc">
  463. <p>Convenience function to create a new linkhash table with char keys.</p>
  464. <dl class="params"><dt>Parameters</dt><dd>
  465. <table class="params">
  466. <tr><td class="paramname">size</td><td>initial table size. </td></tr>
  467. <tr><td class="paramname">free_fn</td><td>callback function used to free memory for entries. </td></tr>
  468. </table>
  469. </dd>
  470. </dl>
  471. <dl class="section return"><dt>Returns</dt><dd>On success, a pointer to the new linkhash table is returned. On error, a null pointer is returned. </dd></dl>
  472. </div>
  473. </div>
  474. <a class="anchor" id="af8108563b961dbf5471fe2c0e51f40a5"></a>
  475. <div class="memitem">
  476. <div class="memproto">
  477. <table class="memname">
  478. <tr>
  479. <td class="memname">struct <a class="el" href="structlh__table.html">lh_table</a>* lh_kptr_table_new </td>
  480. <td>(</td>
  481. <td class="paramtype">int&#160;</td>
  482. <td class="paramname"><em>size</em>, </td>
  483. </tr>
  484. <tr>
  485. <td class="paramkey"></td>
  486. <td></td>
  487. <td class="paramtype"><a class="el" href="linkhash_8h.html#a671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *&#160;</td>
  488. <td class="paramname"><em>free_fn</em>&#160;</td>
  489. </tr>
  490. <tr>
  491. <td></td>
  492. <td>)</td>
  493. <td></td><td></td>
  494. </tr>
  495. </table>
  496. </div><div class="memdoc">
  497. <p>Convenience function to create a new linkhash table with ptr keys.</p>
  498. <dl class="params"><dt>Parameters</dt><dd>
  499. <table class="params">
  500. <tr><td class="paramname">size</td><td>initial table size. </td></tr>
  501. <tr><td class="paramname">free_fn</td><td>callback function used to free memory for entries. </td></tr>
  502. </table>
  503. </dd>
  504. </dl>
  505. <dl class="section return"><dt>Returns</dt><dd>On success, a pointer to the new linkhash table is returned. On error, a null pointer is returned. </dd></dl>
  506. </div>
  507. </div>
  508. <a class="anchor" id="a2fed2c78f70d229edb2d00775ffe593c"></a>
  509. <div class="memitem">
  510. <div class="memproto">
  511. <table class="memname">
  512. <tr>
  513. <td class="memname">int lh_table_delete </td>
  514. <td>(</td>
  515. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  516. <td class="paramname"><em>t</em>, </td>
  517. </tr>
  518. <tr>
  519. <td class="paramkey"></td>
  520. <td></td>
  521. <td class="paramtype">const void *&#160;</td>
  522. <td class="paramname"><em>k</em>&#160;</td>
  523. </tr>
  524. <tr>
  525. <td></td>
  526. <td>)</td>
  527. <td></td><td></td>
  528. </tr>
  529. </table>
  530. </div><div class="memdoc">
  531. <p>Delete a record from the table.</p>
  532. <p>If a callback free function is provided then it is called for the for the item being deleted. </p><dl class="params"><dt>Parameters</dt><dd>
  533. <table class="params">
  534. <tr><td class="paramname">t</td><td>the table to delete from. </td></tr>
  535. <tr><td class="paramname">k</td><td>a pointer to the key to delete. </td></tr>
  536. </table>
  537. </dd>
  538. </dl>
  539. <dl class="section return"><dt>Returns</dt><dd>0 if the item was deleted. </dd>
  540. <dd>
  541. -1 if it was not found. </dd></dl>
  542. </div>
  543. </div>
  544. <a class="anchor" id="ae5885a71c3457190fb1dc2d6e20dde3b"></a>
  545. <div class="memitem">
  546. <div class="memproto">
  547. <table class="memname">
  548. <tr>
  549. <td class="memname">int lh_table_delete_entry </td>
  550. <td>(</td>
  551. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  552. <td class="paramname"><em>t</em>, </td>
  553. </tr>
  554. <tr>
  555. <td class="paramkey"></td>
  556. <td></td>
  557. <td class="paramtype">struct <a class="el" href="structlh__entry.html">lh_entry</a> *&#160;</td>
  558. <td class="paramname"><em>e</em>&#160;</td>
  559. </tr>
  560. <tr>
  561. <td></td>
  562. <td>)</td>
  563. <td></td><td></td>
  564. </tr>
  565. </table>
  566. </div><div class="memdoc">
  567. <p>Delete a record from the table.</p>
  568. <p>If a callback free function is provided then it is called for the for the item being deleted. </p><dl class="params"><dt>Parameters</dt><dd>
  569. <table class="params">
  570. <tr><td class="paramname">t</td><td>the table to delete from. </td></tr>
  571. <tr><td class="paramname">e</td><td>a pointer to the entry to delete. </td></tr>
  572. </table>
  573. </dd>
  574. </dl>
  575. <dl class="section return"><dt>Returns</dt><dd>0 if the item was deleted. </dd>
  576. <dd>
  577. -1 if it was not found. </dd></dl>
  578. </div>
  579. </div>
  580. <a class="anchor" id="a81653acf740cf8c9fe672e6cd16df0cf"></a>
  581. <div class="memitem">
  582. <div class="memproto">
  583. <table class="memname">
  584. <tr>
  585. <td class="memname">void lh_table_free </td>
  586. <td>(</td>
  587. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  588. <td class="paramname"><em>t</em></td><td>)</td>
  589. <td></td>
  590. </tr>
  591. </table>
  592. </div><div class="memdoc">
  593. <p>Free a linkhash table.</p>
  594. <p>If a lh_entry_free_fn callback free function was provided then it is called for all entries in the table.</p>
  595. <dl class="params"><dt>Parameters</dt><dd>
  596. <table class="params">
  597. <tr><td class="paramname">t</td><td>table to free. </td></tr>
  598. </table>
  599. </dd>
  600. </dl>
  601. </div>
  602. </div>
  603. <a class="anchor" id="a86c0cd547be1e2c2486a73bd58e1352c"></a>
  604. <div class="memitem">
  605. <div class="memproto">
  606. <table class="memname">
  607. <tr>
  608. <td class="memname">int lh_table_insert </td>
  609. <td>(</td>
  610. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  611. <td class="paramname"><em>t</em>, </td>
  612. </tr>
  613. <tr>
  614. <td class="paramkey"></td>
  615. <td></td>
  616. <td class="paramtype">const void *&#160;</td>
  617. <td class="paramname"><em>k</em>, </td>
  618. </tr>
  619. <tr>
  620. <td class="paramkey"></td>
  621. <td></td>
  622. <td class="paramtype">const void *&#160;</td>
  623. <td class="paramname"><em>v</em>&#160;</td>
  624. </tr>
  625. <tr>
  626. <td></td>
  627. <td>)</td>
  628. <td></td><td></td>
  629. </tr>
  630. </table>
  631. </div><div class="memdoc">
  632. <p>Insert a record into the table.</p>
  633. <dl class="params"><dt>Parameters</dt><dd>
  634. <table class="params">
  635. <tr><td class="paramname">t</td><td>the table to insert into. </td></tr>
  636. <tr><td class="paramname">k</td><td>a pointer to the key to insert. </td></tr>
  637. <tr><td class="paramname">v</td><td>a pointer to the value to insert.</td></tr>
  638. </table>
  639. </dd>
  640. </dl>
  641. <dl class="section return"><dt>Returns</dt><dd>On success, <code>0</code> is returned. On error, a negative value is returned. </dd></dl>
  642. </div>
  643. </div>
  644. <a class="anchor" id="a4558a9347a422e03a15b0b7a29b82dc3"></a>
  645. <div class="memitem">
  646. <div class="memproto">
  647. <table class="memname">
  648. <tr>
  649. <td class="memname">int lh_table_insert_w_hash </td>
  650. <td>(</td>
  651. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  652. <td class="paramname"><em>t</em>, </td>
  653. </tr>
  654. <tr>
  655. <td class="paramkey"></td>
  656. <td></td>
  657. <td class="paramtype">const void *&#160;</td>
  658. <td class="paramname"><em>k</em>, </td>
  659. </tr>
  660. <tr>
  661. <td class="paramkey"></td>
  662. <td></td>
  663. <td class="paramtype">const void *&#160;</td>
  664. <td class="paramname"><em>v</em>, </td>
  665. </tr>
  666. <tr>
  667. <td class="paramkey"></td>
  668. <td></td>
  669. <td class="paramtype">const unsigned long&#160;</td>
  670. <td class="paramname"><em>h</em>, </td>
  671. </tr>
  672. <tr>
  673. <td class="paramkey"></td>
  674. <td></td>
  675. <td class="paramtype">const unsigned&#160;</td>
  676. <td class="paramname"><em>opts</em>&#160;</td>
  677. </tr>
  678. <tr>
  679. <td></td>
  680. <td>)</td>
  681. <td></td><td></td>
  682. </tr>
  683. </table>
  684. </div><div class="memdoc">
  685. <p>Insert a record into the table using a precalculated key hash.</p>
  686. <p>The hash h, which should be calculated with lh_get_hash() on k, is provided by the caller, to allow for optimization when multiple operations with the same key are known to be needed.</p>
  687. <dl class="params"><dt>Parameters</dt><dd>
  688. <table class="params">
  689. <tr><td class="paramname">t</td><td>the table to insert into. </td></tr>
  690. <tr><td class="paramname">k</td><td>a pointer to the key to insert. </td></tr>
  691. <tr><td class="paramname">v</td><td>a pointer to the value to insert. </td></tr>
  692. <tr><td class="paramname">h</td><td>hash value of the key to insert </td></tr>
  693. <tr><td class="paramname">opts</td><td>if set to JSON_C_OBJECT_KEY_IS_CONSTANT, sets <a class="el" href="structlh__entry.html#a14f40cc124c32b03f81151ae7934d2e7">lh_entry.k_is_constant</a> so t's free function knows to avoid freeing the key. </td></tr>
  694. </table>
  695. </dd>
  696. </dl>
  697. </div>
  698. </div>
  699. <a class="anchor" id="ac9ba631c91fe80fb905f04c7cd526f2b"></a>
  700. <div class="memitem">
  701. <div class="memproto">
  702. <table class="memname">
  703. <tr>
  704. <td class="memname">int lh_table_length </td>
  705. <td>(</td>
  706. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  707. <td class="paramname"><em>t</em></td><td>)</td>
  708. <td></td>
  709. </tr>
  710. </table>
  711. </div><div class="memdoc">
  712. </div>
  713. </div>
  714. <a class="anchor" id="a49c27f18a174eaf126d1b7953df13cb1"></a>
  715. <div class="memitem">
  716. <div class="memproto">
  717. <table class="memname">
  718. <tr>
  719. <td class="memname">const void* lh_table_lookup </td>
  720. <td>(</td>
  721. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  722. <td class="paramname"><em>t</em>, </td>
  723. </tr>
  724. <tr>
  725. <td class="paramkey"></td>
  726. <td></td>
  727. <td class="paramtype">const void *&#160;</td>
  728. <td class="paramname"><em>k</em>&#160;</td>
  729. </tr>
  730. <tr>
  731. <td></td>
  732. <td>)</td>
  733. <td></td><td></td>
  734. </tr>
  735. </table>
  736. </div><div class="memdoc">
  737. <p>Lookup a record into the table.</p>
  738. <dl class="params"><dt>Parameters</dt><dd>
  739. <table class="params">
  740. <tr><td class="paramname">t</td><td>the table to lookup </td></tr>
  741. <tr><td class="paramname">k</td><td>a pointer to the key to lookup </td></tr>
  742. </table>
  743. </dd>
  744. </dl>
  745. <dl class="section return"><dt>Returns</dt><dd>a pointer to the found value or NULL if it does not exist. </dd></dl>
  746. <dl class="deprecated"><dt><b><a class="el" href="deprecated.html#_deprecated000007">Deprecated:</a></b></dt><dd>Use <a class="el" href="linkhash_8h.html#a81c270bb0dd9d5c8a3e7ae20bc4d67f3">lh_table_lookup_ex()</a> instead. </dd></dl>
  747. </div>
  748. </div>
  749. <a class="anchor" id="ad3b6ca2d967a6c3021ee6c39e014a918"></a>
  750. <div class="memitem">
  751. <div class="memproto">
  752. <table class="memname">
  753. <tr>
  754. <td class="memname">struct <a class="el" href="structlh__entry.html">lh_entry</a>* lh_table_lookup_entry </td>
  755. <td>(</td>
  756. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  757. <td class="paramname"><em>t</em>, </td>
  758. </tr>
  759. <tr>
  760. <td class="paramkey"></td>
  761. <td></td>
  762. <td class="paramtype">const void *&#160;</td>
  763. <td class="paramname"><em>k</em>&#160;</td>
  764. </tr>
  765. <tr>
  766. <td></td>
  767. <td>)</td>
  768. <td></td><td></td>
  769. </tr>
  770. </table>
  771. </div><div class="memdoc">
  772. <p>Lookup a record in the table.</p>
  773. <dl class="params"><dt>Parameters</dt><dd>
  774. <table class="params">
  775. <tr><td class="paramname">t</td><td>the table to lookup </td></tr>
  776. <tr><td class="paramname">k</td><td>a pointer to the key to lookup </td></tr>
  777. </table>
  778. </dd>
  779. </dl>
  780. <dl class="section return"><dt>Returns</dt><dd>a pointer to the record structure of the value or NULL if it does not exist. </dd></dl>
  781. </div>
  782. </div>
  783. <a class="anchor" id="a59ecaf34ef59280952f4459b2de63677"></a>
  784. <div class="memitem">
  785. <div class="memproto">
  786. <table class="memname">
  787. <tr>
  788. <td class="memname">struct <a class="el" href="structlh__entry.html">lh_entry</a>* lh_table_lookup_entry_w_hash </td>
  789. <td>(</td>
  790. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  791. <td class="paramname"><em>t</em>, </td>
  792. </tr>
  793. <tr>
  794. <td class="paramkey"></td>
  795. <td></td>
  796. <td class="paramtype">const void *&#160;</td>
  797. <td class="paramname"><em>k</em>, </td>
  798. </tr>
  799. <tr>
  800. <td class="paramkey"></td>
  801. <td></td>
  802. <td class="paramtype">const unsigned long&#160;</td>
  803. <td class="paramname"><em>h</em>&#160;</td>
  804. </tr>
  805. <tr>
  806. <td></td>
  807. <td>)</td>
  808. <td></td><td></td>
  809. </tr>
  810. </table>
  811. </div><div class="memdoc">
  812. <p>Lookup a record in the table using a precalculated key hash.</p>
  813. <p>The hash h, which should be calculated with lh_get_hash() on k, is provided by the caller, to allow for optimization when multiple operations with the same key are known to be needed.</p>
  814. <dl class="params"><dt>Parameters</dt><dd>
  815. <table class="params">
  816. <tr><td class="paramname">t</td><td>the table to lookup </td></tr>
  817. <tr><td class="paramname">k</td><td>a pointer to the key to lookup </td></tr>
  818. <tr><td class="paramname">h</td><td>hash value of the key to lookup </td></tr>
  819. </table>
  820. </dd>
  821. </dl>
  822. <dl class="section return"><dt>Returns</dt><dd>a pointer to the record structure of the value or NULL if it does not exist. </dd></dl>
  823. </div>
  824. </div>
  825. <a class="anchor" id="a81c270bb0dd9d5c8a3e7ae20bc4d67f3"></a>
  826. <div class="memitem">
  827. <div class="memproto">
  828. <table class="memname">
  829. <tr>
  830. <td class="memname"><a class="el" href="json__object_8h.html#a81f02022906fafc71eb9197049f07f73">json_bool</a> lh_table_lookup_ex </td>
  831. <td>(</td>
  832. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  833. <td class="paramname"><em>t</em>, </td>
  834. </tr>
  835. <tr>
  836. <td class="paramkey"></td>
  837. <td></td>
  838. <td class="paramtype">const void *&#160;</td>
  839. <td class="paramname"><em>k</em>, </td>
  840. </tr>
  841. <tr>
  842. <td class="paramkey"></td>
  843. <td></td>
  844. <td class="paramtype">void **&#160;</td>
  845. <td class="paramname"><em>v</em>&#160;</td>
  846. </tr>
  847. <tr>
  848. <td></td>
  849. <td>)</td>
  850. <td></td><td></td>
  851. </tr>
  852. </table>
  853. </div><div class="memdoc">
  854. <p>Lookup a record in the table.</p>
  855. <dl class="params"><dt>Parameters</dt><dd>
  856. <table class="params">
  857. <tr><td class="paramname">t</td><td>the table to lookup </td></tr>
  858. <tr><td class="paramname">k</td><td>a pointer to the key to lookup </td></tr>
  859. <tr><td class="paramname">v</td><td>a pointer to a where to store the found value (set to NULL if it doesn't exist). </td></tr>
  860. </table>
  861. </dd>
  862. </dl>
  863. <dl class="section return"><dt>Returns</dt><dd>whether or not the key was found </dd></dl>
  864. </div>
  865. </div>
  866. <a class="anchor" id="a9c4f8a71dbe4d3390d9f7adb331beb0e"></a>
  867. <div class="memitem">
  868. <div class="memproto">
  869. <table class="memname">
  870. <tr>
  871. <td class="memname">struct <a class="el" href="structlh__table.html">lh_table</a>* lh_table_new </td>
  872. <td>(</td>
  873. <td class="paramtype">int&#160;</td>
  874. <td class="paramname"><em>size</em>, </td>
  875. </tr>
  876. <tr>
  877. <td class="paramkey"></td>
  878. <td></td>
  879. <td class="paramtype"><a class="el" href="linkhash_8h.html#a671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *&#160;</td>
  880. <td class="paramname"><em>free_fn</em>, </td>
  881. </tr>
  882. <tr>
  883. <td class="paramkey"></td>
  884. <td></td>
  885. <td class="paramtype"><a class="el" href="linkhash_8h.html#a38bae27995dcfb6ee3fb109a9be229b2">lh_hash_fn</a> *&#160;</td>
  886. <td class="paramname"><em>hash_fn</em>, </td>
  887. </tr>
  888. <tr>
  889. <td class="paramkey"></td>
  890. <td></td>
  891. <td class="paramtype"><a class="el" href="linkhash_8h.html#a91fd85fc81b0c7c83c62f00e84729091">lh_equal_fn</a> *&#160;</td>
  892. <td class="paramname"><em>equal_fn</em>&#160;</td>
  893. </tr>
  894. <tr>
  895. <td></td>
  896. <td>)</td>
  897. <td></td><td></td>
  898. </tr>
  899. </table>
  900. </div><div class="memdoc">
  901. <p>Create a new linkhash table.</p>
  902. <dl class="params"><dt>Parameters</dt><dd>
  903. <table class="params">
  904. <tr><td class="paramname">size</td><td>initial table size. The table is automatically resized although this incurs a performance penalty. </td></tr>
  905. <tr><td class="paramname">free_fn</td><td>callback function used to free memory for entries when lh_table_free or lh_table_delete is called. If NULL is provided, then memory for keys and values must be freed by the caller. </td></tr>
  906. <tr><td class="paramname">hash_fn</td><td>function used to hash keys. 2 standard ones are defined: lh_ptr_hash and lh_char_hash for hashing pointer values and C strings respectively. </td></tr>
  907. <tr><td class="paramname">equal_fn</td><td>comparison function to compare keys. 2 standard ones defined: lh_ptr_hash and lh_char_hash for comparing pointer values and C strings respectively. </td></tr>
  908. </table>
  909. </dd>
  910. </dl>
  911. <dl class="section return"><dt>Returns</dt><dd>On success, a pointer to the new linkhash table is returned. On error, a null pointer is returned. </dd></dl>
  912. </div>
  913. </div>
  914. <a class="anchor" id="a30c8414e31aeee7669acc938116d933f"></a>
  915. <div class="memitem">
  916. <div class="memproto">
  917. <table class="memname">
  918. <tr>
  919. <td class="memname">int lh_table_resize </td>
  920. <td>(</td>
  921. <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> *&#160;</td>
  922. <td class="paramname"><em>t</em>, </td>
  923. </tr>
  924. <tr>
  925. <td class="paramkey"></td>
  926. <td></td>
  927. <td class="paramtype">int&#160;</td>
  928. <td class="paramname"><em>new_size</em>&#160;</td>
  929. </tr>
  930. <tr>
  931. <td></td>
  932. <td>)</td>
  933. <td></td><td></td>
  934. </tr>
  935. </table>
  936. </div><div class="memdoc">
  937. <p>Resizes the specified table.</p>
  938. <dl class="params"><dt>Parameters</dt><dd>
  939. <table class="params">
  940. <tr><td class="paramname">t</td><td>Pointer to table to resize. </td></tr>
  941. <tr><td class="paramname">new_size</td><td>New table size. Must be positive.</td></tr>
  942. </table>
  943. </dd>
  944. </dl>
  945. <dl class="section return"><dt>Returns</dt><dd>On success, <code>0</code> is returned. On error, a negative value is returned. </dd></dl>
  946. </div>
  947. </div>
  948. </div><!-- contents -->
  949. <!-- start footer part -->
  950. <hr class="footer"/><address class="footer"><small>
  951. Generated on Mon Mar 5 2018 23:17:09 for json-c by &#160;<a href="http://www.doxygen.org/index.html">
  952. <img class="footer" src="doxygen.png" alt="doxygen"/>
  953. </a> 1.8.8
  954. </small></address>
  955. </body>
  956. </html>

No Description