debase-ruby_core_source 0.10.8 → 0.10.9

Sign up to get free protection for your applications and to get access to all the features.
Files changed (58) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +4 -0
  3. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/addr2line.h +21 -0
  4. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/builtin.h +78 -0
  5. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/ccan/build_assert/build_assert.h +40 -0
  6. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/ccan/check_type/check_type.h +63 -0
  7. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/ccan/container_of/container_of.h +142 -0
  8. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/ccan/list/list.h +788 -0
  9. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/ccan/str/str.h +16 -0
  10. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/constant.h +50 -0
  11. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/debug_counter.h +390 -0
  12. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/dln.h +51 -0
  13. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/encindex.h +69 -0
  14. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/eval_intern.h +312 -0
  15. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/gc.h +131 -0
  16. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/hrtime.h +168 -0
  17. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/id.h +290 -0
  18. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/id_table.h +34 -0
  19. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/insns.inc +253 -0
  20. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/insns_info.inc +9197 -0
  21. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/internal.h +2697 -0
  22. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/iseq.h +312 -0
  23. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/known_errors.inc +791 -0
  24. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/method.h +229 -0
  25. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/mjit.h +177 -0
  26. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/mjit_compile.inc +7779 -0
  27. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/node.h +476 -0
  28. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/node_name.inc +208 -0
  29. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/opt_sc.inc +109 -0
  30. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/optinsn.inc +128 -0
  31. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/optunifs.inc +43 -0
  32. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/parse.h +210 -0
  33. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/probes_helper.h +42 -0
  34. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/regenc.h +254 -0
  35. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/regint.h +938 -0
  36. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/regparse.h +370 -0
  37. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/revision.h +2 -0
  38. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/ruby_assert.h +15 -0
  39. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/ruby_atomic.h +244 -0
  40. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/siphash.h +48 -0
  41. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/symbol.h +119 -0
  42. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/thread_pthread.h +75 -0
  43. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/thread_win32.h +36 -0
  44. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/timev.h +56 -0
  45. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/transcode_data.h +139 -0
  46. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/transient_heap.h +62 -0
  47. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/variable.h +9 -0
  48. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/version.h +77 -0
  49. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/vm.inc +5466 -0
  50. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/vm_call_iseq_optimized.inc +237 -0
  51. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/vm_core.h +1968 -0
  52. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/vm_debug.h +34 -0
  53. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/vm_exec.h +193 -0
  54. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/vm_insnhelper.h +267 -0
  55. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/vm_opts.h +72 -0
  56. data/lib/debase/ruby_core_source/ruby-2.7.0-p0/vmtc.inc +247 -0
  57. data/lib/debase/ruby_core_source/version.rb +1 -1
  58. metadata +56 -2
