debase-ruby_core_source 3.2.0 → 3.2.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (122) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +1 -0
  3. data/CHANGELOG.md +10 -0
  4. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/addr2line.h +20 -0
  5. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/builtin.h +117 -0
  6. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/build_assert/build_assert.h +40 -0
  7. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/check_type/check_type.h +63 -0
  8. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/container_of/container_of.h +142 -0
  9. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/list/list.h +789 -0
  10. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/str/str.h +17 -0
  11. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/constant.h +53 -0
  12. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/darray.h +246 -0
  13. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/debug_counter.h +423 -0
  14. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/dln.h +31 -0
  15. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/encindex.h +70 -0
  16. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/eval_intern.h +341 -0
  17. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/hrtime.h +227 -0
  18. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/id.h +343 -0
  19. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/id_table.h +39 -0
  20. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/insns.inc +249 -0
  21. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/insns_info.inc +9133 -0
  22. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/array.h +144 -0
  23. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/basic_operators.h +63 -0
  24. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/bignum.h +244 -0
  25. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/bits.h +568 -0
  26. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/class.h +226 -0
  27. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/cmdlineopt.h +63 -0
  28. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/compar.h +29 -0
  29. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/compile.h +34 -0
  30. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/compilers.h +107 -0
  31. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/complex.h +29 -0
  32. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/cont.h +32 -0
  33. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/dir.h +16 -0
  34. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/enc.h +19 -0
  35. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/encoding.h +32 -0
  36. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/enum.h +18 -0
  37. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/enumerator.h +21 -0
  38. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/error.h +213 -0
  39. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/eval.h +32 -0
  40. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/file.h +38 -0
  41. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/fixnum.h +184 -0
  42. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/gc.h +361 -0
  43. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/hash.h +190 -0
  44. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/imemo.h +241 -0
  45. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/inits.h +50 -0
  46. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/io.h +137 -0
  47. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/load.h +18 -0
  48. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/loadpath.h +16 -0
  49. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/math.h +23 -0
  50. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/missing.h +18 -0
  51. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/numeric.h +273 -0
  52. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/object.h +59 -0
  53. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/parse.h +133 -0
  54. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/proc.h +30 -0
  55. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/process.h +124 -0
  56. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/ractor.h +6 -0
  57. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/random.h +16 -0
  58. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/range.h +40 -0
  59. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/rational.h +71 -0
  60. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/re.h +28 -0
  61. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/ruby_parser.h +69 -0
  62. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/sanitizers.h +186 -0
  63. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/serial.h +23 -0
  64. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/signal.h +25 -0
  65. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/static_assert.h +16 -0
  66. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/string.h +160 -0
  67. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/struct.h +127 -0
  68. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/symbol.h +42 -0
  69. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/thread.h +74 -0
  70. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/time.h +34 -0
  71. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/transcode.h +20 -0
  72. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/util.h +27 -0
  73. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/variable.h +71 -0
  74. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/vm.h +129 -0
  75. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/warnings.h +16 -0
  76. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal.h +112 -0
  77. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/iseq.h +334 -0
  78. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/known_errors.inc +791 -0
  79. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/method.h +254 -0
  80. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/node.h +125 -0
  81. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/node_name.inc +210 -0
  82. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/optinsn.inc +128 -0
  83. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/optunifs.inc +43 -0
  84. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parse.h +232 -0
  85. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parser_bits.h +564 -0
  86. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parser_node.h +133 -0
  87. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parser_st.h +162 -0
  88. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parser_value.h +106 -0
  89. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/probes_helper.h +42 -0
  90. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ractor_core.h +387 -0
  91. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/regenc.h +254 -0
  92. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/regint.h +996 -0
  93. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/regparse.h +370 -0
  94. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/revision.h +5 -0
  95. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/rjit.h +103 -0
  96. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/rjit_c.h +165 -0
  97. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ruby_assert.h +14 -0
  98. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ruby_atomic.h +23 -0
  99. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/rubyparser.h +628 -0
  100. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/shape.h +232 -0
  101. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/siphash.h +48 -0
  102. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/symbol.h +119 -0
  103. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/thread_none.h +20 -0
  104. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/thread_pthread.h +126 -0
  105. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/thread_win32.h +58 -0
  106. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/timev.h +58 -0
  107. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/transcode_data.h +138 -0
  108. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/variable.h +30 -0
  109. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/version.h +65 -0
  110. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm.inc +5396 -0
  111. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_call_iseq_optimized.inc +244 -0
  112. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_callinfo.h +608 -0
  113. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_core.h +2089 -0
  114. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_debug.h +122 -0
  115. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_exec.h +199 -0
  116. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_insnhelper.h +271 -0
  117. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_opts.h +67 -0
  118. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_sync.h +137 -0
  119. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vmtc.inc +243 -0
  120. data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/yjit.h +70 -0
  121. data/lib/debase/ruby_core_source/version.rb +1 -1
  122. metadata +120 -3
