Lines Matching refs:table
57 #define EQUAL(table,x,y) ((x)==(y) || (*table->type->compare)((x),(y)) == 0) argument
59 #define do_hash(key,table) (unsigned int)(*(table)->type->hash)((key)) argument
60 #define do_hash_bin(key,table) (do_hash(key, table)%(table)->num_bins) argument
207 st_free_table(table) in st_free_table() argument
208 st_table *table; in st_free_table()
213 for(i = 0; i < table->num_bins; i++) {
214 ptr = table->bins[i];
221 free(table->bins);
222 free(table);
225 #define PTR_NOT_EQUAL(table, ptr, hash_val, key) \ argument
226 ((ptr) != 0 && (ptr->hash != (hash_val) || !EQUAL((table), (key), (ptr)->key)))
234 #define FIND_ENTRY(table, ptr, hash_val, bin_pos) do {\ argument
235 bin_pos = hash_val%(table)->num_bins;\
236 ptr = (table)->bins[bin_pos];\
237 if (PTR_NOT_EQUAL(table, ptr, hash_val, key)) {\
239 while (PTR_NOT_EQUAL(table, ptr->next, hash_val, key)) {\
247 st_lookup(table, key, value) in st_lookup() argument
248 st_table *table; in st_lookup()
255 hash_val = do_hash(key, table);
256 FIND_ENTRY(table, ptr, hash_val, bin_pos);
267 #define ADD_DIRECT(table, key, value, hash_val, bin_pos, ret) \ argument
270 if (table->num_entries/(table->num_bins) > ST_DEFAULT_MAX_DENSITY) {\
271 rehash(table);\
272 bin_pos = hash_val % table->num_bins;\
279 entry->next = table->bins[bin_pos];\
280 table->bins[bin_pos] = entry;\
281 table->num_entries++;\
285 st_insert(table, key, value) in st_insert() argument
286 register st_table *table; in st_insert()
293 hash_val = do_hash(key, table);
294 FIND_ENTRY(table, ptr, hash_val, bin_pos);
297 ADD_DIRECT(table, key, value, hash_val, bin_pos, ONIGERR_MEMORY);
307 st_add_direct(table, key, value) in st_add_direct() argument
308 st_table *table; in st_add_direct()
314 hash_val = do_hash(key, table);
315 bin_pos = hash_val % table->num_bins;
316 ADD_DIRECT(table, key, value, hash_val, bin_pos,);
320 rehash(table) in rehash() argument
321 register st_table *table; in rehash()
324 int i, old_num_bins = table->num_bins, new_num_bins;
334 ptr = table->bins[i];
343 free(table->bins);
344 table->num_bins = new_num_bins;
345 table->bins = new_bins;
390 st_delete(table, key, value) in st_delete() argument
391 register st_table *table; in st_delete()
399 hash_val = do_hash_bin(*key, table);
400 ptr = table->bins[hash_val];
407 if (EQUAL(table, *key, ptr->key)) {
408 table->bins[hash_val] = ptr->next;
409 table->num_entries--;
417 if (EQUAL(table, ptr->next->key, *key)) {
420 table->num_entries--;
432 st_delete_safe(table, key, value, never) in st_delete_safe() argument
433 register st_table *table; in st_delete_safe()
441 hash_val = do_hash_bin(*key, table);
442 ptr = table->bins[hash_val];
450 if ((ptr->key != never) && EQUAL(table, ptr->key, *key)) {
451 table->num_entries--;
476 st_cleanup_safe(table, never) in st_cleanup_safe() argument
477 st_table *table; in st_cleanup_safe()
480 int num_entries = table->num_entries;
482 st_foreach(table, delete_never, never);
483 table->num_entries = num_entries;
487 st_foreach(table, func, arg) in st_foreach() argument
488 st_table *table; in st_foreach()
496 for(i = 0; i < table->num_bins; i++) {
498 for(ptr = table->bins[i]; ptr != 0;) {
503 if (i < table->num_bins) {
504 for (tmp = table->bins[i]; tmp; tmp=tmp->next) {
522 table->bins[i] = ptr->next;
529 table->num_entries--;