@@ -0,0 +1,51 @@
1
+ /**********************************************************************
2
+
3
+ dln.h -
4
+
5
+ $Author$
6
+ created at: Wed Jan 19 16:53:09 JST 1994
7
+
8
+ Copyright (C) 1993-2007 Yukihiro Matsumoto
9
+
10
+ **********************************************************************/
11
+
12
+ #ifndef DLN_H
13
+ #define DLN_H
14
+
15
+ #ifdef __cplusplus
16
+ # ifndef HAVE_PROTOTYPES
17
+ # define HAVE_PROTOTYPES 1
18
+ # endif
19
+ # ifndef HAVE_STDARG_PROTOTYPES
20
+ # define HAVE_STDARG_PROTOTYPES 1
21
+ # endif
22
+ #endif
23
+
24
+ #undef _
25
+ #ifdef HAVE_PROTOTYPES
26
+ # define _(args) args
27
+ #else
28
+ # define _(args) ()
29
+ #endif
30
+
31
+ RUBY_SYMBOL_EXPORT_BEGIN
32
+
33
+ #ifndef DLN_FIND_EXTRA_ARG
34
+ #define DLN_FIND_EXTRA_ARG
35
+ #endif
36
+ #ifndef DLN_FIND_EXTRA_ARG_DECL
37
+ #define DLN_FIND_EXTRA_ARG_DECL
38
+ #endif
39
+
40
+ char *dln_find_exe_r(const char*,const char*,char*,size_t DLN_FIND_EXTRA_ARG_DECL);
41
+ char *dln_find_file_r(const char*,const char*,char*,size_t DLN_FIND_EXTRA_ARG_DECL);
42
+
43
+ #ifdef USE_DLN_A_OUT
44
+ extern char *dln_argv0;
45
+ #endif
46
+
47
+ void *dln_load(const char*);
48
+
49
+ RUBY_SYMBOL_EXPORT_END
50
+
51
+ #endif
@@ -0,0 +1,69 @@
1
+ /**********************************************************************
2
+
3
+ encindex.h -
4
+
5
+ $Author$
6
+ created at: Tue Sep 15 13:21:14 JST 2015
7
+
8
+ Copyright (C) 2015 Yukihiro Matsumoto
9
+
10
+ **********************************************************************/
11
+
12
+ #ifndef RUBY_ENCINDEX_H
13
+ #define RUBY_ENCINDEX_H 1
14
+ #if defined(__cplusplus)
15
+ extern "C" {
16
+ #if 0
17
+ } /* satisfy cc-mode */
18
+ #endif
19
+ #endif
20
+
21
+ enum ruby_preserved_encindex {
22
+ RUBY_ENCINDEX_ASCII,
23
+ RUBY_ENCINDEX_UTF_8,
24
+ RUBY_ENCINDEX_US_ASCII,
25
+
26
+ /* preserved indexes */
27
+ RUBY_ENCINDEX_UTF_16BE,
28
+ RUBY_ENCINDEX_UTF_16LE,
29
+ RUBY_ENCINDEX_UTF_32BE,
30
+ RUBY_ENCINDEX_UTF_32LE,
31
+ RUBY_ENCINDEX_UTF_16,
32
+ RUBY_ENCINDEX_UTF_32,
33
+ RUBY_ENCINDEX_UTF8_MAC,
34
+
35
+ /* for old options of regexp */
36
+ RUBY_ENCINDEX_EUC_JP,
37
+ RUBY_ENCINDEX_Windows_31J,
38
+
39
+ RUBY_ENCINDEX_BUILTIN_MAX
40
+ };
41
+
42
+ #define ENCINDEX_ASCII RUBY_ENCINDEX_ASCII
43
+ #define ENCINDEX_UTF_8 RUBY_ENCINDEX_UTF_8
44
+ #define ENCINDEX_US_ASCII RUBY_ENCINDEX_US_ASCII
45
+ #define ENCINDEX_UTF_16BE RUBY_ENCINDEX_UTF_16BE
46
+ #define ENCINDEX_UTF_16LE RUBY_ENCINDEX_UTF_16LE
47
+ #define ENCINDEX_UTF_32BE RUBY_ENCINDEX_UTF_32BE
48
+ #define ENCINDEX_UTF_32LE RUBY_ENCINDEX_UTF_32LE
49
+ #define ENCINDEX_UTF_16 RUBY_ENCINDEX_UTF_16
50
+ #define ENCINDEX_UTF_32 RUBY_ENCINDEX_UTF_32
51
+ #define ENCINDEX_UTF8_MAC RUBY_ENCINDEX_UTF8_MAC
52
+ #define ENCINDEX_EUC_JP RUBY_ENCINDEX_EUC_JP
53
+ #define ENCINDEX_Windows_31J RUBY_ENCINDEX_Windows_31J
54
+ #define ENCINDEX_BUILTIN_MAX RUBY_ENCINDEX_BUILTIN_MAX
55
+
56
+ #define rb_ascii8bit_encindex() RUBY_ENCINDEX_ASCII
57
+ #define rb_utf8_encindex() RUBY_ENCINDEX_UTF_8
58
+ #define rb_usascii_encindex() RUBY_ENCINDEX_US_ASCII
59
+
60
+ int rb_enc_find_index2(const char *name, long len);
61
+
62
+ #if defined(__cplusplus)
63
+ #if 0
64
+ { /* satisfy cc-mode */
65
+ #endif
66
+ } /* extern "C" { */
67
+ #endif
68
+
69
+ #endif /* RUBY_ENCINDEX_H */
@@ -0,0 +1,312 @@
1
+ #ifndef RUBY_EVAL_INTERN_H
2
+ #define RUBY_EVAL_INTERN_H
3
+
4
+ #include "ruby/ruby.h"
5
+ #include "vm_core.h"
6
+
7
+ static inline void
8
+ vm_passed_block_handler_set(rb_execution_context_t *ec, VALUE block_handler)
9
+ {
10
+ vm_block_handler_verify(block_handler);
11
+ ec->passed_block_handler = block_handler;
12
+ }
13
+
14
+ static inline void
15
+ pass_passed_block_handler(rb_execution_context_t *ec)
16
+ {
17
+ VALUE block_handler = rb_vm_frame_block_handler(ec->cfp);
18
+ vm_passed_block_handler_set(ec, block_handler);
19
+ VM_ENV_FLAGS_SET(ec->cfp->ep, VM_FRAME_FLAG_PASSED);
20
+ }
21
+
22
+ #define PASS_PASSED_BLOCK_HANDLER_EC(ec) pass_passed_block_handler(ec)
23
+ #define PASS_PASSED_BLOCK_HANDLER() pass_passed_block_handler(GET_EC())
24
+
25
+ #ifdef HAVE_STDLIB_H
26
+ #include <stdlib.h>
27
+ #endif
28
+ #ifndef EXIT_SUCCESS
29
+ #define EXIT_SUCCESS 0
30
+ #endif
31
+ #ifndef EXIT_FAILURE
32
+ #define EXIT_FAILURE 1
33
+ #endif
34
+
35
+ #include <stdio.h>
36
+ #include <setjmp.h>
37
+
38
+ #ifdef __APPLE__
39
+ # ifdef HAVE_CRT_EXTERNS_H
40
+ # include <crt_externs.h>
41
+ # else
42
+ # include "missing/crt_externs.h"
43
+ # endif
44
+ #endif
45
+
46
+ #ifndef HAVE_STRING_H
47
+ char *strrchr(const char *, const char);
48
+ #endif
49
+
50
+ #ifdef HAVE_UNISTD_H
51
+ #include <unistd.h>
52
+ #endif
53
+
54
+ #ifdef HAVE_NET_SOCKET_H
55
+ #include <net/socket.h>
56
+ #endif
57
+
58
+ #define ruby_setjmp(env) RUBY_SETJMP(env)
59
+ #define ruby_longjmp(env,val) RUBY_LONGJMP((env),(val))
60
+ #ifdef __CYGWIN__
61
+ # ifndef _setjmp
62
+ int _setjmp(jmp_buf);
63
+ # endif
64
+ # ifndef _longjmp
65
+ NORETURN(void _longjmp(jmp_buf, int));
66
+ # endif
67
+ #endif
68
+
69
+ #include <sys/types.h>
70
+ #include <signal.h>
71
+ #include <errno.h>
72
+
73
+ #ifdef HAVE_SYS_SELECT_H
74
+ #include <sys/select.h>
75
+ #endif
76
+
77
+ /*
78
+ Solaris sys/select.h switches select to select_large_fdset to support larger
79
+ file descriptors if FD_SETSIZE is larger than 1024 on 32bit environment.
80
+ But Ruby doesn't change FD_SETSIZE because fd_set is allocated dynamically.
81
+ So following definition is required to use select_large_fdset.
82
+ */
83
+ #ifdef HAVE_SELECT_LARGE_FDSET
84
+ #define select(n, r, w, e, t) select_large_fdset((n), (r), (w), (e), (t))
85
+ extern int select_large_fdset(int, fd_set *, fd_set *, fd_set *, struct timeval *);
86
+ #endif
87
+
88
+ #ifdef HAVE_SYS_PARAM_H
89
+ #include <sys/param.h>
90
+ #endif
91
+
92
+ #include <sys/stat.h>
93
+
94
+ #ifdef _MSC_VER
95
+ #define SAVE_ROOT_JMPBUF_BEFORE_STMT \
96
+ __try {
97
+ #define SAVE_ROOT_JMPBUF_AFTER_STMT \
98
+ } \
99
+ __except (GetExceptionCode() == EXCEPTION_STACK_OVERFLOW ? \
100
+ (rb_ec_raised_set(GET_EC(), RAISED_STACKOVERFLOW), \
101
+ raise(SIGSEGV), \
102
+ EXCEPTION_EXECUTE_HANDLER) : \
103
+ EXCEPTION_CONTINUE_SEARCH) { \
104
+ /* never reaches here */ \
105
+ }
106
+ #elif defined(__MINGW32__)
107
+ LONG WINAPI rb_w32_stack_overflow_handler(struct _EXCEPTION_POINTERS *);
108
+ #define SAVE_ROOT_JMPBUF_BEFORE_STMT \
109
+ do { \
110
+ PVOID _handler = AddVectoredExceptionHandler(1, rb_w32_stack_overflow_handler);
111
+
112
+ #define SAVE_ROOT_JMPBUF_AFTER_STMT \
113
+ RemoveVectoredExceptionHandler(_handler); \
114
+ } while (0);
115
+ #else
116
+ #define SAVE_ROOT_JMPBUF_BEFORE_STMT
117
+ #define SAVE_ROOT_JMPBUF_AFTER_STMT
118
+ #endif
119
+
120
+ #define SAVE_ROOT_JMPBUF(th, stmt) do \
121
+ if (ruby_setjmp((th)->root_jmpbuf) == 0) { \
122
+ SAVE_ROOT_JMPBUF_BEFORE_STMT \
123
+ stmt; \
124
+ SAVE_ROOT_JMPBUF_AFTER_STMT \
125
+ } \
126
+ else { \
127
+ rb_fiber_start(); \
128
+ } while (0)
129
+
130
+ #define EC_PUSH_TAG(ec) do { \
131
+ rb_execution_context_t * const _ec = (ec); \
132
+ struct rb_vm_tag _tag; \
133
+ _tag.state = TAG_NONE; \
134
+ _tag.tag = Qundef; \
135
+ _tag.prev = _ec->tag;
136
+
137
+ #define EC_POP_TAG() \
138
+ _ec->tag = _tag.prev; \
139
+ } while (0)
140
+
141
+ #define EC_TMPPOP_TAG() \
142
+ _ec->tag = _tag.prev
143
+
144
+ #define EC_REPUSH_TAG() (void)(_ec->tag = &_tag)
145
+
146
+ #if defined __GNUC__ && __GNUC__ == 4 && (__GNUC_MINOR__ >= 6 && __GNUC_MINOR__ <= 8) || __clang__
147
+ /* This macro prevents GCC 4.6--4.8 from emitting maybe-uninitialized warnings.
148
+ * This macro also prevents Clang from dumping core in EC_EXEC_TAG().
149
+ * (I confirmed Clang 4.0.1 and 5.0.0.)
150
+ */
151
+ # define VAR_FROM_MEMORY(var) __extension__(*(__typeof__(var) volatile *)&(var))
152
+ # define VAR_INITIALIZED(var) ((var) = VAR_FROM_MEMORY(var))
153
+ # define VAR_NOCLOBBERED(var) volatile var
154
+ #else
155
+ # define VAR_FROM_MEMORY(var) (var)
156
+ # define VAR_INITIALIZED(var) ((void)&(var))
157
+ # define VAR_NOCLOBBERED(var) var
158
+ #endif
159
+
160
+ /* clear ec->tag->state, and return the value */
161
+ static inline int
162
+ rb_ec_tag_state(const rb_execution_context_t *ec)
163
+ {
164
+ enum ruby_tag_type state = ec->tag->state;
165
+ ec->tag->state = TAG_NONE;
166
+ return state;
167
+ }
168
+
169
+ NORETURN(static inline void rb_ec_tag_jump(const rb_execution_context_t *ec, enum ruby_tag_type st));
170
+ static inline void
171
+ rb_ec_tag_jump(const rb_execution_context_t *ec, enum ruby_tag_type st)
172
+ {
173
+ ec->tag->state = st;
174
+ ruby_longjmp(ec->tag->buf, 1);
175
+ }
176
+
177
+ /*
178
+ setjmp() in assignment expression rhs is undefined behavior
179
+ [ISO/IEC 9899:1999] 7.13.1.1
180
+ */
181
+ #define EC_EXEC_TAG() \
182
+ (ruby_setjmp(_tag.buf) ? rb_ec_tag_state(VAR_FROM_MEMORY(_ec)) : (EC_REPUSH_TAG(), 0))
183
+
184
+ #define EC_JUMP_TAG(ec, st) rb_ec_tag_jump(ec, st)
185
+
186
+ #define INTERNAL_EXCEPTION_P(exc) FIXNUM_P(exc)
187
+
188
+ /* CREF operators */
189
+
190
+ #define CREF_FL_PUSHED_BY_EVAL IMEMO_FL_USER1
191
+ #define CREF_FL_OMOD_SHARED IMEMO_FL_USER2
192
+
193
+ static inline VALUE
194
+ CREF_CLASS(const rb_cref_t *cref)
195
+ {
196
+ return cref->klass;
197
+ }
198
+
199
+ static inline rb_cref_t *
200
+ CREF_NEXT(const rb_cref_t *cref)
201
+ {
202
+ return cref->next;
203
+ }
204
+
205
+ static inline const rb_scope_visibility_t *
206
+ CREF_SCOPE_VISI(const rb_cref_t *cref)
207
+ {
208
+ return &cref->scope_visi;
209
+ }
210
+
211
+ static inline VALUE
212
+ CREF_REFINEMENTS(const rb_cref_t *cref)
213
+ {
214
+ return cref->refinements;
215
+ }
216
+
217
+ static inline void
218
+ CREF_REFINEMENTS_SET(rb_cref_t *cref, VALUE refs)
219
+ {
220
+ RB_OBJ_WRITE(cref, &cref->refinements, refs);
221
+ }
222
+
223
+ static inline int
224
+ CREF_PUSHED_BY_EVAL(const rb_cref_t *cref)
225
+ {
226
+ return cref->flags & CREF_FL_PUSHED_BY_EVAL;
227
+ }
228
+
229
+ static inline void
230
+ CREF_PUSHED_BY_EVAL_SET(rb_cref_t *cref)
231
+ {
232
+ cref->flags |= CREF_FL_PUSHED_BY_EVAL;
233
+ }
234
+
235
+ static inline int
236
+ CREF_OMOD_SHARED(const rb_cref_t *cref)
237
+ {
238
+ return cref->flags & CREF_FL_OMOD_SHARED;
239
+ }
240
+
241
+ static inline void
242
+ CREF_OMOD_SHARED_SET(rb_cref_t *cref)
243
+ {
244
+ cref->flags |= CREF_FL_OMOD_SHARED;
245
+ }
246
+
247
+ static inline void
248
+ CREF_OMOD_SHARED_UNSET(rb_cref_t *cref)
249
+ {
250
+ cref->flags &= ~CREF_FL_OMOD_SHARED;
251
+ }
252
+
253
+ enum {
254
+ RAISED_EXCEPTION = 1,
255
+ RAISED_STACKOVERFLOW = 2,
256
+ RAISED_NOMEMORY = 4
257
+ };
258
+ #define rb_ec_raised_set(ec, f) ((ec)->raised_flag |= (f))
259
+ #define rb_ec_raised_reset(ec, f) ((ec)->raised_flag &= ~(f))
260
+ #define rb_ec_raised_p(ec, f) (((ec)->raised_flag & (f)) != 0)
261
+ #define rb_ec_raised_clear(ec) ((ec)->raised_flag = 0)
262
+ int rb_ec_set_raised(rb_execution_context_t *ec);
263
+ int rb_ec_reset_raised(rb_execution_context_t *ec);
264
+ int rb_ec_stack_check(rb_execution_context_t *ec);
265
+
266
+ VALUE rb_f_eval(int argc, const VALUE *argv, VALUE self);
267
+ VALUE rb_make_exception(int argc, const VALUE *argv);
268
+
269
+ NORETURN(void rb_method_name_error(VALUE, VALUE));
270
+
271
+ NORETURN(void rb_fiber_start(void));
272
+
273
+ NORETURN(void rb_print_undef(VALUE, ID, rb_method_visibility_t));
274
+ NORETURN(void rb_print_undef_str(VALUE, VALUE));
275
+ NORETURN(void rb_print_inaccessible(VALUE, ID, rb_method_visibility_t));
276
+ NORETURN(void rb_vm_localjump_error(const char *,VALUE, int));
277
+ NORETURN(void rb_vm_jump_tag_but_local_jump(int));
278
+
279
+ VALUE rb_vm_make_jump_tag_but_local_jump(int state, VALUE val);
280
+ rb_cref_t *rb_vm_cref(void);
281
+ rb_cref_t *rb_vm_cref_replace_with_duplicated_cref(void);
282
+ VALUE rb_vm_call_cfunc(VALUE recv, VALUE (*func)(VALUE), VALUE arg, VALUE block_handler, VALUE filename);
283
+ void rb_vm_set_progname(VALUE filename);
284
+ void rb_thread_terminate_all(void);
285
+ VALUE rb_vm_cbase(void);
286
+
287
+ /* vm_backtrace.c */
288
+ VALUE rb_ec_backtrace_object(const rb_execution_context_t *ec);
289
+ VALUE rb_ec_backtrace_str_ary(const rb_execution_context_t *ec, long lev, long n);
290
+ VALUE rb_ec_backtrace_location_ary(const rb_execution_context_t *ec, long lev, long n);
291
+
292
+ #ifndef CharNext /* defined as CharNext[AW] on Windows. */
293
+ # ifdef HAVE_MBLEN
294
+ # define CharNext(p) ((p) + mblen((p), RUBY_MBCHAR_MAXSIZE))
295
+ # else
296
+ # define CharNext(p) ((p) + 1)
297
+ # endif
298
+ #endif
299
+
300
+ #if defined DOSISH || defined __CYGWIN__
301
+ static inline void
302
+ translit_char(char *p, int from, int to)
303
+ {
304
+ while (*p) {
305
+ if ((unsigned char)*p == from)
306
+ *p = to;
307
+ p = CharNext(p);
308
+ }
309
+ }
310
+ #endif
311
+
312
+ #endif /* RUBY_EVAL_INTERN_H */
@@ -0,0 +1,131 @@
1
+
2
+ #ifndef RUBY_GC_H
3
+ #define RUBY_GC_H 1
4
+
5
+ #if defined(__x86_64__) && !defined(_ILP32) && defined(__GNUC__)
6
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("movq\t%%rsp, %0" : "=r" (*(p)))
7
+ #elif defined(__i386) && defined(__GNUC__)
8
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("movl\t%%esp, %0" : "=r" (*(p)))
9
+ #elif defined(__powerpc64__) && defined(__GNUC__)
10
+ #define SET_MACHINE_STACK_END(p) __asm__ __volatile__ ("mr\t%0, %%r1" : "=r" (*(p)))
11
+ #else
12
+ NOINLINE(void rb_gc_set_stack_end(VALUE **stack_end_p));
13
+ #define SET_MACHINE_STACK_END(p) rb_gc_set_stack_end(p)
14
+ #define USE_CONSERVATIVE_STACK_END
15
+ #endif
16
+
17
+ /* for GC debug */
18
+
19
+ #ifndef RUBY_MARK_FREE_DEBUG
20
+ #define RUBY_MARK_FREE_DEBUG 0
21
+ #endif
22
+
23
+ #if RUBY_MARK_FREE_DEBUG
24
+ extern int ruby_gc_debug_indent;
25
+
26
+ static inline void
27
+ rb_gc_debug_indent(void)
28
+ {
29
+ printf("%*s", ruby_gc_debug_indent, "");
30
+ }
31
+
32
+ static inline void
33
+ rb_gc_debug_body(const char *mode, const char *msg, int st, void *ptr)
34
+ {
35
+ if (st == 0) {
36
+ ruby_gc_debug_indent--;
37
+ }
38
+ rb_gc_debug_indent();
39
+ printf("%s: %s %s (%p)\n", mode, st ? "->" : "<-", msg, ptr);
40
+
41
+ if (st) {
42
+ ruby_gc_debug_indent++;
43
+ }
44
+
45
+ fflush(stdout);
46
+ }
47
+
48
+ #define RUBY_MARK_ENTER(msg) rb_gc_debug_body("mark", (msg), 1, ptr)
49
+ #define RUBY_MARK_LEAVE(msg) rb_gc_debug_body("mark", (msg), 0, ptr)
50
+ #define RUBY_FREE_ENTER(msg) rb_gc_debug_body("free", (msg), 1, ptr)
51
+ #define RUBY_FREE_LEAVE(msg) rb_gc_debug_body("free", (msg), 0, ptr)
52
+ #define RUBY_GC_INFO rb_gc_debug_indent(); printf
53
+
54
+ #else
55
+ #define RUBY_MARK_ENTER(msg)
56
+ #define RUBY_MARK_LEAVE(msg)
57
+ #define RUBY_FREE_ENTER(msg)
58
+ #define RUBY_FREE_LEAVE(msg)
59
+ #define RUBY_GC_INFO if(0)printf
60
+ #endif
61
+
62
+ #define RUBY_MARK_NO_PIN_UNLESS_NULL(ptr) do { \
63
+ VALUE markobj = (ptr); \
64
+ if (RTEST(markobj)) {rb_gc_mark_movable(markobj);} \
65
+ } while (0)
66
+ #define RUBY_MARK_UNLESS_NULL(ptr) do { \
67
+ VALUE markobj = (ptr); \
68
+ if (RTEST(markobj)) {rb_gc_mark(markobj);} \
69
+ } while (0)
70
+ #define RUBY_FREE_UNLESS_NULL(ptr) if(ptr){ruby_xfree(ptr);(ptr)=NULL;}
71
+
72
+ #if STACK_GROW_DIRECTION > 0
73
+ # define STACK_UPPER(x, a, b) (a)
74
+ #elif STACK_GROW_DIRECTION < 0
75
+ # define STACK_UPPER(x, a, b) (b)
76
+ #else
77
+ RUBY_EXTERN int ruby_stack_grow_direction;
78
+ int ruby_get_stack_grow_direction(volatile VALUE *addr);
79
+ # define stack_growup_p(x) ( \
80
+ (ruby_stack_grow_direction ? \
81
+ ruby_stack_grow_direction : \
82
+ ruby_get_stack_grow_direction(x)) > 0)
83
+ # define STACK_UPPER(x, a, b) (stack_growup_p(x) ? (a) : (b))
84
+ #endif
85
+
86
+ /*
87
+ STACK_GROW_DIR_DETECTION is used with STACK_DIR_UPPER.
88
+
89
+ On most normal systems, stacks grow from high address to lower address. In
90
+ this case, STACK_DIR_UPPER(a, b) will return (b), but on exotic systems where
91
+ the stack grows UP (from low address to high address), it will return (a).
92
+ */
93
+
94
+ #if STACK_GROW_DIRECTION
95
+ #define STACK_GROW_DIR_DETECTION
96
+ #define STACK_DIR_UPPER(a,b) STACK_UPPER(0, (a), (b))
97
+ #else
98
+ #define STACK_GROW_DIR_DETECTION VALUE stack_grow_dir_detection
99
+ #define STACK_DIR_UPPER(a,b) STACK_UPPER(&stack_grow_dir_detection, (a), (b))
100
+ #endif
101
+ #define IS_STACK_DIR_UPPER() STACK_DIR_UPPER(1,0)
102
+
103
+ const char *rb_obj_info(VALUE obj);
104
+ const char *rb_raw_obj_info(char *buff, const int buff_size, VALUE obj);
105
+
106
+ VALUE rb_gc_disable_no_rest(void);
107
+
108
+ struct rb_thread_struct;
109
+
110
+ RUBY_SYMBOL_EXPORT_BEGIN
111
+
112
+ /* exports for objspace module */
113
+ size_t rb_objspace_data_type_memsize(VALUE obj);
114
+ void rb_objspace_reachable_objects_from(VALUE obj, void (func)(VALUE, void *), void *data);
115
+ void rb_objspace_reachable_objects_from_root(void (func)(const char *category, VALUE, void *), void *data);
116
+ int rb_objspace_markable_object_p(VALUE obj);
117
+ int rb_objspace_internal_object_p(VALUE obj);
118
+ int rb_objspace_marked_object_p(VALUE obj);
119
+ int rb_objspace_garbage_object_p(VALUE obj);
120
+
121
+ void rb_objspace_each_objects(
122
+ int (*callback)(void *start, void *end, size_t stride, void *data),
123
+ void *data);
124
+
125
+ void rb_objspace_each_objects_without_setup(
126
+ int (*callback)(void *, void *, size_t, void *),
127
+ void *data);
128
+
129
+ RUBY_SYMBOL_EXPORT_END
130
+
131
+ #endif /* RUBY_GC_H */