11#include "ruby/internal/config.h"
17#define RHASH_AR_TABLE_MAX_SIZE SIZEOF_VALUE
20typedef unsigned char ar_hint_t;
22enum ruby_rhash_flags {
27 RHASH_AR_TABLE_SIZE_SHIFT = (
FL_USHIFT+4),
29 RHASH_AR_TABLE_BOUND_SHIFT = (
FL_USHIFT+8),
32#define RHASH_LEV_MASK (FL_USER13 | FL_USER14 | FL_USER15 | \
33 FL_USER16 | FL_USER17 | FL_USER18 | FL_USER19)
46 ar_hint_t ary[RHASH_AR_TABLE_MAX_SIZE];
58#define RHASH(obj) ((struct RHash *)(obj))
77long rb_dbl_long_hash(
double d);
79st_index_t rb_any_hash(
VALUE a);
87int rb_hash_stlike_delete(
VALUE hash, st_data_t *pkey, st_data_t *pval);
88int rb_hash_stlike_foreach_with_replace(
VALUE hash, st_foreach_check_callback_func *func, st_update_callback_func *replace, st_data_t arg);
89int rb_hash_stlike_update(
VALUE hash, st_data_t key, st_update_callback_func *func, st_data_t arg);
90bool rb_hash_default_unredefined(
VALUE hash);
92VALUE rb_ident_hash_new_with_size(st_index_t size);
93void rb_hash_free(
VALUE hash);
96static inline unsigned RHASH_AR_TABLE_SIZE_RAW(
VALUE h);
100static inline bool RHASH_AR_TABLE_P(
VALUE h);
101static inline bool RHASH_ST_TABLE_P(
VALUE h);
104static inline size_t RHASH_ST_SIZE(
VALUE h);
105static inline void RHASH_ST_CLEAR(
VALUE h);
107RUBY_SYMBOL_EXPORT_BEGIN
110VALUE rb_ident_hash_new(
void);
111int rb_hash_stlike_foreach(
VALUE hash, st_foreach_callback_func *func, st_data_t arg);
112RUBY_SYMBOL_EXPORT_END
114VALUE rb_hash_new_with_size(st_index_t size);
117int rb_hash_stlike_lookup(
VALUE hash, st_data_t key, st_data_t *pval);
122st_table *rb_hash_tbl_raw(
VALUE hash,
const char *file,
int line);
123#define RHASH_TBL_RAW(h) rb_hash_tbl_raw(h, __FILE__, __LINE__)
128RHASH_AR_TABLE_P(
VALUE h)
135RHASH_AR_TABLE(
VALUE h)
142RHASH_ST_TABLE(
VALUE h)
150 return RHASH(h)->ifnone;
156 if (RHASH_AR_TABLE_P(h)) {
157 return RHASH_AR_TABLE_SIZE_RAW(h);
160 return RHASH_ST_SIZE(h);
171RHASH_ST_TABLE_P(
VALUE h)
173 return ! RHASH_AR_TABLE_P(h);
177RHASH_ST_SIZE(
VALUE h)
179 return RHASH_ST_TABLE(h)->num_entries;
183RHASH_ST_CLEAR(
VALUE h)
185 memset(RHASH_ST_TABLE(h), 0,
sizeof(
st_table));
188static inline unsigned
189RHASH_AR_TABLE_SIZE_RAW(
VALUE h)
192 ret >>= RHASH_AR_TABLE_SIZE_SHIFT;
193 return (
unsigned)ret;
196#define RHASH_AR_TABLE_BOUND_RAW(h) \
197 ((unsigned int)((RBASIC(h)->flags >> RHASH_AR_TABLE_BOUND_SHIFT) & \
198 (RHASH_AR_TABLE_BOUND_MASK >> RHASH_AR_TABLE_BOUND_SHIFT)))
200#define RHASH_ST_TABLE_SET(h, s) rb_hash_st_table_set(h, s)
201#define RHASH_TYPE(hash) (RHASH_AR_TABLE_P(hash) ? &objhash : RHASH_ST_TABLE(hash)->type)
203static inline unsigned int
204RHASH_AR_TABLE_BOUND(
VALUE h)
207 const unsigned int bound = RHASH_AR_TABLE_BOUND_RAW(h);
#define RUBY_ASSERT(...)
Asserts that the given expression is truthy if and only if RUBY_DEBUG is truthy.
#define RUBY_EXTERN
Declaration of externally visible global variables.
#define FL_USER3
Old name of RUBY_FL_USER3.
#define FL_USER7
Old name of RUBY_FL_USER7.
#define FL_USER10
Old name of RUBY_FL_USER10.
#define FL_USER6
Old name of RUBY_FL_USER6.
#define FL_USER1
Old name of RUBY_FL_USER1.
#define FL_USER11
Old name of RUBY_FL_USER11.
#define FL_USER8
Old name of RUBY_FL_USER8.
#define FL_TEST_RAW
Old name of RB_FL_TEST_RAW.
#define FL_USER2
Old name of RUBY_FL_USER2.
#define FL_USER9
Old name of RUBY_FL_USER9.
#define FL_USER5
Old name of RUBY_FL_USER5.
#define FL_USHIFT
Old name of RUBY_FL_USHIFT.
#define FL_USER4
Old name of RUBY_FL_USER4.
VALUE type(ANYARGS)
ANYARGS-ed function type.
#define RBIMPL_ATTR_RETURNS_NONNULL()
Wraps (or simulates) __attribute__((returns_nonnull))
#define RHASH_SIZE(h)
Queries the size of the hash.
#define RHASH_EMPTY_P(h)
Checks if the hash is empty.
Ruby object's base components.
const VALUE klass
Class of an object.
uintptr_t VALUE
Type that represents a Ruby object.