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.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/CHANGELOG.md +10 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/addr2line.h +20 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/builtin.h +117 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/build_assert/build_assert.h +40 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/check_type/check_type.h +63 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/container_of/container_of.h +142 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/list/list.h +789 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ccan/str/str.h +17 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/constant.h +53 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/darray.h +246 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/debug_counter.h +423 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/dln.h +31 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/encindex.h +70 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/eval_intern.h +341 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/hrtime.h +227 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/id.h +343 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/id_table.h +39 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/insns.inc +249 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/insns_info.inc +9133 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/array.h +144 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/basic_operators.h +63 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/bignum.h +244 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/bits.h +568 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/class.h +226 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/cmdlineopt.h +63 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/compar.h +29 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/compile.h +34 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/compilers.h +107 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/complex.h +29 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/cont.h +32 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/dir.h +16 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/enc.h +19 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/encoding.h +32 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/enum.h +18 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/enumerator.h +21 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/error.h +213 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/eval.h +32 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/file.h +38 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/fixnum.h +184 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/gc.h +361 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/hash.h +190 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/imemo.h +241 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/inits.h +50 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/io.h +137 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/load.h +18 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/loadpath.h +16 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/math.h +23 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/missing.h +18 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/numeric.h +273 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/object.h +59 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/parse.h +133 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/proc.h +30 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/process.h +124 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/ractor.h +6 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/random.h +16 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/range.h +40 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/rational.h +71 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/re.h +28 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/ruby_parser.h +69 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/sanitizers.h +186 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/serial.h +23 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/signal.h +25 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/static_assert.h +16 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/string.h +160 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/struct.h +127 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/symbol.h +42 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/thread.h +74 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/time.h +34 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/transcode.h +20 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/util.h +27 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/variable.h +71 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/vm.h +129 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal/warnings.h +16 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/internal.h +112 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/iseq.h +334 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/known_errors.inc +791 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/method.h +254 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/node.h +125 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/node_name.inc +210 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/optinsn.inc +128 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/optunifs.inc +43 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parse.h +232 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parser_bits.h +564 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parser_node.h +133 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parser_st.h +162 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/parser_value.h +106 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/probes_helper.h +42 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ractor_core.h +387 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/regenc.h +254 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/regint.h +996 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/regparse.h +370 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/revision.h +5 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/rjit.h +103 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/rjit_c.h +165 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ruby_assert.h +14 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/ruby_atomic.h +23 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/rubyparser.h +628 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/shape.h +232 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/siphash.h +48 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/symbol.h +119 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/thread_none.h +20 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/thread_pthread.h +126 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/thread_win32.h +58 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/timev.h +58 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/transcode_data.h +138 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/variable.h +30 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/version.h +65 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm.inc +5396 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_call_iseq_optimized.inc +244 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_callinfo.h +608 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_core.h +2089 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_debug.h +122 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_exec.h +199 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_insnhelper.h +271 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_opts.h +67 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vm_sync.h +137 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/vmtc.inc +243 -0
- data/lib/debase/ruby_core_source/ruby-3.3.0-preview2/yjit.h +70 -0
- data/lib/debase/ruby_core_source/version.rb +1 -1
- 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";
|