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 54 kB

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

No Description