1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
2 <html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
3 <title>json-c: linkhash.h File Reference</title>
4 <link href="tabs.css" rel="stylesheet" type="text/css">
5 <link href="doxygen.css" rel="stylesheet" type="text/css">
7 <!-- Generated by Doxygen 1.5.8 -->
8 <div class="navigation" id="top">
11 <li><a href="index.html"><span>Main Page</span></a></li>
12 <li><a href="annotated.html"><span>Data Structures</span></a></li>
13 <li class="current"><a href="files.html"><span>Files</span></a></li>
18 <li><a href="files.html"><span>File List</span></a></li>
19 <li><a href="globals.html"><span>Globals</span></a></li>
23 <div class="contents">
24 <h1>linkhash.h File Reference</h1><table border="0" cellpadding="0" cellspacing="0">
26 <tr><td colspan="2"><br><h2>Data Structures</h2></td></tr>
27 <tr><td class="memItemLeft" nowrap align="right" valign="top">struct </td><td class="memItemRight" valign="bottom"><a class="el" href="structlh__entry.html">lh_entry</a></td></tr>
29 <tr><td class="memItemLeft" nowrap align="right" valign="top">struct </td><td class="memItemRight" valign="bottom"><a class="el" href="structlh__table.html">lh_table</a></td></tr>
31 <tr><td colspan="2"><br><h2>Defines</h2></td></tr>
32 <tr><td class="memItemLeft" nowrap align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#032f1bd115df254dda325437203ce5fb">LH_PRIME</a> 0x9e370001UL</td></tr>
34 <tr><td class="memItemLeft" nowrap align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#93fad7f8ae44575dc89c9567859972d2">LH_EMPTY</a> (void*)-1</td></tr>
36 <tr><td class="memItemLeft" nowrap align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#c69428f2de0a6fb080b6fb373d506aa7">LH_FREED</a> (void*)-2</td></tr>
38 <tr><td class="memItemLeft" nowrap align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#d7dd67da915065dce2c6f44cb03e2d82">lh_foreach</a>(table, entry) for(entry = table->head; entry; entry = entry->next)</td></tr>
40 <tr><td class="memItemLeft" nowrap align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#bcbb0df08b4976d0649b826b6bacfca1">lh_foreach_safe</a>(table, entry, tmp) for(entry = table->head; entry && ((tmp = entry->next) || 1); entry = tmp)</td></tr>
42 <tr><td colspan="2"><br><h2>Typedefs</h2></td></tr>
43 <tr><td class="memItemLeft" nowrap align="right" valign="top">typedef void( </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> )(struct <a class="el" href="structlh__entry.html">lh_entry</a> *e)</td></tr>
45 <tr><td class="memItemLeft" nowrap align="right" valign="top">typedef unsigned long( </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#38bae27995dcfb6ee3fb109a9be229b2">lh_hash_fn</a> )(const void *k)</td></tr>
47 <tr><td class="memItemLeft" nowrap align="right" valign="top">typedef int( </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#91fd85fc81b0c7c83c62f00e84729091">lh_equal_fn</a> )(const void *k1, const void *k2)</td></tr>
49 <tr><td colspan="2"><br><h2>Functions</h2></td></tr>
50 <tr><td class="memItemLeft" nowrap align="right" valign="top">unsigned long </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#2e560f0d3e5a20f6b0bfa4049737db23">lh_ptr_hash</a> (const void *k)</td></tr>
52 <tr><td class="memItemLeft" nowrap align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#6ce3cb97560072c40f5caeaba85f756a">lh_ptr_equal</a> (const void *k1, const void *k2)</td></tr>
54 <tr><td class="memItemLeft" nowrap align="right" valign="top">unsigned long </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#1fcf495b9c4ce169630cb31f638b8435">lh_char_hash</a> (const void *k)</td></tr>
56 <tr><td class="memItemLeft" nowrap align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#e4e9f21fb1a556c7a50c6b7ea61f2079">lh_char_equal</a> (const void *k1, const void *k2)</td></tr>
58 <tr><td class="memItemLeft" nowrap align="right" valign="top">struct <a class="el" href="structlh__table.html">lh_table</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#c3ba464ac43c083397b1f1d34f2ddf55">lh_table_new</a> (int size, const char *name, <a class="el" href="linkhash_8h.html#671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *free_fn, <a class="el" href="linkhash_8h.html#38bae27995dcfb6ee3fb109a9be229b2">lh_hash_fn</a> *hash_fn, <a class="el" href="linkhash_8h.html#91fd85fc81b0c7c83c62f00e84729091">lh_equal_fn</a> *equal_fn)</td></tr>
60 <tr><td class="memItemLeft" nowrap align="right" valign="top">struct <a class="el" href="structlh__table.html">lh_table</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#0aaf11e11ee5b0925279a52eab04bc38">lh_kchar_table_new</a> (int size, const char *name, <a class="el" href="linkhash_8h.html#671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *free_fn)</td></tr>
62 <tr><td class="memItemLeft" nowrap align="right" valign="top">struct <a class="el" href="structlh__table.html">lh_table</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#705513954267a16cc1d40a284a7c441e">lh_kptr_table_new</a> (int size, const char *name, <a class="el" href="linkhash_8h.html#671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> *free_fn)</td></tr>
64 <tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#81653acf740cf8c9fe672e6cd16df0cf">lh_table_free</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t)</td></tr>
66 <tr><td class="memItemLeft" nowrap align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#22b897763cc34a98c21c7fe82d151004">lh_table_insert</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, void *k, const void *v)</td></tr>
68 <tr><td class="memItemLeft" nowrap align="right" valign="top">struct <a class="el" href="structlh__entry.html">lh_entry</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#d3b6ca2d967a6c3021ee6c39e014a918">lh_table_lookup_entry</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k)</td></tr>
70 <tr><td class="memItemLeft" nowrap align="right" valign="top">const void * </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#49c27f18a174eaf126d1b7953df13cb1">lh_table_lookup</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k)</td></tr>
72 <tr><td class="memItemLeft" nowrap align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#e5885a71c3457190fb1dc2d6e20dde3b">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>
74 <tr><td class="memItemLeft" nowrap align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#2fed2c78f70d229edb2d00775ffe593c">lh_table_delete</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, const void *k)</td></tr>
76 <tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#1294160fa0e80cee04cd745a401f43a4">lh_abort</a> (const char *msg,...)</td></tr>
78 <tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="linkhash_8h.html#5322eccf3394af7dc1ebb22af8f8c562">lh_table_resize</a> (struct <a class="el" href="structlh__table.html">lh_table</a> *t, int new_size)</td></tr>
81 <hr><h2>Define Documentation</h2>
82 <a class="anchor" name="93fad7f8ae44575dc89c9567859972d2"></a><!-- doxytag: member="linkhash.h::LH_EMPTY" ref="93fad7f8ae44575dc89c9567859972d2" args="" -->
84 <div class="memproto">
85 <table class="memname">
87 <td class="memname">#define LH_EMPTY (void*)-1 </td>
94 sentinel pointer value for empty slots
97 <a class="anchor" name="d7dd67da915065dce2c6f44cb03e2d82"></a><!-- doxytag: member="linkhash.h::lh_foreach" ref="d7dd67da915065dce2c6f44cb03e2d82" args="(table, entry)" -->
99 <div class="memproto">
100 <table class="memname">
102 <td class="memname">#define lh_foreach </td>
104 <td class="paramtype">table, <tr>
105 <td class="paramkey"></td>
107 <td class="paramtype">entry </td>
108 <td class="paramname"> </td>
109 <td> ) </td>
110 <td> for(entry = table->head; entry; entry = entry->next)</td>
117 Convenience list iterator.
120 <a class="anchor" name="bcbb0df08b4976d0649b826b6bacfca1"></a><!-- doxytag: member="linkhash.h::lh_foreach_safe" ref="bcbb0df08b4976d0649b826b6bacfca1" args="(table, entry, tmp)" -->
121 <div class="memitem">
122 <div class="memproto">
123 <table class="memname">
125 <td class="memname">#define lh_foreach_safe </td>
127 <td class="paramtype">table, <tr>
128 <td class="paramkey"></td>
130 <td class="paramtype">entry, <tr>
131 <td class="paramkey"></td>
133 <td class="paramtype">tmp </td>
134 <td class="paramname"> </td>
135 <td> ) </td>
136 <td> for(entry = table->head; entry && ((tmp = entry->next) || 1); entry = tmp)</td>
143 lh_foreach_safe allows calling of deletion routine while iterating.
146 <a class="anchor" name="c69428f2de0a6fb080b6fb373d506aa7"></a><!-- doxytag: member="linkhash.h::LH_FREED" ref="c69428f2de0a6fb080b6fb373d506aa7" args="" -->
147 <div class="memitem">
148 <div class="memproto">
149 <table class="memname">
151 <td class="memname">#define LH_FREED (void*)-2 </td>
158 sentinel pointer value for freed slots
161 <a class="anchor" name="032f1bd115df254dda325437203ce5fb"></a><!-- doxytag: member="linkhash.h::LH_PRIME" ref="032f1bd115df254dda325437203ce5fb" args="" -->
162 <div class="memitem">
163 <div class="memproto">
164 <table class="memname">
166 <td class="memname">#define LH_PRIME 0x9e370001UL </td>
173 golden prime used in hash functions
176 <hr><h2>Typedef Documentation</h2>
177 <a class="anchor" name="671553d0ee3c2a123190ba0f8ed2b635"></a><!-- doxytag: member="linkhash.h::lh_entry_free_fn" ref="671553d0ee3c2a123190ba0f8ed2b635" args=")(struct lh_entry *e)" -->
178 <div class="memitem">
179 <div class="memproto">
180 <table class="memname">
182 <td class="memname">typedef void( <a class="el" href="linkhash_8h.html#671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a>)(struct <a class="el" href="structlh__entry.html">lh_entry</a> *e) </td>
189 callback function prototypes
192 <a class="anchor" name="91fd85fc81b0c7c83c62f00e84729091"></a><!-- doxytag: member="linkhash.h::lh_equal_fn" ref="91fd85fc81b0c7c83c62f00e84729091" args=")(const void *k1, const void *k2)" -->
193 <div class="memitem">
194 <div class="memproto">
195 <table class="memname">
197 <td class="memname">typedef int( <a class="el" href="linkhash_8h.html#91fd85fc81b0c7c83c62f00e84729091">lh_equal_fn</a>)(const void *k1, const void *k2) </td>
204 callback function prototypes
207 <a class="anchor" name="38bae27995dcfb6ee3fb109a9be229b2"></a><!-- doxytag: member="linkhash.h::lh_hash_fn" ref="38bae27995dcfb6ee3fb109a9be229b2" args=")(const void *k)" -->
208 <div class="memitem">
209 <div class="memproto">
210 <table class="memname">
212 <td class="memname">typedef unsigned long( <a class="el" href="linkhash_8h.html#38bae27995dcfb6ee3fb109a9be229b2">lh_hash_fn</a>)(const void *k) </td>
219 callback function prototypes
222 <hr><h2>Function Documentation</h2>
223 <a class="anchor" name="1294160fa0e80cee04cd745a401f43a4"></a><!-- doxytag: member="linkhash.h::lh_abort" ref="1294160fa0e80cee04cd745a401f43a4" args="(const char *msg,...)" -->
224 <div class="memitem">
225 <div class="memproto">
226 <table class="memname">
228 <td class="memname">void lh_abort </td>
230 <td class="paramtype">const char * </td>
231 <td class="paramname"> <em>msg</em>, </td>
234 <td class="paramkey"></td>
236 <td class="paramtype"> </td>
237 <td class="paramname"> <em>...</em></td><td> </td>
242 <td></td><td></td><td></td>
252 <a class="anchor" name="e4e9f21fb1a556c7a50c6b7ea61f2079"></a><!-- doxytag: member="linkhash.h::lh_char_equal" ref="e4e9f21fb1a556c7a50c6b7ea61f2079" args="(const void *k1, const void *k2)" -->
253 <div class="memitem">
254 <div class="memproto">
255 <table class="memname">
257 <td class="memname">int lh_char_equal </td>
259 <td class="paramtype">const void * </td>
260 <td class="paramname"> <em>k1</em>, </td>
263 <td class="paramkey"></td>
265 <td class="paramtype">const void * </td>
266 <td class="paramname"> <em>k2</em></td><td> </td>
271 <td></td><td></td><td></td>
281 <a class="anchor" name="1fcf495b9c4ce169630cb31f638b8435"></a><!-- doxytag: member="linkhash.h::lh_char_hash" ref="1fcf495b9c4ce169630cb31f638b8435" args="(const void *k)" -->
282 <div class="memitem">
283 <div class="memproto">
284 <table class="memname">
286 <td class="memname">unsigned long lh_char_hash </td>
288 <td class="paramtype">const void * </td>
289 <td class="paramname"> <em>k</em> </td>
290 <td> ) </td>
301 <a class="anchor" name="0aaf11e11ee5b0925279a52eab04bc38"></a><!-- doxytag: member="linkhash.h::lh_kchar_table_new" ref="0aaf11e11ee5b0925279a52eab04bc38" args="(int size, const char *name, lh_entry_free_fn *free_fn)" -->
302 <div class="memitem">
303 <div class="memproto">
304 <table class="memname">
306 <td class="memname">struct <a class="el" href="structlh__table.html">lh_table</a>* lh_kchar_table_new </td>
308 <td class="paramtype">int </td>
309 <td class="paramname"> <em>size</em>, </td>
312 <td class="paramkey"></td>
314 <td class="paramtype">const char * </td>
315 <td class="paramname"> <em>name</em>, </td>
318 <td class="paramkey"></td>
320 <td class="paramtype"><a class="el" href="linkhash_8h.html#671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> * </td>
321 <td class="paramname"> <em>free_fn</em></td><td> </td>
326 <td></td><td></td><td><code> [read]</code></td>
333 Convenience function to create a new linkhash table with char keys. <dl compact><dt><b>Parameters:</b></dt><dd>
334 <table border="0" cellspacing="2" cellpadding="0">
335 <tr><td valign="top"></td><td valign="top"><em>size</em> </td><td>initial table size. </td></tr>
336 <tr><td valign="top"></td><td valign="top"><em>name</em> </td><td>table name. </td></tr>
337 <tr><td valign="top"></td><td valign="top"><em>free_fn</em> </td><td>callback function used to free memory for entries. </td></tr>
340 <dl class="return" compact><dt><b>Returns:</b></dt><dd>a pointer onto the linkhash table. </dd></dl>
344 <a class="anchor" name="705513954267a16cc1d40a284a7c441e"></a><!-- doxytag: member="linkhash.h::lh_kptr_table_new" ref="705513954267a16cc1d40a284a7c441e" args="(int size, const char *name, lh_entry_free_fn *free_fn)" -->
345 <div class="memitem">
346 <div class="memproto">
347 <table class="memname">
349 <td class="memname">struct <a class="el" href="structlh__table.html">lh_table</a>* lh_kptr_table_new </td>
351 <td class="paramtype">int </td>
352 <td class="paramname"> <em>size</em>, </td>
355 <td class="paramkey"></td>
357 <td class="paramtype">const char * </td>
358 <td class="paramname"> <em>name</em>, </td>
361 <td class="paramkey"></td>
363 <td class="paramtype"><a class="el" href="linkhash_8h.html#671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> * </td>
364 <td class="paramname"> <em>free_fn</em></td><td> </td>
369 <td></td><td></td><td><code> [read]</code></td>
376 Convenience function to create a new linkhash table with ptr keys. <dl compact><dt><b>Parameters:</b></dt><dd>
377 <table border="0" cellspacing="2" cellpadding="0">
378 <tr><td valign="top"></td><td valign="top"><em>size</em> </td><td>initial table size. </td></tr>
379 <tr><td valign="top"></td><td valign="top"><em>name</em> </td><td>table name. </td></tr>
380 <tr><td valign="top"></td><td valign="top"><em>free_fn</em> </td><td>callback function used to free memory for entries. </td></tr>
383 <dl class="return" compact><dt><b>Returns:</b></dt><dd>a pointer onto the linkhash table. </dd></dl>
387 <a class="anchor" name="6ce3cb97560072c40f5caeaba85f756a"></a><!-- doxytag: member="linkhash.h::lh_ptr_equal" ref="6ce3cb97560072c40f5caeaba85f756a" args="(const void *k1, const void *k2)" -->
388 <div class="memitem">
389 <div class="memproto">
390 <table class="memname">
392 <td class="memname">int lh_ptr_equal </td>
394 <td class="paramtype">const void * </td>
395 <td class="paramname"> <em>k1</em>, </td>
398 <td class="paramkey"></td>
400 <td class="paramtype">const void * </td>
401 <td class="paramname"> <em>k2</em></td><td> </td>
406 <td></td><td></td><td></td>
416 <a class="anchor" name="2e560f0d3e5a20f6b0bfa4049737db23"></a><!-- doxytag: member="linkhash.h::lh_ptr_hash" ref="2e560f0d3e5a20f6b0bfa4049737db23" args="(const void *k)" -->
417 <div class="memitem">
418 <div class="memproto">
419 <table class="memname">
421 <td class="memname">unsigned long lh_ptr_hash </td>
423 <td class="paramtype">const void * </td>
424 <td class="paramname"> <em>k</em> </td>
425 <td> ) </td>
433 Pre-defined hash and equality functions
436 <a class="anchor" name="2fed2c78f70d229edb2d00775ffe593c"></a><!-- doxytag: member="linkhash.h::lh_table_delete" ref="2fed2c78f70d229edb2d00775ffe593c" args="(struct lh_table *t, const void *k)" -->
437 <div class="memitem">
438 <div class="memproto">
439 <table class="memname">
441 <td class="memname">int lh_table_delete </td>
443 <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> * </td>
444 <td class="paramname"> <em>t</em>, </td>
447 <td class="paramkey"></td>
449 <td class="paramtype">const void * </td>
450 <td class="paramname"> <em>k</em></td><td> </td>
455 <td></td><td></td><td></td>
462 Delete a record from the table. If a callback free function is provided then it is called for the for the item being deleted. <dl compact><dt><b>Parameters:</b></dt><dd>
463 <table border="0" cellspacing="2" cellpadding="0">
464 <tr><td valign="top"></td><td valign="top"><em>t</em> </td><td>the table to delete from. </td></tr>
465 <tr><td valign="top"></td><td valign="top"><em>k</em> </td><td>a pointer to the key to delete. </td></tr>
468 <dl class="return" compact><dt><b>Returns:</b></dt><dd>0 if the item was deleted. <p>
469 -1 if it was not found. </dd></dl>
473 <a class="anchor" name="e5885a71c3457190fb1dc2d6e20dde3b"></a><!-- doxytag: member="linkhash.h::lh_table_delete_entry" ref="e5885a71c3457190fb1dc2d6e20dde3b" args="(struct lh_table *t, struct lh_entry *e)" -->
474 <div class="memitem">
475 <div class="memproto">
476 <table class="memname">
478 <td class="memname">int lh_table_delete_entry </td>
480 <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> * </td>
481 <td class="paramname"> <em>t</em>, </td>
484 <td class="paramkey"></td>
486 <td class="paramtype">struct <a class="el" href="structlh__entry.html">lh_entry</a> * </td>
487 <td class="paramname"> <em>e</em></td><td> </td>
492 <td></td><td></td><td></td>
499 Delete a record from the table. If a callback free function is provided then it is called for the for the item being deleted. <dl compact><dt><b>Parameters:</b></dt><dd>
500 <table border="0" cellspacing="2" cellpadding="0">
501 <tr><td valign="top"></td><td valign="top"><em>t</em> </td><td>the table to delete from. </td></tr>
502 <tr><td valign="top"></td><td valign="top"><em>e</em> </td><td>a pointer to the entry to delete. </td></tr>
505 <dl class="return" compact><dt><b>Returns:</b></dt><dd>0 if the item was deleted. <p>
506 -1 if it was not found. </dd></dl>
510 <a class="anchor" name="81653acf740cf8c9fe672e6cd16df0cf"></a><!-- doxytag: member="linkhash.h::lh_table_free" ref="81653acf740cf8c9fe672e6cd16df0cf" args="(struct lh_table *t)" -->
511 <div class="memitem">
512 <div class="memproto">
513 <table class="memname">
515 <td class="memname">void lh_table_free </td>
517 <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> * </td>
518 <td class="paramname"> <em>t</em> </td>
519 <td> ) </td>
527 Free a linkhash table. If a callback free function is provided then it is called for all entries in the table. <dl compact><dt><b>Parameters:</b></dt><dd>
528 <table border="0" cellspacing="2" cellpadding="0">
529 <tr><td valign="top"></td><td valign="top"><em>t</em> </td><td>table to free. </td></tr>
535 <a class="anchor" name="22b897763cc34a98c21c7fe82d151004"></a><!-- doxytag: member="linkhash.h::lh_table_insert" ref="22b897763cc34a98c21c7fe82d151004" args="(struct lh_table *t, void *k, const void *v)" -->
536 <div class="memitem">
537 <div class="memproto">
538 <table class="memname">
540 <td class="memname">int lh_table_insert </td>
542 <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> * </td>
543 <td class="paramname"> <em>t</em>, </td>
546 <td class="paramkey"></td>
548 <td class="paramtype">void * </td>
549 <td class="paramname"> <em>k</em>, </td>
552 <td class="paramkey"></td>
554 <td class="paramtype">const void * </td>
555 <td class="paramname"> <em>v</em></td><td> </td>
560 <td></td><td></td><td></td>
567 Insert a record into the table. <dl compact><dt><b>Parameters:</b></dt><dd>
568 <table border="0" cellspacing="2" cellpadding="0">
569 <tr><td valign="top"></td><td valign="top"><em>t</em> </td><td>the table to insert into. </td></tr>
570 <tr><td valign="top"></td><td valign="top"><em>k</em> </td><td>a pointer to the key to insert. </td></tr>
571 <tr><td valign="top"></td><td valign="top"><em>v</em> </td><td>a pointer to the value to insert. </td></tr>
577 <a class="anchor" name="49c27f18a174eaf126d1b7953df13cb1"></a><!-- doxytag: member="linkhash.h::lh_table_lookup" ref="49c27f18a174eaf126d1b7953df13cb1" args="(struct lh_table *t, const void *k)" -->
578 <div class="memitem">
579 <div class="memproto">
580 <table class="memname">
582 <td class="memname">const void* lh_table_lookup </td>
584 <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> * </td>
585 <td class="paramname"> <em>t</em>, </td>
588 <td class="paramkey"></td>
590 <td class="paramtype">const void * </td>
591 <td class="paramname"> <em>k</em></td><td> </td>
596 <td></td><td></td><td></td>
603 Lookup a record into the table <dl compact><dt><b>Parameters:</b></dt><dd>
604 <table border="0" cellspacing="2" cellpadding="0">
605 <tr><td valign="top"></td><td valign="top"><em>t</em> </td><td>the table to lookup </td></tr>
606 <tr><td valign="top"></td><td valign="top"><em>k</em> </td><td>a pointer to the key to lookup </td></tr>
609 <dl class="return" compact><dt><b>Returns:</b></dt><dd>a pointer to the found value or NULL if it does not exist. </dd></dl>
613 <a class="anchor" name="d3b6ca2d967a6c3021ee6c39e014a918"></a><!-- doxytag: member="linkhash.h::lh_table_lookup_entry" ref="d3b6ca2d967a6c3021ee6c39e014a918" args="(struct lh_table *t, const void *k)" -->
614 <div class="memitem">
615 <div class="memproto">
616 <table class="memname">
618 <td class="memname">struct <a class="el" href="structlh__entry.html">lh_entry</a>* lh_table_lookup_entry </td>
620 <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> * </td>
621 <td class="paramname"> <em>t</em>, </td>
624 <td class="paramkey"></td>
626 <td class="paramtype">const void * </td>
627 <td class="paramname"> <em>k</em></td><td> </td>
632 <td></td><td></td><td><code> [read]</code></td>
639 Lookup a record into the table. <dl compact><dt><b>Parameters:</b></dt><dd>
640 <table border="0" cellspacing="2" cellpadding="0">
641 <tr><td valign="top"></td><td valign="top"><em>t</em> </td><td>the table to lookup </td></tr>
642 <tr><td valign="top"></td><td valign="top"><em>k</em> </td><td>a pointer to the key to lookup </td></tr>
645 <dl class="return" compact><dt><b>Returns:</b></dt><dd>a pointer to the record structure of the value or NULL if it does not exist. </dd></dl>
649 <a class="anchor" name="c3ba464ac43c083397b1f1d34f2ddf55"></a><!-- doxytag: member="linkhash.h::lh_table_new" ref="c3ba464ac43c083397b1f1d34f2ddf55" args="(int size, const char *name, lh_entry_free_fn *free_fn, lh_hash_fn *hash_fn, lh_equal_fn *equal_fn)" -->
650 <div class="memitem">
651 <div class="memproto">
652 <table class="memname">
654 <td class="memname">struct <a class="el" href="structlh__table.html">lh_table</a>* lh_table_new </td>
656 <td class="paramtype">int </td>
657 <td class="paramname"> <em>size</em>, </td>
660 <td class="paramkey"></td>
662 <td class="paramtype">const char * </td>
663 <td class="paramname"> <em>name</em>, </td>
666 <td class="paramkey"></td>
668 <td class="paramtype"><a class="el" href="linkhash_8h.html#671553d0ee3c2a123190ba0f8ed2b635">lh_entry_free_fn</a> * </td>
669 <td class="paramname"> <em>free_fn</em>, </td>
672 <td class="paramkey"></td>
674 <td class="paramtype"><a class="el" href="linkhash_8h.html#38bae27995dcfb6ee3fb109a9be229b2">lh_hash_fn</a> * </td>
675 <td class="paramname"> <em>hash_fn</em>, </td>
678 <td class="paramkey"></td>
680 <td class="paramtype"><a class="el" href="linkhash_8h.html#91fd85fc81b0c7c83c62f00e84729091">lh_equal_fn</a> * </td>
681 <td class="paramname"> <em>equal_fn</em></td><td> </td>
686 <td></td><td></td><td><code> [read]</code></td>
693 Create a new linkhash table. <dl compact><dt><b>Parameters:</b></dt><dd>
694 <table border="0" cellspacing="2" cellpadding="0">
695 <tr><td valign="top"></td><td valign="top"><em>size</em> </td><td>initial table size. The table is automatically resized although this incurs a performance penalty. </td></tr>
696 <tr><td valign="top"></td><td valign="top"><em>name</em> </td><td>the table name. </td></tr>
697 <tr><td valign="top"></td><td valign="top"><em>free_fn</em> </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>
698 <tr><td valign="top"></td><td valign="top"><em>hash_fn</em> </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>
699 <tr><td valign="top"></td><td valign="top"><em>equal_fn</em> </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>
702 <dl class="return" compact><dt><b>Returns:</b></dt><dd>a pointer onto the linkhash table. </dd></dl>
706 <a class="anchor" name="5322eccf3394af7dc1ebb22af8f8c562"></a><!-- doxytag: member="linkhash.h::lh_table_resize" ref="5322eccf3394af7dc1ebb22af8f8c562" args="(struct lh_table *t, int new_size)" -->
707 <div class="memitem">
708 <div class="memproto">
709 <table class="memname">
711 <td class="memname">void lh_table_resize </td>
713 <td class="paramtype">struct <a class="el" href="structlh__table.html">lh_table</a> * </td>
714 <td class="paramname"> <em>t</em>, </td>
717 <td class="paramkey"></td>
719 <td class="paramtype">int </td>
720 <td class="paramname"> <em>new_size</em></td><td> </td>
725 <td></td><td></td><td></td>
736 <hr size="1"><address style="text-align: right;"><small>Generated on Fri Jul 31 10:58:15 2009 for json-c by
737 <a href="http://www.doxygen.org/index.html">
738 <img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.8 </small></address>