2015-09-17 04:24:54 -04:00
|
|
|
#ifndef RUBY_ID_TABLE_H
|
|
|
|
#define RUBY_ID_TABLE_H 1
|
2015-08-12 04:43:55 -04:00
|
|
|
#include "ruby/ruby.h"
|
|
|
|
|
|
|
|
struct rb_id_table;
|
|
|
|
|
|
|
|
/* compatible with ST_* */
|
|
|
|
enum rb_id_table_iterator_result {
|
|
|
|
ID_TABLE_CONTINUE = ST_CONTINUE,
|
|
|
|
ID_TABLE_STOP = ST_STOP,
|
|
|
|
ID_TABLE_DELETE = ST_DELETE,
|
2016-08-05 20:35:33 -04:00
|
|
|
ID_TABLE_ITERATOR_RESULT_END
|
2015-08-12 04:43:55 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
struct rb_id_table *rb_id_table_create(size_t size);
|
|
|
|
void rb_id_table_free(struct rb_id_table *tbl);
|
|
|
|
void rb_id_table_clear(struct rb_id_table *tbl);
|
|
|
|
|
2015-11-02 17:18:32 -05:00
|
|
|
size_t rb_id_table_size(const struct rb_id_table *tbl);
|
|
|
|
size_t rb_id_table_memsize(const struct rb_id_table *tbl);
|
2015-08-12 04:43:55 -04:00
|
|
|
|
|
|
|
int rb_id_table_insert(struct rb_id_table *tbl, ID id, VALUE val);
|
|
|
|
int rb_id_table_lookup(struct rb_id_table *tbl, ID id, VALUE *valp);
|
|
|
|
int rb_id_table_delete(struct rb_id_table *tbl, ID id);
|
2015-08-25 20:47:10 -04:00
|
|
|
|
|
|
|
typedef enum rb_id_table_iterator_result rb_id_table_foreach_func_t(ID id, VALUE val, void *data);
|
|
|
|
typedef enum rb_id_table_iterator_result rb_id_table_foreach_values_func_t(VALUE val, void *data);
|
|
|
|
void rb_id_table_foreach(struct rb_id_table *tbl, rb_id_table_foreach_func_t *func, void *data);
|
|
|
|
void rb_id_table_foreach_values(struct rb_id_table *tbl, rb_id_table_foreach_values_func_t *func, void *data);
|
2015-09-17 04:24:54 -04:00
|
|
|
|
|
|
|
#endif /* RUBY_ID_TABLE_H */
|