prometheus-client-mmap 0.22.0-x86_64-linux-musl → 1.2.1-x86_64-linux-musl

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.
Files changed (71) hide show
  1. checksums.yaml +4 -4
  2. data/.tool-versions +1 -0
  3. data/README.md +32 -17
  4. data/ext/fast_mmaped_file_rs/Cargo.toml +14 -9
  5. data/ext/fast_mmaped_file_rs/build.rs +5 -0
  6. data/ext/fast_mmaped_file_rs/extconf.rb +1 -3
  7. data/ext/fast_mmaped_file_rs/src/error.rs +2 -2
  8. data/ext/fast_mmaped_file_rs/src/file_entry.rs +222 -17
  9. data/ext/fast_mmaped_file_rs/src/file_info.rs +56 -6
  10. data/ext/fast_mmaped_file_rs/src/lib.rs +0 -1
  11. data/ext/fast_mmaped_file_rs/src/map.rs +12 -12
  12. data/ext/fast_mmaped_file_rs/src/mmap/inner.rs +6 -10
  13. data/ext/fast_mmaped_file_rs/src/mmap.rs +225 -47
  14. data/ext/fast_mmaped_file_rs/src/raw_entry.rs +1 -1
  15. data/ext/fast_mmaped_file_rs/src/testhelper.rs +1 -1
  16. data/lib/3.1/fast_mmaped_file_rs.so +0 -0
  17. data/lib/3.2/fast_mmaped_file_rs.so +0 -0
  18. data/lib/3.3/fast_mmaped_file_rs.so +0 -0
  19. data/lib/3.4/fast_mmaped_file_rs.so +0 -0
  20. data/lib/prometheus/client/formats/text.rb +1 -34
  21. data/lib/prometheus/client/helper/mmaped_file.rb +3 -3
  22. data/lib/prometheus/client/label_set_validator.rb +1 -2
  23. data/lib/prometheus/client/support/puma.rb +44 -0
  24. data/lib/prometheus/client/version.rb +1 -1
  25. metadata +62 -61
  26. data/ext/fast_mmaped_file/extconf.rb +0 -30
  27. data/ext/fast_mmaped_file/fast_mmaped_file.c +0 -122
  28. data/ext/fast_mmaped_file/file_format.c +0 -5
  29. data/ext/fast_mmaped_file/file_format.h +0 -11
  30. data/ext/fast_mmaped_file/file_parsing.c +0 -195
  31. data/ext/fast_mmaped_file/file_parsing.h +0 -27
  32. data/ext/fast_mmaped_file/file_reading.c +0 -102
  33. data/ext/fast_mmaped_file/file_reading.h +0 -30
  34. data/ext/fast_mmaped_file/globals.h +0 -14
  35. data/ext/fast_mmaped_file/mmap.c +0 -427
  36. data/ext/fast_mmaped_file/mmap.h +0 -61
  37. data/ext/fast_mmaped_file/rendering.c +0 -199
  38. data/ext/fast_mmaped_file/rendering.h +0 -8
  39. data/ext/fast_mmaped_file/utils.c +0 -56
  40. data/ext/fast_mmaped_file/utils.h +0 -22
  41. data/ext/fast_mmaped_file/value_access.c +0 -242
  42. data/ext/fast_mmaped_file/value_access.h +0 -15
  43. data/ext/fast_mmaped_file_rs/.cargo/config.toml +0 -23
  44. data/ext/fast_mmaped_file_rs/Cargo.lock +0 -790
  45. data/ext/fast_mmaped_file_rs/src/parser.rs +0 -346
  46. data/lib/2.7/fast_mmaped_file.so +0 -0
  47. data/lib/2.7/fast_mmaped_file_rs.so +0 -0
  48. data/lib/3.0/fast_mmaped_file.so +0 -0
  49. data/lib/3.0/fast_mmaped_file_rs.so +0 -0
  50. data/lib/3.1/fast_mmaped_file.so +0 -0
  51. data/lib/3.2/fast_mmaped_file.so +0 -0
  52. data/vendor/c/hashmap/.gitignore +0 -52
  53. data/vendor/c/hashmap/LICENSE +0 -21
  54. data/vendor/c/hashmap/README.md +0 -90
  55. data/vendor/c/hashmap/_config.yml +0 -1
  56. data/vendor/c/hashmap/src/hashmap.c +0 -692
  57. data/vendor/c/hashmap/src/hashmap.h +0 -267
  58. data/vendor/c/hashmap/test/Makefile +0 -22
  59. data/vendor/c/hashmap/test/hashmap_test.c +0 -608
  60. data/vendor/c/jsmn/.travis.yml +0 -4
  61. data/vendor/c/jsmn/LICENSE +0 -20
  62. data/vendor/c/jsmn/Makefile +0 -41
  63. data/vendor/c/jsmn/README.md +0 -168
  64. data/vendor/c/jsmn/example/jsondump.c +0 -126
  65. data/vendor/c/jsmn/example/simple.c +0 -76
  66. data/vendor/c/jsmn/jsmn.c +0 -314
  67. data/vendor/c/jsmn/jsmn.h +0 -76
  68. data/vendor/c/jsmn/library.json +0 -16
  69. data/vendor/c/jsmn/test/test.h +0 -27
  70. data/vendor/c/jsmn/test/tests.c +0 -407
  71. data/vendor/c/jsmn/test/testutil.h +0 -94
