Ruby 3.5.0dev (2025-04-26 revision 687bd837244309fa293d6e08d0e13a662fce3a83)
set_table.h
1#ifndef INTERNAL_SET_TABLE_H
2#define INTERNAL_SET_TABLE_H
3
4#include "include/ruby/st.h"
5
6struct set_table_entry;
7
8typedef struct set_table_entry set_table_entry;
9
10struct set_table {
11 /* Cached features of the table -- see st.c for more details. */
12 unsigned char entry_power, bin_power, size_ind;
13 /* How many times the table was rebuilt. */
14 unsigned int rebuilds_num;
15 const struct st_hash_type *type;
16 /* Number of entries currently in the table. */
17 st_index_t num_entries;
18 /* Array of bins used for access by keys. */
19 st_index_t *bins;
20 /* Start and bound index of entries in array entries.
21 entries_starts and entries_bound are in interval
22 [0,allocated_entries]. */
23 st_index_t entries_start, entries_bound;
24 /* Array of size 2^entry_power. */
25 set_table_entry *entries;
26};
27
28typedef struct set_table set_table;
29
30typedef int set_foreach_callback_func(st_data_t, st_data_t);
31typedef int set_foreach_check_callback_func(st_data_t, st_data_t, int);
32typedef int set_update_callback_func(st_data_t *key, st_data_t arg, int existing);
33
34#define set_table_size rb_set_table_size
35size_t rb_set_table_size(const struct set_table *tbl);
36#define set_init_table_with_size rb_set_init_table_with_size
37set_table *rb_set_init_table_with_size(set_table *tab, const struct st_hash_type *, st_index_t);
38#define set_init_numtable rb_set_init_numtable
39set_table *rb_set_init_numtable(void);
40#define set_delete rb_set_delete
41int rb_set_delete(set_table *, st_data_t *); /* returns 0:notfound 1:deleted */
42#define set_insert rb_set_insert
43int rb_set_insert(set_table *, st_data_t);
44#define set_lookup rb_set_lookup
45int rb_set_lookup(set_table *, st_data_t);
46#define set_foreach_with_replace rb_set_foreach_with_replace
47int rb_set_foreach_with_replace(set_table *tab, set_foreach_check_callback_func *func, set_update_callback_func *replace, st_data_t arg);
48#define set_foreach rb_set_foreach
49int rb_set_foreach(set_table *, set_foreach_callback_func *, st_data_t);
50#define set_foreach_check rb_set_foreach_check
51int rb_set_foreach_check(set_table *, set_foreach_check_callback_func *, st_data_t, st_data_t);
52#define set_keys rb_set_keys
53st_index_t rb_set_keys(set_table *table, st_data_t *keys, st_index_t size);
54#define set_free_table rb_set_free_table
55void rb_set_free_table(set_table *);
56#define set_clear rb_set_clear
57void rb_set_clear(set_table *);
58#define set_copy rb_set_copy
59set_table *rb_set_copy(set_table *new_table, set_table *old_table);
60#define set_memsize rb_set_memsize
61PUREFUNC(size_t rb_set_memsize(const set_table *));
62#define set_compact_table rb_set_compact_table
63void set_compact_table(set_table *tab);
64
65#endif