@@ -0,0 +1,254 @@
1
+ #ifndef RUBY_METHOD_H
2
+ #define RUBY_METHOD_H 1
3
+ /**********************************************************************
4
+
5
+ method.h -
6
+
7
+ $Author$
8
+ created at: Wed Jul 15 20:02:33 2009
9
+
10
+ Copyright (C) 2009 Koichi Sasada
11
+
12
+ **********************************************************************/
13
+
14
+ #include "internal.h"
15
+ #include "internal/imemo.h"
16
+ #include "internal/compilers.h"
17
+ #include "internal/static_assert.h"
18
+
19
+ #ifndef END_OF_ENUMERATION
20
+ # if defined(__GNUC__) &&! defined(__STRICT_ANSI__)
21
+ # define END_OF_ENUMERATION(key)
22
+ # else
23
+ # define END_OF_ENUMERATION(key) END_OF_##key##_PLACEHOLDER = 0
24
+ # endif
25
+ #endif
26
+
27
+ /* cref */
28
+
29
+ typedef enum {
30
+ METHOD_VISI_UNDEF = 0x00,
31
+ METHOD_VISI_PUBLIC = 0x01,
32
+ METHOD_VISI_PRIVATE = 0x02,
33
+ METHOD_VISI_PROTECTED = 0x03,
34
+
35
+ METHOD_VISI_MASK = 0x03
36
+ } rb_method_visibility_t;
37
+
38
+ typedef struct rb_scope_visi_struct {
39
+ BITFIELD(rb_method_visibility_t, method_visi, 3);
40
+ unsigned int module_func : 1;
41
+ } rb_scope_visibility_t;
42
+
43
+ /*! CREF (Class REFerence) */
44
+ typedef struct rb_cref_struct {
45
+ VALUE flags;
46
+ VALUE refinements;
47
+ VALUE klass_or_self;
48
+ struct rb_cref_struct * next;
49
+ const rb_scope_visibility_t scope_visi;
50
+ } rb_cref_t;
51
+
52
+ /* method data type */
53
+
54
+ typedef struct rb_method_entry_struct {
55
+ VALUE flags;
56
+ VALUE defined_class;
57
+ struct rb_method_definition_struct * const def;
58
+ ID called_id;
59
+ VALUE owner;
60
+ } rb_method_entry_t;
61
+
62
+ typedef struct rb_callable_method_entry_struct { /* same fields with rb_method_entry_t */
63
+ VALUE flags;
64
+ const VALUE defined_class;
65
+ struct rb_method_definition_struct * const def;
66
+ ID called_id;
67
+ const VALUE owner;
68
+ } rb_callable_method_entry_t;
69
+
70
+ #define METHOD_ENTRY_VISI(me) (rb_method_visibility_t)(((me)->flags & (IMEMO_FL_USER0 | IMEMO_FL_USER1)) >> (IMEMO_FL_USHIFT+0))
71
+ #define METHOD_ENTRY_BASIC(me) (int) (((me)->flags & (IMEMO_FL_USER2 )) >> (IMEMO_FL_USHIFT+2))
72
+ #define METHOD_ENTRY_COMPLEMENTED(me) ((me)->flags & IMEMO_FL_USER3)
73
+ #define METHOD_ENTRY_COMPLEMENTED_SET(me) ((me)->flags |= IMEMO_FL_USER3)
74
+ #define METHOD_ENTRY_CACHED(me) ((me)->flags & IMEMO_FL_USER4)
75
+ #define METHOD_ENTRY_CACHED_SET(me) ((me)->flags |= IMEMO_FL_USER4)
76
+ #define METHOD_ENTRY_INVALIDATED(me) ((me)->flags & IMEMO_FL_USER5)
77
+ #define METHOD_ENTRY_INVALIDATED_SET(me) ((me)->flags |= IMEMO_FL_USER5)
78
+
79
+ static inline void
80
+ METHOD_ENTRY_VISI_SET(rb_method_entry_t *me, rb_method_visibility_t visi)
81
+ {
82
+ VM_ASSERT((int)visi >= 0 && visi <= 3);
83
+ me->flags = (me->flags & ~(IMEMO_FL_USER0 | IMEMO_FL_USER1)) | (visi << (IMEMO_FL_USHIFT+0));
84
+ }
85
+ static inline void
86
+ METHOD_ENTRY_BASIC_SET(rb_method_entry_t *me, unsigned int basic)
87
+ {
88
+ VM_ASSERT(basic <= 1);
89
+ me->flags = (me->flags & ~(IMEMO_FL_USER2 )) | (basic << (IMEMO_FL_USHIFT+2));
90
+ }
91
+ static inline void
92
+ METHOD_ENTRY_FLAGS_SET(rb_method_entry_t *me, rb_method_visibility_t visi, unsigned int basic)
93
+ {
94
+ VM_ASSERT((int)visi >= 0 && visi <= 3);
95
+ VM_ASSERT(basic <= 1);
96
+ me->flags =
97
+ (me->flags & ~(IMEMO_FL_USER0|IMEMO_FL_USER1|IMEMO_FL_USER2)) |
98
+ ((visi << (IMEMO_FL_USHIFT+0)) | (basic << (IMEMO_FL_USHIFT+2)));
99
+ }
100
+ static inline void
101
+ METHOD_ENTRY_FLAGS_COPY(rb_method_entry_t *dst, const rb_method_entry_t *src)
102
+ {
103
+ dst->flags =
104
+ (dst->flags & ~(IMEMO_FL_USER0|IMEMO_FL_USER1|IMEMO_FL_USER2)) |
105
+ (src->flags & (IMEMO_FL_USER0|IMEMO_FL_USER1|IMEMO_FL_USER2));
106
+ }
107
+
108
+ typedef enum {
109
+ VM_METHOD_TYPE_ISEQ, /*!< Ruby method */
110
+ VM_METHOD_TYPE_CFUNC, /*!< C method */
111
+ VM_METHOD_TYPE_ATTRSET, /*!< attr_writer or attr_accessor */
112
+ VM_METHOD_TYPE_IVAR, /*!< attr_reader or attr_accessor */
113
+ VM_METHOD_TYPE_BMETHOD,
114
+ VM_METHOD_TYPE_ZSUPER,
115
+ VM_METHOD_TYPE_ALIAS,
116
+ VM_METHOD_TYPE_UNDEF,
117
+ VM_METHOD_TYPE_NOTIMPLEMENTED,
118
+ VM_METHOD_TYPE_OPTIMIZED, /*!< Kernel#send, Proc#call, etc */
119
+ VM_METHOD_TYPE_MISSING, /*!< wrapper for method_missing(id) */
120
+ VM_METHOD_TYPE_REFINED, /*!< refinement */
121
+
122
+ END_OF_ENUMERATION(VM_METHOD_TYPE)
123
+ } rb_method_type_t;
124
+ #define VM_METHOD_TYPE_MINIMUM_BITS 4
125
+ STATIC_ASSERT(VM_METHOD_TYPE_MINIMUM_BITS,
126
+ VM_METHOD_TYPE_REFINED <= (1<<VM_METHOD_TYPE_MINIMUM_BITS));
127
+
128
+ #ifndef rb_iseq_t
129
+ typedef struct rb_iseq_struct rb_iseq_t;
130
+ #define rb_iseq_t rb_iseq_t
131
+ #endif
132
+
133
+ typedef struct rb_method_iseq_struct {
134
+ const rb_iseq_t * iseqptr; /*!< iseq pointer, should be separated from iseqval */
135
+ rb_cref_t * cref; /*!< class reference, should be marked */
136
+ } rb_method_iseq_t; /* check rb_add_method_iseq() when modify the fields */
137
+
138
+ typedef struct rb_method_cfunc_struct {
139
+ VALUE (*func)(ANYARGS);
140
+ VALUE (*invoker)(VALUE recv, int argc, const VALUE *argv, VALUE (*func)(ANYARGS));
141
+ int argc;
142
+ } rb_method_cfunc_t;
143
+
144
+ typedef struct rb_method_attr_struct {
145
+ ID id;
146
+ VALUE location; /* should be marked */
147
+ } rb_method_attr_t;
148
+
149
+ typedef struct rb_method_alias_struct {
150
+ struct rb_method_entry_struct * original_me; /* original_me->klass is original owner */
151
+ } rb_method_alias_t;
152
+
153
+ typedef struct rb_method_refined_struct {
154
+ struct rb_method_entry_struct * orig_me;
155
+ VALUE owner;
156
+ } rb_method_refined_t;
157
+
158
+ typedef struct rb_method_bmethod_struct {
159
+ VALUE proc; /* should be marked */
160
+ struct rb_hook_list_struct *hooks;
161
+ VALUE defined_ractor;
162
+ } rb_method_bmethod_t;
163
+
164
+ enum method_optimized_type {
165
+ OPTIMIZED_METHOD_TYPE_SEND,
166
+ OPTIMIZED_METHOD_TYPE_CALL,
167
+ OPTIMIZED_METHOD_TYPE_BLOCK_CALL,
168
+ OPTIMIZED_METHOD_TYPE_STRUCT_AREF,
169
+ OPTIMIZED_METHOD_TYPE_STRUCT_ASET,
170
+ OPTIMIZED_METHOD_TYPE__MAX
171
+ };
172
+
173
+ typedef struct rb_method_optimized {
174
+ enum method_optimized_type type;
175
+ unsigned int index;
176
+ } rb_method_optimized_t;
177
+
178
+ struct rb_method_definition_struct {
179
+ BITFIELD(rb_method_type_t, type, VM_METHOD_TYPE_MINIMUM_BITS);
180
+ unsigned int iseq_overload: 1;
181
+ int alias_count : 27;
182
+ int complemented_count : 28;
183
+ unsigned int no_redef_warning: 1;
184
+
185
+ union {
186
+ rb_method_iseq_t iseq;
187
+ rb_method_cfunc_t cfunc;
188
+ rb_method_attr_t attr;
189
+ rb_method_alias_t alias;
190
+ rb_method_refined_t refined;
191
+ rb_method_bmethod_t bmethod;
192
+ rb_method_optimized_t optimized;
193
+ } body;
194
+
195
+ ID original_id;
196
+ uintptr_t method_serial;
197
+ };
198
+
199
+ struct rb_id_table;
200
+
201
+ typedef struct rb_method_definition_struct rb_method_definition_t;
202
+ STATIC_ASSERT(sizeof_method_def, offsetof(rb_method_definition_t, body)==8);
203
+
204
+ #define UNDEFINED_METHOD_ENTRY_P(me) (!(me) || !(me)->def || (me)->def->type == VM_METHOD_TYPE_UNDEF)
205
+ #define UNDEFINED_REFINED_METHOD_P(def) \
206
+ ((def)->type == VM_METHOD_TYPE_REFINED && \
207
+ UNDEFINED_METHOD_ENTRY_P((def)->body.refined.orig_me))
208
+
209
+ void rb_add_method(VALUE klass, ID mid, rb_method_type_t type, void *option, rb_method_visibility_t visi);
210
+ void rb_add_method_cfunc(VALUE klass, ID mid, VALUE (*func)(ANYARGS), int argc, rb_method_visibility_t visi);
211
+ void rb_add_method_iseq(VALUE klass, ID mid, const rb_iseq_t *iseq, rb_cref_t *cref, rb_method_visibility_t visi);
212
+ void rb_add_method_optimized(VALUE klass, ID mid, enum method_optimized_type, unsigned int index, rb_method_visibility_t visi);
213
+ void rb_add_refined_method_entry(VALUE refined_class, ID mid);
214
+
215
+ rb_method_entry_t *rb_method_entry_set(VALUE klass, ID mid, const rb_method_entry_t *, rb_method_visibility_t noex);
216
+ rb_method_entry_t *rb_method_entry_create(ID called_id, VALUE klass, rb_method_visibility_t visi, const rb_method_definition_t *def);
217
+
218
+ const rb_method_entry_t *rb_method_entry_at(VALUE obj, ID id);
219
+
220
+ const rb_method_entry_t *rb_method_entry(VALUE klass, ID id);
221
+ const rb_method_entry_t *rb_method_entry_with_refinements(VALUE klass, ID id, VALUE *defined_class);
222
+ const rb_method_entry_t *rb_method_entry_without_refinements(VALUE klass, ID id, VALUE *defined_class);
223
+ const rb_method_entry_t *rb_resolve_refined_method(VALUE refinements, const rb_method_entry_t *me);
224
+ RUBY_SYMBOL_EXPORT_BEGIN
225
+ const rb_method_entry_t *rb_resolve_me_location(const rb_method_entry_t *, VALUE[5]);
226
+ RUBY_SYMBOL_EXPORT_END
227
+
228
+ const rb_callable_method_entry_t *rb_callable_method_entry(VALUE klass, ID id);
229
+ const rb_callable_method_entry_t *rb_callable_method_entry_or_negative(VALUE klass, ID id);
230
+ const rb_callable_method_entry_t *rb_callable_method_entry_with_refinements(VALUE klass, ID id, VALUE *defined_class);
231
+ const rb_callable_method_entry_t *rb_callable_method_entry_without_refinements(VALUE klass, ID id, VALUE *defined_class);
232
+
233
+ int rb_method_entry_arity(const rb_method_entry_t *me);
234
+ int rb_method_entry_eq(const rb_method_entry_t *m1, const rb_method_entry_t *m2);
235
+ st_index_t rb_hash_method_entry(st_index_t hash, const rb_method_entry_t *me);
236
+
237
+ VALUE rb_method_entry_location(const rb_method_entry_t *me);
238
+
239
+ void rb_free_method_entry(const rb_method_entry_t *me);
240
+
241
+ const rb_method_entry_t *rb_method_entry_clone(const rb_method_entry_t *me);
242
+ const rb_callable_method_entry_t *rb_method_entry_complement_defined_class(const rb_method_entry_t *src_me, ID called_id, VALUE defined_class);
243
+ void rb_method_entry_copy(rb_method_entry_t *dst, const rb_method_entry_t *src);
244
+
245
+ void rb_method_table_insert(VALUE klass, struct rb_id_table *table, ID method_id, const rb_method_entry_t *me);
246
+
247
+ void rb_scope_visibility_set(rb_method_visibility_t);
248
+
249
+ VALUE rb_unnamed_parameters(int arity);
250
+
251
+ void rb_clear_method_cache(VALUE klass_or_module, ID mid);
252
+ void rb_clear_all_refinement_method_cache(void);
253
+
254
+ #endif /* RUBY_METHOD_H */
@@ -0,0 +1,125 @@
1
+ #ifndef RUBY_NODE_H
2
+ #define RUBY_NODE_H 1
3
+ /**********************************************************************
4
+
5
+ node.h -
6
+
7
+ $Author$
8
+ created at: Fri May 28 15:14:02 JST 1993
9
+
10
+ Copyright (C) 1993-2007 Yukihiro Matsumoto
11
+
12
+ **********************************************************************/
13
+
14
+ #include <stdbool.h>
15
+ #include "rubyparser.h"
16
+ #include "ruby/backward/2/attributes.h"
17
+
18
+ typedef void (*bug_report_func)(const char *fmt, ...);
19
+
20
+ typedef struct node_buffer_elem_struct {
21
+ struct node_buffer_elem_struct *next;
22
+ long len;
23
+ NODE buf[FLEX_ARY_LEN];
24
+ } node_buffer_elem_t;
25
+
26
+ typedef struct {
27
+ long idx, len;
28
+ node_buffer_elem_t *head;
29
+ node_buffer_elem_t *last;
30
+ } node_buffer_list_t;
31
+
32
+ struct node_buffer_struct {
33
+ node_buffer_list_t unmarkable;
34
+ node_buffer_list_t markable;
35
+ struct rb_ast_local_table_link *local_tables;
36
+ VALUE mark_hash;
37
+ // - id (sequence number)
38
+ // - token_type
39
+ // - text of token
40
+ // - location info
41
+ // Array, whose entry is array
42
+ VALUE tokens;
43
+ #ifdef UNIVERSAL_PARSER
44
+ rb_parser_config_t *config;
45
+ #endif
46
+ };
47
+
48
+ RUBY_SYMBOL_EXPORT_BEGIN
49
+
50
+ #ifdef UNIVERSAL_PARSER
51
+ rb_ast_t *rb_ast_new(rb_parser_config_t *config);
52
+ #else
53
+ rb_ast_t *rb_ast_new();
54
+ #endif
55
+ size_t rb_ast_memsize(const rb_ast_t*);
56
+ void rb_ast_dispose(rb_ast_t*);
57
+ VALUE rb_ast_tokens(rb_ast_t *ast);
58
+ #if RUBY_DEBUG
59
+ void rb_ast_node_type_change(NODE *n, enum node_type type);
60
+ #endif
61
+ const char *ruby_node_name(int node);
62
+ void rb_node_init(NODE *n, enum node_type type, VALUE a0, VALUE a1, VALUE a2);
63
+
64
+ void rb_ast_mark(rb_ast_t*);
65
+ void rb_ast_update_references(rb_ast_t*);
66
+ void rb_ast_free(rb_ast_t*);
67
+ void rb_ast_add_mark_object(rb_ast_t*, VALUE);
68
+ void rb_ast_set_tokens(rb_ast_t*, VALUE);
69
+ NODE *rb_ast_newnode(rb_ast_t*, enum node_type type);
70
+ void rb_ast_delete_node(rb_ast_t*, NODE *n);
71
+ rb_ast_id_table_t *rb_ast_new_local_table(rb_ast_t*, int);
72
+ rb_ast_id_table_t *rb_ast_resize_latest_local_table(rb_ast_t*, int);
73
+
74
+ VALUE rb_parser_dump_tree(const NODE *node, int comment);
75
+
76
+ const struct kwtable *rb_reserved_word(const char *, unsigned int);
77
+
78
+ struct parser_params;
79
+ void *rb_parser_malloc(struct parser_params *, size_t);
80
+ void *rb_parser_realloc(struct parser_params *, void *, size_t);
81
+ void *rb_parser_calloc(struct parser_params *, size_t, size_t);
82
+ void rb_parser_free(struct parser_params *, void *);
83
+ PRINTF_ARGS(void rb_parser_printf(struct parser_params *parser, const char *fmt, ...), 2, 3);
84
+ VALUE rb_node_set_type(NODE *n, enum node_type t);
85
+
86
+ RUBY_SYMBOL_EXPORT_END
87
+
88
+ #define NODE_LSHIFT (NODE_TYPESHIFT+7)
89
+ #define NODE_LMASK (((SIGNED_VALUE)1<<(sizeof(VALUE)*CHAR_BIT-NODE_LSHIFT))-1)
90
+
91
+ #define nd_line(n) (int)(((SIGNED_VALUE)(n)->flags)>>NODE_LSHIFT)
92
+ #define nd_set_line(n,l) \
93
+ (n)->flags=(((n)->flags&~((VALUE)(-1)<<NODE_LSHIFT))|((VALUE)((l)&NODE_LMASK)<<NODE_LSHIFT))
94
+
95
+
96
+ #define NODE_SPECIAL_REQUIRED_KEYWORD ((NODE *)-1)
97
+ #define NODE_REQUIRED_KEYWORD_P(node) ((node)->nd_value == NODE_SPECIAL_REQUIRED_KEYWORD)
98
+ #define NODE_SPECIAL_NO_NAME_REST ((NODE *)-1)
99
+ #define NODE_NAMED_REST_P(node) ((node) != NODE_SPECIAL_NO_NAME_REST)
100
+ #define NODE_SPECIAL_EXCESSIVE_COMMA ((ID)1)
101
+ #define NODE_SPECIAL_NO_REST_KEYWORD ((NODE *)-1)
102
+
103
+ #define nd_first_column(n) ((int)((n)->nd_loc.beg_pos.column))
104
+ #define nd_set_first_column(n, v) ((n)->nd_loc.beg_pos.column = (v))
105
+ #define nd_first_lineno(n) ((int)((n)->nd_loc.beg_pos.lineno))
106
+ #define nd_set_first_lineno(n, v) ((n)->nd_loc.beg_pos.lineno = (v))
107
+ #define nd_first_loc(n) ((n)->nd_loc.beg_pos)
108
+ #define nd_set_first_loc(n, v) (nd_first_loc(n) = (v))
109
+
110
+ #define nd_last_column(n) ((int)((n)->nd_loc.end_pos.column))
111
+ #define nd_set_last_column(n, v) ((n)->nd_loc.end_pos.column = (v))
112
+ #define nd_last_lineno(n) ((int)((n)->nd_loc.end_pos.lineno))
113
+ #define nd_set_last_lineno(n, v) ((n)->nd_loc.end_pos.lineno = (v))
114
+ #define nd_last_loc(n) ((n)->nd_loc.end_pos)
115
+ #define nd_set_last_loc(n, v) (nd_last_loc(n) = (v))
116
+ #define nd_node_id(n) ((n)->node_id)
117
+ #define nd_set_node_id(n,id) ((n)->node_id = (id))
118
+
119
+ static inline bool
120
+ nd_type_p(const NODE *n, enum node_type t)
121
+ {
122
+ return (enum node_type)nd_type(n) == t;
123
+ }
124
+
125
+ #endif /* RUBY_NODE_H */
@@ -0,0 +1,210 @@
1
+ case NODE_SCOPE:
2
+ return "NODE_SCOPE";
3
+ case NODE_BLOCK:
4
+ return "NODE_BLOCK";
5
+ case NODE_IF:
6
+ return "NODE_IF";
7
+ case NODE_UNLESS:
8
+ return "NODE_UNLESS";
9
+ case NODE_CASE:
10
+ return "NODE_CASE";
11
+ case NODE_CASE2:
12
+ return "NODE_CASE2";
13
+ case NODE_CASE3:
14
+ return "NODE_CASE3";
15
+ case NODE_WHEN:
16
+ return "NODE_WHEN";
17
+ case NODE_IN:
18
+ return "NODE_IN";
19
+ case NODE_WHILE:
20
+ return "NODE_WHILE";
21
+ case NODE_UNTIL:
22
+ return "NODE_UNTIL";
23
+ case NODE_ITER:
24
+ return "NODE_ITER";
25
+ case NODE_FOR:
26
+ return "NODE_FOR";
27
+ case NODE_FOR_MASGN:
28
+ return "NODE_FOR_MASGN";
29
+ case NODE_BREAK:
30
+ return "NODE_BREAK";
31
+ case NODE_NEXT:
32
+ return "NODE_NEXT";
33
+ case NODE_REDO:
34
+ return "NODE_REDO";
35
+ case NODE_RETRY:
36
+ return "NODE_RETRY";
37
+ case NODE_BEGIN:
38
+ return "NODE_BEGIN";
39
+ case NODE_RESCUE:
40
+ return "NODE_RESCUE";
41
+ case NODE_RESBODY:
42
+ return "NODE_RESBODY";
43
+ case NODE_ENSURE:
44
+ return "NODE_ENSURE";
45
+ case NODE_AND:
46
+ return "NODE_AND";
47
+ case NODE_OR:
48
+ return "NODE_OR";
49
+ case NODE_MASGN:
50
+ return "NODE_MASGN";
51
+ case NODE_LASGN:
52
+ return "NODE_LASGN";
53
+ case NODE_DASGN:
54
+ return "NODE_DASGN";
55
+ case NODE_GASGN:
56
+ return "NODE_GASGN";
57
+ case NODE_IASGN:
58
+ return "NODE_IASGN";
59
+ case NODE_CDECL:
60
+ return "NODE_CDECL";
61
+ case NODE_CVASGN:
62
+ return "NODE_CVASGN";
63
+ case NODE_OP_ASGN1:
64
+ return "NODE_OP_ASGN1";
65
+ case NODE_OP_ASGN2:
66
+ return "NODE_OP_ASGN2";
67
+ case NODE_OP_ASGN_AND:
68
+ return "NODE_OP_ASGN_AND";
69
+ case NODE_OP_ASGN_OR:
70
+ return "NODE_OP_ASGN_OR";
71
+ case NODE_OP_CDECL:
72
+ return "NODE_OP_CDECL";
73
+ case NODE_CALL:
74
+ return "NODE_CALL";
75
+ case NODE_OPCALL:
76
+ return "NODE_OPCALL";
77
+ case NODE_FCALL:
78
+ return "NODE_FCALL";
79
+ case NODE_VCALL:
80
+ return "NODE_VCALL";
81
+ case NODE_QCALL:
82
+ return "NODE_QCALL";
83
+ case NODE_SUPER:
84
+ return "NODE_SUPER";
85
+ case NODE_ZSUPER:
86
+ return "NODE_ZSUPER";
87
+ case NODE_LIST:
88
+ return "NODE_LIST";
89
+ case NODE_ZLIST:
90
+ return "NODE_ZLIST";
91
+ case NODE_VALUES:
92
+ return "NODE_VALUES";
93
+ case NODE_HASH:
94
+ return "NODE_HASH";
95
+ case NODE_RETURN:
96
+ return "NODE_RETURN";
97
+ case NODE_YIELD:
98
+ return "NODE_YIELD";
99
+ case NODE_LVAR:
100
+ return "NODE_LVAR";
101
+ case NODE_DVAR:
102
+ return "NODE_DVAR";
103
+ case NODE_GVAR:
104
+ return "NODE_GVAR";
105
+ case NODE_IVAR:
106
+ return "NODE_IVAR";
107
+ case NODE_CONST:
108
+ return "NODE_CONST";
109
+ case NODE_CVAR:
110
+ return "NODE_CVAR";
111
+ case NODE_NTH_REF:
112
+ return "NODE_NTH_REF";
113
+ case NODE_BACK_REF:
114
+ return "NODE_BACK_REF";
115
+ case NODE_MATCH:
116
+ return "NODE_MATCH";
117
+ case NODE_MATCH2:
118
+ return "NODE_MATCH2";
119
+ case NODE_MATCH3:
120
+ return "NODE_MATCH3";
121
+ case NODE_LIT:
122
+ return "NODE_LIT";
123
+ case NODE_STR:
124
+ return "NODE_STR";
125
+ case NODE_DSTR:
126
+ return "NODE_DSTR";
127
+ case NODE_XSTR:
128
+ return "NODE_XSTR";
129
+ case NODE_DXSTR:
130
+ return "NODE_DXSTR";
131
+ case NODE_EVSTR:
132
+ return "NODE_EVSTR";
133
+ case NODE_DREGX:
134
+ return "NODE_DREGX";
135
+ case NODE_ONCE:
136
+ return "NODE_ONCE";
137
+ case NODE_ARGS:
138
+ return "NODE_ARGS";
139
+ case NODE_ARGS_AUX:
140
+ return "NODE_ARGS_AUX";
141
+ case NODE_OPT_ARG:
142
+ return "NODE_OPT_ARG";
143
+ case NODE_KW_ARG:
144
+ return "NODE_KW_ARG";
145
+ case NODE_POSTARG:
146
+ return "NODE_POSTARG";
147
+ case NODE_ARGSCAT:
148
+ return "NODE_ARGSCAT";
149
+ case NODE_ARGSPUSH:
150
+ return "NODE_ARGSPUSH";
151
+ case NODE_SPLAT:
152
+ return "NODE_SPLAT";
153
+ case NODE_BLOCK_PASS:
154
+ return "NODE_BLOCK_PASS";
155
+ case NODE_DEFN:
156
+ return "NODE_DEFN";
157
+ case NODE_DEFS:
158
+ return "NODE_DEFS";
159
+ case NODE_ALIAS:
160
+ return "NODE_ALIAS";
161
+ case NODE_VALIAS:
162
+ return "NODE_VALIAS";
163
+ case NODE_UNDEF:
164
+ return "NODE_UNDEF";
165
+ case NODE_CLASS:
166
+ return "NODE_CLASS";
167
+ case NODE_MODULE:
168
+ return "NODE_MODULE";
169
+ case NODE_SCLASS:
170
+ return "NODE_SCLASS";
171
+ case NODE_COLON2:
172
+ return "NODE_COLON2";
173
+ case NODE_COLON3:
174
+ return "NODE_COLON3";
175
+ case NODE_DOT2:
176
+ return "NODE_DOT2";
177
+ case NODE_DOT3:
178
+ return "NODE_DOT3";
179
+ case NODE_FLIP2:
180
+ return "NODE_FLIP2";
181
+ case NODE_FLIP3:
182
+ return "NODE_FLIP3";
183
+ case NODE_SELF:
184
+ return "NODE_SELF";
185
+ case NODE_NIL:
186
+ return "NODE_NIL";
187
+ case NODE_TRUE:
188
+ return "NODE_TRUE";
189
+ case NODE_FALSE:
190
+ return "NODE_FALSE";
191
+ case NODE_ERRINFO:
192
+ return "NODE_ERRINFO";
193
+ case NODE_DEFINED:
194
+ return "NODE_DEFINED";
195
+ case NODE_POSTEXE:
196
+ return "NODE_POSTEXE";
197
+ case NODE_DSYM:
198
+ return "NODE_DSYM";
199
+ case NODE_ATTRASGN:
200
+ return "NODE_ATTRASGN";
201
+ case NODE_LAMBDA:
202
+ return "NODE_LAMBDA";
203
+ case NODE_ARYPTN:
204
+ return "NODE_ARYPTN";
205
+ case NODE_HSHPTN:
206
+ return "NODE_HSHPTN";
207
+ case NODE_FNDPTN:
208
+ return "NODE_FNDPTN";
209
+ case NODE_ERROR:
210
+ return "NODE_ERROR";