@@ -1,199 +0,0 @@
1
- #include "rendering.h"
2
-
3
- #include <float.h>
4
- #include <jsmn.h>
5
-
6
- #include "file_parsing.h"
7
- #include "globals.h"
8
- #include "utils.h"
9
-
10
- #ifndef DBL_DECIMAL_DIG
11
- #define DBL_DECIMAL_DIG 17
12
- #endif
13
-
14
- #define LABELS_START_OFFSET 4
15
-
16
- static inline int is_valid(const jsmntok_t *token) { return token->start < token->end && token->start >= 0; }
17
- static inline int valid_not_null(const entry_t *entry, const jsmntok_t *token) {
18
- static const char null_s[] = "null";
19
-
20
- if (!is_valid(token)) {
21
- return 0;
22
- }
23
-
24
- if (token->type != JSMN_PRIMITIVE) {
25
- return 1;
26
- }
27
-
28
- size_t token_len = token->end - token->start;
29
-
30
- if (token_len < sizeof(null_s) - 1) {
31
- return 1;
32
- }
33
-
34
- return strncmp(null_s, entry->json + token->start, sizeof(null_s) - 1) != 0;
35
- }
36
-
37
- static inline int append_token(VALUE string, const entry_t *entry, const jsmntok_t *token) {
38
- if (!is_valid(token)) {
39
- save_exception(prom_eParsingError, "parsing failed: %s", entry->json);
40
- return 0;
41
- }
42
-
43
- rb_str_cat(string, entry->json + token->start, token->end - token->start);
44
- return 1;
45
- }
46
-
47
- static int append_labels(VALUE string, const entry_t *entry, const int label_count, const jsmntok_t *tokens) {
48
- if (label_count <= 0) {
49
- if (is_pid_significant(entry)) {
50
- rb_str_cat(string, "{pid=\"", 6);
51
- rb_str_append(string, entry->pid);
52
- rb_str_cat(string, "\"}", 2);
53
- }
54
- return 1;
55
- }
56
-
57
- rb_str_cat(string, "{", 1);
58
-
59
- for (int i = 0; i < label_count; i++) {
60
- int key = LABELS_START_OFFSET + i;
61
- int val = LABELS_START_OFFSET + label_count + 1 + i;
62
-
63
- if (!append_token(string, entry, &tokens[key])) {
64
- return 0;
65
- }
66
- rb_str_cat(string, "=", 1);
67
-
68
- rb_str_cat(string, "\"", 1);
69
- if (valid_not_null(entry, &tokens[val])) {
70
- append_token(string, entry, &tokens[val]);
71
- }
72
- rb_str_cat(string, "\"", 1);
73
-
74
- if (i < label_count - 1) {
75
- rb_str_cat(string, ",", 1);
76
- }
77
- }
78
-
79
- if (is_pid_significant(entry)) {
80
- rb_str_cat(string, ",pid=\"", 6);
81
- rb_str_append(string, entry->pid);
82
- rb_str_cat(string, "\"", 1);
83
- }
84
-
85
- rb_str_cat(string, "}", 1);
86
- return 1;
87
- }
88
-
89
- static int validate_token_count(const int token_count, const entry_t *entry) {
90
- if (token_count < 0) {
91
- save_exception(prom_eParsingError, "too many labels or malformed json: %s", entry->json);
92
- return 0;
93
- }
94
-
95
- if (token_count < LABELS_START_OFFSET) {
96
- save_exception(prom_eParsingError, "malformed json: %s", entry->json);
97
- return 0;
98
- }
99
-
100
- if ((token_count - (LABELS_START_OFFSET + 1)) % 2 != 0) {
101
- save_exception(prom_eParsingError, "mismatched number of labels: %s", entry->json);
102
- return 0;
103
- }
104
-
105
- return 1;
106
- }
107
-
108
- static int append_entry(VALUE string, const entry_t *entry) {
109
- jsmn_parser parser;
110
- jsmn_init(&parser);
111
-
112
- jsmntok_t tokens[200];
113
- jsmntok_t *name_token = &tokens[2];
114
-
115
- int token_count = jsmn_parse(&parser, entry->json, entry->json_size, tokens, sizeof(tokens) / sizeof(tokens[0]));
116
- int label_count = (token_count - (LABELS_START_OFFSET + 1)) / 2;
117
-
118
- //
119
- // Example JSON "['metric', 'name',['label_a','label_b'],['value_a', 'value_b']]"
120
- // will be parsed into following token list:
121
- //
122
- // [ "'metric', 'name',['label_a','label_b'],['value_a', 'value_b']",
123
- // "metric", "name",
124
- // "['label_a','label_b']", "label_a", "label_b",
125
- // "['value_a', 'value_b']", "value_a", "value_b" ]
126
- //
127
- // where 'metric' is the name of the metric, while 'name'
128
- // is in summaries and histograms to store names of "submetrics" like:
129
- // histogram_name_bucket or histogram_name_sum
130
-
131
- if (!validate_token_count(token_count, entry)) {
132
- return 0;
133
- }
134
-
135
- if (!append_token(string, entry, name_token)) {
136
- return 0;
137
- }
138
-
139
- if (!append_labels(string, entry, label_count, tokens)) {
140
- return 0;
141
- }
142
-
143
- char value[255];
144
-
145
- // print value with highest possible precision so that we do not lose any data
146
- int written = snprintf(value, sizeof(value), " %.*g\n", DBL_DECIMAL_DIG, entry->value);
147
- rb_str_cat(string, value, written);
148
-
149
- return 1;
150
- }
151
-
152
- static void append_entry_head(VALUE string, const entry_t *entry) {
153
- static const char help_beg[] = "# HELP ";
154
- static const char help_fin[] = " Multiprocess metric\n";
155
-
156
- rb_str_cat(string, help_beg, sizeof(help_beg) - 1);
157
- rb_str_cat(string, entry->name, entry->name_len);
158
- rb_str_cat(string, help_fin, sizeof(help_fin) - 1);
159
-
160
- static const char type_beg[] = "# TYPE ";
161
-
162
- rb_str_cat(string, type_beg, sizeof(type_beg) - 1);
163
- rb_str_cat(string, entry->name, entry->name_len);
164
- rb_str_cat(string, " ", 1);
165
- rb_str_cat2(string, rb_id2name(entry->type));
166
- rb_str_cat(string, "\n", 1);
167
- }
168
-
169
- static inline int entry_name_equal(const entry_t *a, const entry_t *b) {
170
- if (a == NULL || b == NULL) {
171
- return a == b;
172
- }
173
-
174
- if (a->name_len != b->name_len) {
175
- return 0;
176
- }
177
-
178
- return strncmp(a->name, b->name, a->name_len) == 0;
179
- }
180
-
181
- int entries_to_string(VALUE string, entry_t **sorted_entries, size_t entries_count) {
182
- entry_t *previous = NULL;
183
-
184
- for (size_t i = 0; i < entries_count; i++) {
185
- entry_t *entry = sorted_entries[i];
186
-
187
- // when entry->name changes write metric header
188
- if (!entry_name_equal(previous, entry)) {
189
- previous = entry;
190
- append_entry_head(string, entry);
191
- }
192
-
193
- if (!append_entry(string, entry)) {
194
- return 0;
195
- }
196
- }
197
-
198
- return 1;
199
- }
@@ -1,8 +0,0 @@
1
- #ifndef RENDERING_H
2
- #define RENDERING_H
3
- #include <file_parsing.h>
4
- #include <ruby.h>
5
-
6
- int entries_to_string(VALUE string, entry_t **sorted_entries, size_t entries_count);
7
-
8
- #endif
@@ -1,56 +0,0 @@
1
- #include "utils.h"
2
-
3
- #include <errno.h>
4
-
5
- static void rb_save_exception(VALUE exception, VALUE message) {
6
- VALUE current_thread = rb_thread_current();
7
-
8
- rb_thread_local_aset(current_thread, rb_intern("prometheus_last_exception"), exception);
9
- rb_thread_local_aset(current_thread, rb_intern("prometheus_last_exception_message"), message);
10
- }
11
- /* @deprecated - use with_exception ignoring return value */
12
- void save_exception(VALUE exception, const char *fmt, ...) {
13
- va_list args;
14
-
15
- va_start(args, fmt);
16
- VALUE message = rb_vsprintf(fmt, args);
17
-
18
- rb_save_exception(exception, message);
19
- va_end(args);
20
- }
21
-
22
- int with_exception(VALUE exception, const char *fmt, ...) {
23
- va_list args;
24
-
25
- va_start(args, fmt);
26
- VALUE message = rb_vsprintf(fmt, args);
27
-
28
- rb_save_exception(exception, message);
29
- va_end(args);
30
-
31
- return FAILURE;
32
- }
33
-
34
- int with_exception_errno(VALUE exception, const char *fmt, ...) {
35
- va_list args;
36
-
37
- va_start(args, fmt);
38
- VALUE message = rb_vsprintf(fmt, args);
39
- rb_str_catf(message, " (%s)", strerror(errno));
40
-
41
- rb_save_exception(exception, message);
42
- va_end(args);
43
-
44
- return FAILURE;
45
- }
46
-
47
- NORETURN(void raise_last_exception()) {
48
- VALUE current_thread = rb_thread_current();
49
- VALUE exception = rb_thread_local_aref(current_thread, rb_intern("prometheus_last_exception"));
50
- VALUE message = rb_thread_local_aref(current_thread, rb_intern("prometheus_last_exception_message"));
51
- if (exception != Qnil) {
52
- rb_raise(exception, "%s", StringValueCStr(message));
53
- } else {
54
- rb_raise(rb_eRuntimeError, "no exception found in thread local");
55
- }
56
- }
@@ -1,22 +0,0 @@
1
- #ifndef UNUSED_H
2
- #define UNUSED_H
3
- #include <ruby.h>
4
-
5
- #ifdef UNUSED
6
- #elif defined(__GNUC__)
7
- #define UNUSED(x) UNUSED_##x __attribute__((unused))
8
- #elif defined(__LCLINT__)
9
- #define UNUSED(x) /*@unused@*/ x
10
- #else
11
- #define UNUSED(x) x
12
- #endif
13
-
14
- #define SUCCESS 1
15
- #define FAILURE 0
16
-
17
- NORETURN(void raise_last_exception());
18
- void save_exception(VALUE exception, const char *fmt, ...);
19
- int with_exception(VALUE exception, const char *fmt, ...);
20
- int with_exception_errno(VALUE exception, const char *fmt, ...);
21
-
22
- #endif
@@ -1,242 +0,0 @@
1
- #include "value_access.h"
2
-
3
- #include <errno.h>
4
- #include <fcntl.h>
5
- #include <ruby/intern.h>
6
- #include <sys/mman.h>
7
- #include <unistd.h>
8
-
9
- #include "file_format.h"
10
- #include "mmap.h"
11
- #include "utils.h"
12
-
13
- static void close_file(mm_ipc *i_mm) {
14
- close(i_mm->t->fd);
15
- i_mm->t->fd = -1;
16
- }
17
-
18
- static int open_and_extend_file(mm_ipc *i_mm, size_t len) {
19
- if (i_mm->t->fd < 0) {
20
- int fd;
21
-
22
- if ((fd = open(i_mm->t->path, i_mm->t->smode)) == -1) {
23
- return with_exception_errno(rb_eArgError, "%s: Can't open %s", __FILE__, i_mm->t->path);
24
- }
25
- i_mm->t->fd = fd;
26
- }
27
-
28
- if (lseek(i_mm->t->fd, len - 1, SEEK_SET) == -1) {
29
- close_file(i_mm);
30
- return with_exception_errno(rb_eIOError, "Can't lseek %zu", len - 1);
31
- }
32
-
33
- if (write(i_mm->t->fd, "\000", 1) != 1) {
34
- close_file(i_mm);
35
- return with_exception_errno(rb_eIOError, "Can't extend %s", i_mm->t->path);
36
- }
37
- i_mm->t->len = len;
38
-
39
- return SUCCESS;
40
- }
41
-
42
- static int perform_munmap(mm_ipc *i_mm) {
43
- if (i_mm->t->addr != NULL && munmap(i_mm->t->addr, i_mm->t->len)) {
44
- i_mm->t->addr = NULL;
45
- return with_exception_errno(rb_eArgError, "munmap failed");
46
- }
47
-
48
- i_mm->t->addr = NULL;
49
- i_mm->t->len = 0;
50
- i_mm->t->real = 0;
51
-
52
- return SUCCESS;
53
- }
54
-
55
- static int perform_mmap(mm_ipc *i_mm, size_t len) {
56
- MMAP_RETTYPE addr = mmap(0, len, i_mm->t->pmode, i_mm->t->vscope, i_mm->t->fd, i_mm->t->offset);
57
-
58
- if (addr == MAP_FAILED) {
59
- return with_exception_errno(rb_eArgError, "mmap failed");
60
- }
61
-
62
- i_mm->t->addr = addr;
63
- i_mm->t->len = len;
64
- i_mm->t->real = len;
65
-
66
- return SUCCESS;
67
- }
68
-
69
- static int expand(VALUE self, mm_ipc *i_mm, size_t len) {
70
- if (len < i_mm->t->len) {
71
- return with_exception(rb_eArgError, "Can't reduce the size of mmap");
72
- }
73
-
74
- if (!perform_munmap(i_mm)) {
75
- return FAILURE;
76
- }
77
-
78
- if (!open_and_extend_file(i_mm, len)) {
79
- return FAILURE;
80
- }
81
-
82
- if (!perform_mmap(i_mm, len)) {
83
- close_file(i_mm);
84
- return FAILURE;
85
- }
86
-
87
- if ((i_mm->t->flag & MM_LOCK) && mlock(i_mm->t->addr, len) == -1) {
88
- return with_exception_errno(rb_eArgError, "mlock(%d)", errno);
89
- }
90
-
91
- mm_update(self);
92
-
93
- return SUCCESS;
94
- }
95
-
96
- static void save_entry(mm_ipc *i_mm, size_t offset, VALUE key, VALUE value) {
97
- uint32_t key_length = (uint32_t)RSTRING_LEN(key);
98
-
99
- char *pos = (char *)i_mm->t->addr + offset;
100
-
101
- memcpy(pos, &key_length, sizeof(uint32_t));
102
- pos += sizeof(uint32_t);
103
-
104
- memmove(pos, StringValuePtr(key), key_length);
105
- pos += key_length;
106
-
107
- memset(pos, ' ', padding_length(key_length)); // TODO: considder padding with /0
108
- pos += padding_length(key_length);
109
-
110
- double val = NUM2DBL(value);
111
- memcpy(pos, &val, sizeof(double));
112
- }
113
-
114
- static void save_value(mm_ipc *i_mm, VALUE _offset, VALUE value) {
115
- Check_Type(_offset, T_FIXNUM);
116
- size_t offset = NUM2UINT(_offset);
117
- if ((i_mm->t->real + sizeof(double)) <= offset) {
118
- rb_raise(rb_eIndexError, "offset %zu out of string", offset);
119
- }
120
-
121
- if (i_mm->t->flag & MM_FROZEN) {
122
- rb_error_frozen("mmap");
123
- }
124
-
125
- char *pos = (char *)i_mm->t->addr + offset;
126
-
127
- double val = NUM2DBL(value);
128
- memcpy(pos, &val, sizeof(double));
129
- }
130
-
131
- static VALUE load_value(mm_ipc *i_mm, VALUE _offset) {
132
- Check_Type(_offset, T_FIXNUM);
133
- size_t offset = NUM2UINT(_offset);
134
- if ((i_mm->t->real + sizeof(double)) <= offset) {
135
- rb_raise(rb_eIndexError, "offset %zu out of string", offset);
136
- }
137
-
138
- char *pos = (char *)i_mm->t->addr + offset;
139
-
140
- double value;
141
- memcpy(&value, pos, sizeof(double));
142
- return DBL2NUM(value);
143
- }
144
-
145
- uint32_t load_used(mm_ipc *i_mm) {
146
- uint32_t used = *((uint32_t *)i_mm->t->addr);
147
-
148
- if (used == 0) {
149
- used = START_POSITION;
150
- }
151
- return used;
152
- }
153
-
154
- void save_used(mm_ipc *i_mm, uint32_t used) { *((uint32_t *)i_mm->t->addr) = used; }
155
-
156
- static VALUE initialize_entry(VALUE self, mm_ipc *i_mm, VALUE positions, VALUE key, VALUE value) {
157
- if (i_mm->t->flag & MM_FROZEN) {
158
- rb_error_frozen("mmap");
159
- }
160
-
161
- if (RSTRING_LEN(key) > INT32_MAX) {
162
- rb_raise(rb_eArgError, "string length gt %d", INT32_MAX);
163
- }
164
-
165
- uint32_t key_length = (uint32_t)RSTRING_LEN(key);
166
- uint32_t value_offset = sizeof(uint32_t) + key_length + padding_length(key_length);
167
- uint32_t entry_length = value_offset + sizeof(double);
168
-
169
- uint32_t used = load_used(i_mm);
170
- while (i_mm->t->len < (used + entry_length)) {
171
- if (!expand(self, i_mm, i_mm->t->len * 2)) {
172
- raise_last_exception();
173
- }
174
- }
175
-
176
- save_entry(i_mm, used, key, value);
177
- save_used(i_mm, used + entry_length);
178
-
179
- return rb_hash_aset(positions, key, INT2NUM(used + value_offset));
180
- }
181
-
182
- VALUE method_fetch_entry(VALUE self, VALUE positions, VALUE key, VALUE default_value) {
183
- Check_Type(positions, T_HASH);
184
- Check_Type(key, T_STRING);
185
-
186
- mm_ipc *i_mm;
187
- GET_MMAP(self, i_mm, MM_MODIFY);
188
-
189
- VALUE position = rb_hash_lookup(positions, key);
190
-
191
- if (position != Qnil) {
192
- return load_value(i_mm, position);
193
- }
194
-
195
- position = initialize_entry(self, i_mm, positions, key, default_value);
196
- return load_value(i_mm, position);
197
- }
198
-
199
- VALUE method_upsert_entry(VALUE self, VALUE positions, VALUE key, VALUE value) {
200
- Check_Type(positions, T_HASH);
201
- Check_Type(key, T_STRING);
202
-
203
- mm_ipc *i_mm;
204
- GET_MMAP(self, i_mm, MM_MODIFY);
205
-
206
- VALUE position = rb_hash_lookup(positions, key);
207
-
208
- if (position != Qnil) {
209
- save_value(i_mm, position, value);
210
- return load_value(i_mm, position);
211
- }
212
-
213
- position = initialize_entry(self, i_mm, positions, key, value);
214
- return load_value(i_mm, position);
215
- }
216
-
217
- VALUE method_load_used(VALUE self) {
218
- mm_ipc *i_mm;
219
-
220
- GET_MMAP(self, i_mm, MM_MODIFY);
221
- return UINT2NUM(load_used(i_mm));
222
- }
223
-
224
- VALUE method_save_used(VALUE self, VALUE value) {
225
- Check_Type(value, T_FIXNUM);
226
- mm_ipc *i_mm;
227
-
228
- GET_MMAP(self, i_mm, MM_MODIFY);
229
-
230
- if (i_mm->t->flag & MM_FROZEN) {
231
- rb_error_frozen("mmap");
232
- }
233
-
234
- if (i_mm->t->len < INITIAL_SIZE) {
235
- if (!expand(self, i_mm, INITIAL_SIZE)) {
236
- raise_last_exception();
237
- }
238
- }
239
-
240
- save_used(i_mm, NUM2UINT(value));
241
- return value;
242
- }
@@ -1,15 +0,0 @@
1
- #ifndef VALUE_ACCESS_H
2
- #define VALUE_ACCESS_H
3
- #include <ruby.h>
4
-
5
- VALUE method_load_used(VALUE self);
6
-
7
- VALUE method_save_used(VALUE self, VALUE value);
8
-
9
- VALUE method_get_double(VALUE self, VALUE index);
10
-
11
- VALUE method_fetch_entry(VALUE self, VALUE positions, VALUE key, VALUE default_value);
12
-
13
- VALUE method_upsert_entry(VALUE self, VALUE positions, VALUE key, VALUE value);
14
-
15
- #endif
@@ -1,23 +0,0 @@
1
- [target.aarch64-apple-darwin]
2
- # Without this flag, when linking static libruby, the linker removes symbols
3
- # (such as `_rb_ext_ractor_safe`) which it thinks are dead code... but they are
4
- # not, and they need to be included for the `embed` feature to work with static
5
- # Ruby.
6
- rustflags = [
7
- "-C", "link-dead-code=on",
8
- "-C", "link-arg=-undefined",
9
- "-C", "link-arg=dynamic_lookup",
10
- ]
11
-
12
- [target.x86_64-apple-darwin]
13
- rustflags = [
14
- "-C", "link-dead-code=on",
15
- "-C", "link-arg=-undefined",
16
- "-C", "link-arg=dynamic_lookup",
17
- ]
18
-
19
- [target.aarch64-unknown-linux-gnu]
20
- rustflags = [ "-C", "link-dead-code=on" ]
21
-
22
- [target.x86_64-unknown-linux-gnu]
23
- rustflags = [ "-C", "link-dead-code=on" ]