prism-cli 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,229 @@
1
+ /*
2
+ ** mruby/hash.h - Hash class
3
+ **
4
+ ** See Copyright Notice in mruby.h
5
+ */
6
+
7
+ #ifndef MRUBY_HASH_H
8
+ #define MRUBY_HASH_H
9
+
10
+ #include "common.h"
11
+
12
+ /**
13
+ * Hash class
14
+ */
15
+ MRB_BEGIN_DECL
16
+
17
+ struct RHash {
18
+ MRB_OBJECT_HEADER;
19
+ struct iv_tbl *iv;
20
+ struct htable *ht;
21
+ };
22
+
23
+ #define mrb_hash_ptr(v) ((struct RHash*)(mrb_ptr(v)))
24
+ #define mrb_hash_value(p) mrb_obj_value((void*)(p))
25
+
26
+ MRB_API mrb_value mrb_hash_new_capa(mrb_state*, mrb_int);
27
+ MRB_API mrb_value mrb_ensure_hash_type(mrb_state *mrb, mrb_value hash);
28
+ MRB_API mrb_value mrb_check_hash_type(mrb_state *mrb, mrb_value hash);
29
+
30
+ /*
31
+ * Initializes a new hash.
32
+ *
33
+ * Equivalent to:
34
+ *
35
+ * Hash.new
36
+ *
37
+ * @param mrb The mruby state reference.
38
+ * @return The initialized hash.
39
+ */
40
+ MRB_API mrb_value mrb_hash_new(mrb_state *mrb);
41
+
42
+ /*
43
+ * Sets a keys and values to hashes.
44
+ *
45
+ * Equivalent to:
46
+ *
47
+ * hash[key] = val
48
+ *
49
+ * @param mrb The mruby state reference.
50
+ * @param hash The target hash.
51
+ * @param key The key to set.
52
+ * @param val The value to set.
53
+ * @return The value.
54
+ */
55
+ MRB_API void mrb_hash_set(mrb_state *mrb, mrb_value hash, mrb_value key, mrb_value val);
56
+
57
+ /*
58
+ * Gets a value from a key. If the key is not found, the default of the
59
+ * hash is used.
60
+ *
61
+ * Equivalent to:
62
+ *
63
+ * hash[key]
64
+ *
65
+ * @param mrb The mruby state reference.
66
+ * @param hash The target hash.
67
+ * @param key The key to get.
68
+ * @return The found value.
69
+ */
70
+ MRB_API mrb_value mrb_hash_get(mrb_state *mrb, mrb_value hash, mrb_value key);
71
+
72
+ /*
73
+ * Gets a value from a key. If the key is not found, the default parameter is
74
+ * used.
75
+ *
76
+ * Equivalent to:
77
+ *
78
+ * hash.key?(key) ? hash[key] : def
79
+ *
80
+ * @param mrb The mruby state reference.
81
+ * @param hash The target hash.
82
+ * @param key The key to get.
83
+ * @param def The default value.
84
+ * @return The found value.
85
+ */
86
+ MRB_API mrb_value mrb_hash_fetch(mrb_state *mrb, mrb_value hash, mrb_value key, mrb_value def);
87
+
88
+ /*
89
+ * Deletes hash key and value pair.
90
+ *
91
+ * Equivalent to:
92
+ *
93
+ * hash.delete(key)
94
+ *
95
+ * @param mrb The mruby state reference.
96
+ * @param hash The target hash.
97
+ * @param key The key to delete.
98
+ * @return The deleted value.
99
+ */
100
+ MRB_API mrb_value mrb_hash_delete_key(mrb_state *mrb, mrb_value hash, mrb_value key);
101
+
102
+ /*
103
+ * Gets an array of keys.
104
+ *
105
+ * Equivalent to:
106
+ *
107
+ * hash.keys
108
+ *
109
+ * @param mrb The mruby state reference.
110
+ * @param hash The target hash.
111
+ * @return An array with the keys of the hash.
112
+ */
113
+ MRB_API mrb_value mrb_hash_keys(mrb_state *mrb, mrb_value hash);
114
+ /*
115
+ * Check if the hash has the key.
116
+ *
117
+ * Equivalent to:
118
+ *
119
+ * hash.key?(key)
120
+ *
121
+ * @param mrb The mruby state reference.
122
+ * @param hash The target hash.
123
+ * @param key The key to check existence.
124
+ * @return True if the hash has the key
125
+ */
126
+ MRB_API mrb_bool mrb_hash_key_p(mrb_state *mrb, mrb_value hash, mrb_value key);
127
+
128
+ /*
129
+ * Check if the hash is empty
130
+ *
131
+ * Equivalent to:
132
+ *
133
+ * hash.empty?
134
+ *
135
+ * @param mrb The mruby state reference.
136
+ * @param self The target hash.
137
+ * @return True if the hash is empty, false otherwise.
138
+ */
139
+ MRB_API mrb_bool mrb_hash_empty_p(mrb_state *mrb, mrb_value self);
140
+
141
+ /*
142
+ * Gets an array of values.
143
+ *
144
+ * Equivalent to:
145
+ *
146
+ * hash.values
147
+ *
148
+ * @param mrb The mruby state reference.
149
+ * @param hash The target hash.
150
+ * @return An array with the values of the hash.
151
+ */
152
+ MRB_API mrb_value mrb_hash_values(mrb_state *mrb, mrb_value hash);
153
+
154
+ /*
155
+ * Clears the hash.
156
+ *
157
+ * Equivalent to:
158
+ *
159
+ * hash.clear
160
+ *
161
+ * @param mrb The mruby state reference.
162
+ * @param hash The target hash.
163
+ * @return The hash
164
+ */
165
+ MRB_API mrb_value mrb_hash_clear(mrb_state *mrb, mrb_value hash);
166
+
167
+ /*
168
+ * Get hash size.
169
+ *
170
+ * Equivalent to:
171
+ *
172
+ * hash.size
173
+ *
174
+ * @param mrb The mruby state reference.
175
+ * @param hash The target hash.
176
+ * @return The hash size.
177
+ */
178
+ MRB_API mrb_int mrb_hash_size(mrb_state *mrb, mrb_value hash);
179
+
180
+ /*
181
+ * Copies the hash.
182
+ *
183
+ *
184
+ * @param mrb The mruby state reference.
185
+ * @param hash The target hash.
186
+ * @return The copy of the hash
187
+ */
188
+ MRB_API mrb_value mrb_hash_dup(mrb_state *mrb, mrb_value hash);
189
+
190
+ /*
191
+ * Merges two hashes. The first hash will be modified by the
192
+ * second hash.
193
+ *
194
+ * @param mrb The mruby state reference.
195
+ * @param hash1 The target hash.
196
+ * @param hash2 Updating hash
197
+ */
198
+ MRB_API void mrb_hash_merge(mrb_state *mrb, mrb_value hash1, mrb_value hash2);
199
+
200
+ /* declaration of struct mrb_hash_value */
201
+ /* be careful when you touch the internal */
202
+ typedef struct {
203
+ mrb_value v;
204
+ mrb_int n;
205
+ } mrb_hash_value;
206
+
207
+ /* RHASH_TBL allocates st_table if not available. */
208
+ #define RHASH(obj) ((struct RHash*)(mrb_ptr(obj)))
209
+ #define RHASH_TBL(h) (RHASH(h)->ht)
210
+ #define RHASH_IFNONE(h) mrb_iv_get(mrb, (h), mrb_intern_lit(mrb, "ifnone"))
211
+ #define RHASH_PROCDEFAULT(h) RHASH_IFNONE(h)
212
+
213
+ #define MRB_HASH_DEFAULT 1
214
+ #define MRB_HASH_PROC_DEFAULT 2
215
+ #define MRB_RHASH_DEFAULT_P(h) (RHASH(h)->flags & MRB_HASH_DEFAULT)
216
+ #define MRB_RHASH_PROCDEFAULT_P(h) (RHASH(h)->flags & MRB_HASH_PROC_DEFAULT)
217
+
218
+ /* GC functions */
219
+ void mrb_gc_mark_hash(mrb_state*, struct RHash*);
220
+ size_t mrb_gc_mark_hash_size(mrb_state*, struct RHash*);
221
+ void mrb_gc_free_hash(mrb_state*, struct RHash*);
222
+
223
+ /* return non zero to break the loop */
224
+ typedef int (mrb_hash_foreach_func)(mrb_state *mrb, mrb_value key, mrb_value val, void *data);
225
+ MRB_API void mrb_hash_foreach(mrb_state *mrb, struct RHash *hash, mrb_hash_foreach_func *func, void *p);
226
+
227
+ MRB_END_DECL
228
+
229
+ #endif /* MRUBY_HASH_H */
@@ -0,0 +1,75 @@
1
+ /*
2
+ ** mruby/irep.h - mrb_irep structure
3
+ **
4
+ ** See Copyright Notice in mruby.h
5
+ */
6
+
7
+ #ifndef MRUBY_IREP_H
8
+ #define MRUBY_IREP_H
9
+
10
+ #include "common.h"
11
+ #include <mruby/compile.h>
12
+
13
+ /**
14
+ * Compiled mruby scripts.
15
+ */
16
+ MRB_BEGIN_DECL
17
+
18
+ enum irep_pool_type {
19
+ IREP_TT_STRING,
20
+ IREP_TT_FIXNUM,
21
+ IREP_TT_FLOAT,
22
+ };
23
+
24
+ struct mrb_locals {
25
+ mrb_sym name;
26
+ uint16_t r;
27
+ };
28
+
29
+ /* Program data array struct */
30
+ typedef struct mrb_irep {
31
+ uint16_t nlocals; /* Number of local variables */
32
+ uint16_t nregs; /* Number of register variables */
33
+ uint8_t flags;
34
+
35
+ mrb_code *iseq;
36
+ mrb_value *pool;
37
+ mrb_sym *syms;
38
+ struct mrb_irep **reps;
39
+
40
+ struct mrb_locals *lv;
41
+ /* debug info */
42
+ struct mrb_irep_debug_info* debug_info;
43
+
44
+ uint16_t ilen, plen, slen, rlen;
45
+ uint32_t refcnt;
46
+ } mrb_irep;
47
+
48
+ #define MRB_ISEQ_NO_FREE 1
49
+
50
+ MRB_API mrb_irep *mrb_add_irep(mrb_state *mrb);
51
+
52
+ /* @param [const uint8_t*] irep code, expected as a literal */
53
+ MRB_API mrb_value mrb_load_irep(mrb_state*, const uint8_t*);
54
+
55
+ /* @param [const uint8_t*] irep code, expected as a literal */
56
+ MRB_API mrb_value mrb_load_irep_cxt(mrb_state*, const uint8_t*, mrbc_context*);
57
+
58
+ void mrb_irep_free(mrb_state*, struct mrb_irep*);
59
+ void mrb_irep_incref(mrb_state*, struct mrb_irep*);
60
+ void mrb_irep_decref(mrb_state*, struct mrb_irep*);
61
+ void mrb_irep_cutref(mrb_state*, struct mrb_irep*);
62
+ void mrb_irep_remove_lv(mrb_state *mrb, mrb_irep *irep);
63
+
64
+ struct mrb_insn_data {
65
+ uint8_t insn;
66
+ uint16_t a;
67
+ uint16_t b;
68
+ uint8_t c;
69
+ };
70
+
71
+ struct mrb_insn_data mrb_decode_insn(mrb_code *pc);
72
+
73
+ MRB_END_DECL
74
+
75
+ #endif /* MRUBY_IREP_H */
@@ -0,0 +1,47 @@
1
+ /*
2
+ ** mruby/istruct.h - Inline structures
3
+ **
4
+ ** See Copyright Notice in mruby.h
5
+ */
6
+
7
+ #ifndef MRUBY_ISTRUCT_H
8
+ #define MRUBY_ISTRUCT_H
9
+
10
+ #include "common.h"
11
+ #include <string.h>
12
+
13
+ /**
14
+ * Inline structures that fit in RVALUE
15
+ *
16
+ * They cannot have finalizer, and cannot have instance variables.
17
+ */
18
+ MRB_BEGIN_DECL
19
+
20
+ #define ISTRUCT_DATA_SIZE (sizeof(void*) * 3)
21
+
22
+ struct RIstruct {
23
+ MRB_OBJECT_HEADER;
24
+ char inline_data[ISTRUCT_DATA_SIZE];
25
+ };
26
+
27
+ #define RISTRUCT(obj) ((struct RIstruct*)(mrb_ptr(obj)))
28
+ #define ISTRUCT_PTR(obj) (RISTRUCT(obj)->inline_data)
29
+
30
+ MRB_INLINE mrb_int mrb_istruct_size()
31
+ {
32
+ return ISTRUCT_DATA_SIZE;
33
+ }
34
+
35
+ MRB_INLINE void* mrb_istruct_ptr(mrb_value object)
36
+ {
37
+ return ISTRUCT_PTR(object);
38
+ }
39
+
40
+ MRB_INLINE void mrb_istruct_copy(mrb_value dest, mrb_value src)
41
+ {
42
+ memcpy(ISTRUCT_PTR(dest), ISTRUCT_PTR(src), ISTRUCT_DATA_SIZE);
43
+ }
44
+
45
+ MRB_END_DECL
46
+
47
+ #endif /* MRUBY_ISTRUCT_H */
@@ -0,0 +1,274 @@
1
+ /*
2
+ ** mruby/khash.c - Hash for mruby
3
+ **
4
+ ** See Copyright Notice in mruby.h
5
+ */
6
+
7
+ #ifndef MRUBY_KHASH_H
8
+ #define MRUBY_KHASH_H
9
+
10
+ #include <string.h>
11
+
12
+ #include <mruby.h>
13
+ #include "common.h"
14
+
15
+ /**
16
+ * khash definitions used in mruby's hash table.
17
+ */
18
+ MRB_BEGIN_DECL
19
+
20
+ typedef uint32_t khint_t;
21
+ typedef khint_t khiter_t;
22
+
23
+ #ifndef KHASH_DEFAULT_SIZE
24
+ # define KHASH_DEFAULT_SIZE 32
25
+ #endif
26
+ #define KHASH_MIN_SIZE 8
27
+
28
+ #define UPPER_BOUND(x) ((x)>>2|(x)>>1)
29
+
30
+ /* extern uint8_t __m[]; */
31
+
32
+ /* mask for flags */
33
+ static const uint8_t __m_empty[] = {0x02, 0x08, 0x20, 0x80};
34
+ static const uint8_t __m_del[] = {0x01, 0x04, 0x10, 0x40};
35
+ static const uint8_t __m_either[] = {0x03, 0x0c, 0x30, 0xc0};
36
+
37
+
38
+ #define __ac_isempty(ed_flag, i) (ed_flag[(i)/4]&__m_empty[(i)%4])
39
+ #define __ac_isdel(ed_flag, i) (ed_flag[(i)/4]&__m_del[(i)%4])
40
+ #define __ac_iseither(ed_flag, i) (ed_flag[(i)/4]&__m_either[(i)%4])
41
+ #define khash_power2(v) do { \
42
+ v--;\
43
+ v |= v >> 1;\
44
+ v |= v >> 2;\
45
+ v |= v >> 4;\
46
+ v |= v >> 8;\
47
+ v |= v >> 16;\
48
+ v++;\
49
+ } while (0)
50
+ #define khash_mask(h) ((h)->n_buckets-1)
51
+ #define khash_upper_bound(h) (UPPER_BOUND((h)->n_buckets))
52
+
53
+ /* declare struct kh_xxx and kh_xxx_funcs
54
+
55
+ name: hash name
56
+ khkey_t: key data type
57
+ khval_t: value data type
58
+ kh_is_map: (0: hash set / 1: hash map)
59
+ */
60
+ #define KHASH_DECLARE(name, khkey_t, khval_t, kh_is_map) \
61
+ typedef struct kh_##name { \
62
+ khint_t n_buckets; \
63
+ khint_t size; \
64
+ khint_t n_occupied; \
65
+ uint8_t *ed_flags; \
66
+ khkey_t *keys; \
67
+ khval_t *vals; \
68
+ } kh_##name##_t; \
69
+ void kh_alloc_##name(mrb_state *mrb, kh_##name##_t *h); \
70
+ kh_##name##_t *kh_init_##name##_size(mrb_state *mrb, khint_t size); \
71
+ kh_##name##_t *kh_init_##name(mrb_state *mrb); \
72
+ void kh_destroy_##name(mrb_state *mrb, kh_##name##_t *h); \
73
+ void kh_clear_##name(mrb_state *mrb, kh_##name##_t *h); \
74
+ khint_t kh_get_##name(mrb_state *mrb, kh_##name##_t *h, khkey_t key); \
75
+ khint_t kh_put_##name(mrb_state *mrb, kh_##name##_t *h, khkey_t key, int *ret); \
76
+ void kh_resize_##name(mrb_state *mrb, kh_##name##_t *h, khint_t new_n_buckets); \
77
+ void kh_del_##name(mrb_state *mrb, kh_##name##_t *h, khint_t x); \
78
+ kh_##name##_t *kh_copy_##name(mrb_state *mrb, kh_##name##_t *h);
79
+
80
+ static inline void
81
+ kh_fill_flags(uint8_t *p, uint8_t c, size_t len)
82
+ {
83
+ while (len-- > 0) {
84
+ *p++ = c;
85
+ }
86
+ }
87
+
88
+ /* define kh_xxx_funcs
89
+
90
+ name: hash name
91
+ khkey_t: key data type
92
+ khval_t: value data type
93
+ kh_is_map: (0: hash set / 1: hash map)
94
+ __hash_func: hash function
95
+ __hash_equal: hash comparation function
96
+ */
97
+ #define KHASH_DEFINE(name, khkey_t, khval_t, kh_is_map, __hash_func, __hash_equal) \
98
+ void kh_alloc_##name(mrb_state *mrb, kh_##name##_t *h) \
99
+ { \
100
+ khint_t sz = h->n_buckets; \
101
+ size_t len = sizeof(khkey_t) + (kh_is_map ? sizeof(khval_t) : 0); \
102
+ uint8_t *p = (uint8_t*)mrb_malloc(mrb, sizeof(uint8_t)*sz/4+len*sz); \
103
+ h->size = h->n_occupied = 0; \
104
+ h->keys = (khkey_t *)p; \
105
+ h->vals = kh_is_map ? (khval_t *)(p+sizeof(khkey_t)*sz) : NULL; \
106
+ h->ed_flags = p+len*sz; \
107
+ kh_fill_flags(h->ed_flags, 0xaa, sz/4); \
108
+ } \
109
+ kh_##name##_t *kh_init_##name##_size(mrb_state *mrb, khint_t size) { \
110
+ kh_##name##_t *h = (kh_##name##_t*)mrb_calloc(mrb, 1, sizeof(kh_##name##_t)); \
111
+ if (size < KHASH_MIN_SIZE) \
112
+ size = KHASH_MIN_SIZE; \
113
+ khash_power2(size); \
114
+ h->n_buckets = size; \
115
+ kh_alloc_##name(mrb, h); \
116
+ return h; \
117
+ } \
118
+ kh_##name##_t *kh_init_##name(mrb_state *mrb) { \
119
+ return kh_init_##name##_size(mrb, KHASH_DEFAULT_SIZE); \
120
+ } \
121
+ void kh_destroy_##name(mrb_state *mrb, kh_##name##_t *h) \
122
+ { \
123
+ if (h) { \
124
+ mrb_free(mrb, h->keys); \
125
+ mrb_free(mrb, h); \
126
+ } \
127
+ } \
128
+ void kh_clear_##name(mrb_state *mrb, kh_##name##_t *h) \
129
+ { \
130
+ (void)mrb; \
131
+ if (h && h->ed_flags) { \
132
+ kh_fill_flags(h->ed_flags, 0xaa, h->n_buckets/4); \
133
+ h->size = h->n_occupied = 0; \
134
+ } \
135
+ } \
136
+ khint_t kh_get_##name(mrb_state *mrb, kh_##name##_t *h, khkey_t key) \
137
+ { \
138
+ khint_t k = __hash_func(mrb,key) & khash_mask(h), step = 0; \
139
+ (void)mrb; \
140
+ while (!__ac_isempty(h->ed_flags, k)) { \
141
+ if (!__ac_isdel(h->ed_flags, k)) { \
142
+ if (__hash_equal(mrb,h->keys[k], key)) return k; \
143
+ } \
144
+ k = (k+(++step)) & khash_mask(h); \
145
+ } \
146
+ return kh_end(h); \
147
+ } \
148
+ void kh_resize_##name(mrb_state *mrb, kh_##name##_t *h, khint_t new_n_buckets) \
149
+ { \
150
+ if (new_n_buckets < KHASH_MIN_SIZE) \
151
+ new_n_buckets = KHASH_MIN_SIZE; \
152
+ khash_power2(new_n_buckets); \
153
+ { \
154
+ kh_##name##_t hh; \
155
+ uint8_t *old_ed_flags = h->ed_flags; \
156
+ khkey_t *old_keys = h->keys; \
157
+ khval_t *old_vals = h->vals; \
158
+ khint_t old_n_buckets = h->n_buckets; \
159
+ khint_t i; \
160
+ hh.n_buckets = new_n_buckets; \
161
+ kh_alloc_##name(mrb, &hh); \
162
+ /* relocate */ \
163
+ for (i=0 ; i<old_n_buckets ; i++) { \
164
+ if (!__ac_iseither(old_ed_flags, i)) { \
165
+ khint_t k = kh_put_##name(mrb, &hh, old_keys[i], NULL); \
166
+ if (kh_is_map) kh_value(&hh,k) = old_vals[i]; \
167
+ } \
168
+ } \
169
+ /* copy hh to h */ \
170
+ *h = hh; \
171
+ mrb_free(mrb, old_keys); \
172
+ } \
173
+ } \
174
+ khint_t kh_put_##name(mrb_state *mrb, kh_##name##_t *h, khkey_t key, int *ret) \
175
+ { \
176
+ khint_t k, del_k, step = 0; \
177
+ if (h->n_occupied >= khash_upper_bound(h)) { \
178
+ kh_resize_##name(mrb, h, h->n_buckets*2); \
179
+ } \
180
+ k = __hash_func(mrb,key) & khash_mask(h); \
181
+ del_k = kh_end(h); \
182
+ while (!__ac_isempty(h->ed_flags, k)) { \
183
+ if (!__ac_isdel(h->ed_flags, k)) { \
184
+ if (__hash_equal(mrb,h->keys[k], key)) { \
185
+ if (ret) *ret = 0; \
186
+ return k; \
187
+ } \
188
+ } \
189
+ else if (del_k == kh_end(h)) { \
190
+ del_k = k; \
191
+ } \
192
+ k = (k+(++step)) & khash_mask(h); \
193
+ } \
194
+ if (del_k != kh_end(h)) { \
195
+ /* put at del */ \
196
+ h->keys[del_k] = key; \
197
+ h->ed_flags[del_k/4] &= ~__m_del[del_k%4]; \
198
+ h->size++; \
199
+ if (ret) *ret = 2; \
200
+ return del_k; \
201
+ } \
202
+ else { \
203
+ /* put at empty */ \
204
+ h->keys[k] = key; \
205
+ h->ed_flags[k/4] &= ~__m_empty[k%4]; \
206
+ h->size++; \
207
+ h->n_occupied++; \
208
+ if (ret) *ret = 1; \
209
+ return k; \
210
+ } \
211
+ } \
212
+ void kh_del_##name(mrb_state *mrb, kh_##name##_t *h, khint_t x) \
213
+ { \
214
+ (void)mrb; \
215
+ mrb_assert(x != h->n_buckets && !__ac_iseither(h->ed_flags, x)); \
216
+ h->ed_flags[x/4] |= __m_del[x%4]; \
217
+ h->size--; \
218
+ } \
219
+ kh_##name##_t *kh_copy_##name(mrb_state *mrb, kh_##name##_t *h) \
220
+ { \
221
+ kh_##name##_t *h2; \
222
+ khiter_t k, k2; \
223
+ \
224
+ h2 = kh_init_##name(mrb); \
225
+ for (k = kh_begin(h); k != kh_end(h); k++) { \
226
+ if (kh_exist(h, k)) { \
227
+ k2 = kh_put_##name(mrb, h2, kh_key(h, k), NULL); \
228
+ if (kh_is_map) kh_value(h2, k2) = kh_value(h, k); \
229
+ } \
230
+ } \
231
+ return h2; \
232
+ }
233
+
234
+
235
+ #define khash_t(name) kh_##name##_t
236
+
237
+ #define kh_init_size(name,mrb,size) kh_init_##name##_size(mrb,size)
238
+ #define kh_init(name,mrb) kh_init_##name(mrb)
239
+ #define kh_destroy(name, mrb, h) kh_destroy_##name(mrb, h)
240
+ #define kh_clear(name, mrb, h) kh_clear_##name(mrb, h)
241
+ #define kh_resize(name, mrb, h, s) kh_resize_##name(mrb, h, s)
242
+ #define kh_put(name, mrb, h, k) kh_put_##name(mrb, h, k, NULL)
243
+ #define kh_put2(name, mrb, h, k, r) kh_put_##name(mrb, h, k, r)
244
+ #define kh_get(name, mrb, h, k) kh_get_##name(mrb, h, k)
245
+ #define kh_del(name, mrb, h, k) kh_del_##name(mrb, h, k)
246
+ #define kh_copy(name, mrb, h) kh_copy_##name(mrb, h)
247
+
248
+ #define kh_exist(h, x) (!__ac_iseither((h)->ed_flags, (x)))
249
+ #define kh_key(h, x) ((h)->keys[x])
250
+ #define kh_val(h, x) ((h)->vals[x])
251
+ #define kh_value(h, x) ((h)->vals[x])
252
+ #define kh_begin(h) (khint_t)(0)
253
+ #define kh_end(h) ((h)->n_buckets)
254
+ #define kh_size(h) ((h)->size)
255
+ #define kh_n_buckets(h) ((h)->n_buckets)
256
+
257
+ #define kh_int_hash_func(mrb,key) (khint_t)((key)^((key)<<2)^((key)>>2))
258
+ #define kh_int_hash_equal(mrb,a, b) (a == b)
259
+ #define kh_int64_hash_func(mrb,key) (khint_t)((key)>>33^(key)^(key)<<11)
260
+ #define kh_int64_hash_equal(mrb,a, b) (a == b)
261
+ static inline khint_t __ac_X31_hash_string(const char *s)
262
+ {
263
+ khint_t h = *s;
264
+ if (h) for (++s ; *s; ++s) h = (h << 5) - h + *s;
265
+ return h;
266
+ }
267
+ #define kh_str_hash_func(mrb,key) __ac_X31_hash_string(key)
268
+ #define kh_str_hash_equal(mrb,a, b) (strcmp(a, b) == 0)
269
+
270
+ typedef const char *kh_cstr_t;
271
+
272
+ MRB_END_DECL
273
+
274
+ #endif /* MRUBY_KHASH_H */