kanayago 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.rubocop.yml +15 -0
- data/.rubocop_todo.yml +23 -0
- data/LICENSE.txt +21 -0
- data/README.md +79 -0
- data/Rakefile +182 -0
- data/ext/kanayago/ccan/check_type/check_type.h +63 -0
- data/ext/kanayago/ccan/container_of/container_of.h +142 -0
- data/ext/kanayago/ccan/list/list.h +791 -0
- data/ext/kanayago/ccan/str/str.h +17 -0
- data/ext/kanayago/constant.h +53 -0
- data/ext/kanayago/extconf.rb +21 -0
- data/ext/kanayago/id.h +347 -0
- data/ext/kanayago/id_table.h +39 -0
- data/ext/kanayago/internal/array.h +151 -0
- data/ext/kanayago/internal/basic_operators.h +64 -0
- data/ext/kanayago/internal/bignum.h +244 -0
- data/ext/kanayago/internal/bits.h +568 -0
- data/ext/kanayago/internal/compile.h +34 -0
- data/ext/kanayago/internal/compilers.h +107 -0
- data/ext/kanayago/internal/complex.h +29 -0
- data/ext/kanayago/internal/encoding.h +36 -0
- data/ext/kanayago/internal/error.h +218 -0
- data/ext/kanayago/internal/fixnum.h +184 -0
- data/ext/kanayago/internal/gc.h +322 -0
- data/ext/kanayago/internal/hash.h +191 -0
- data/ext/kanayago/internal/imemo.h +261 -0
- data/ext/kanayago/internal/io.h +140 -0
- data/ext/kanayago/internal/numeric.h +274 -0
- data/ext/kanayago/internal/parse.h +117 -0
- data/ext/kanayago/internal/rational.h +71 -0
- data/ext/kanayago/internal/re.h +28 -0
- data/ext/kanayago/internal/ruby_parser.h +125 -0
- data/ext/kanayago/internal/sanitizers.h +297 -0
- data/ext/kanayago/internal/serial.h +23 -0
- data/ext/kanayago/internal/static_assert.h +16 -0
- data/ext/kanayago/internal/string.h +186 -0
- data/ext/kanayago/internal/symbol.h +45 -0
- data/ext/kanayago/internal/thread.h +79 -0
- data/ext/kanayago/internal/variable.h +72 -0
- data/ext/kanayago/internal/vm.h +137 -0
- data/ext/kanayago/internal/warnings.h +16 -0
- data/ext/kanayago/internal.h +108 -0
- data/ext/kanayago/kanayago.c +420 -0
- data/ext/kanayago/kanayago.h +21 -0
- data/ext/kanayago/lex.c +302 -0
- data/ext/kanayago/method.h +255 -0
- data/ext/kanayago/node.c +440 -0
- data/ext/kanayago/node.h +111 -0
- data/ext/kanayago/node_name.inc +224 -0
- data/ext/kanayago/parse.c +26931 -0
- data/ext/kanayago/parse.h +244 -0
- data/ext/kanayago/parse.tmp.y +16145 -0
- data/ext/kanayago/parser_bits.h +564 -0
- data/ext/kanayago/parser_node.h +32 -0
- data/ext/kanayago/parser_st.c +164 -0
- data/ext/kanayago/parser_st.h +162 -0
- data/ext/kanayago/parser_value.h +106 -0
- data/ext/kanayago/probes.h +4 -0
- data/ext/kanayago/ruby_assert.h +14 -0
- data/ext/kanayago/ruby_atomic.h +23 -0
- data/ext/kanayago/ruby_parser.c +1165 -0
- data/ext/kanayago/rubyparser.h +1391 -0
- data/ext/kanayago/shape.h +234 -0
- data/ext/kanayago/st.c +2339 -0
- data/ext/kanayago/symbol.h +123 -0
- data/ext/kanayago/thread_pthread.h +168 -0
- data/ext/kanayago/universal_parser.c +230 -0
- data/ext/kanayago/vm_core.h +2215 -0
- data/ext/kanayago/vm_opts.h +67 -0
- data/lib/kanayago/version.rb +5 -0
- data/lib/kanayago.rb +11 -0
- data/sig/kanayago.rbs +4 -0
- metadata +116 -0
@@ -0,0 +1,186 @@
|
|
1
|
+
#ifndef INTERNAL_STRING_H /*-*-C-*-vi:se ft=c:*/
|
2
|
+
#define INTERNAL_STRING_H
|
3
|
+
/**
|
4
|
+
* @author Ruby developers <ruby-core@ruby-lang.org>
|
5
|
+
* @copyright This file is a part of the programming language Ruby.
|
6
|
+
* Permission is hereby granted, to either redistribute and/or
|
7
|
+
* modify this file, provided that the conditions mentioned in the
|
8
|
+
* file COPYING are met. Consult the file for details.
|
9
|
+
* @brief Internal header for String.
|
10
|
+
*/
|
11
|
+
#include "ruby/internal/config.h"
|
12
|
+
#include <stddef.h> /* for size_t */
|
13
|
+
#include "internal/compilers.h" /* for __has_builtin */
|
14
|
+
#include "ruby/internal/stdbool.h" /* for bool */
|
15
|
+
#include "ruby/encoding.h" /* for rb_encoding */
|
16
|
+
#include "ruby/ruby.h" /* for VALUE */
|
17
|
+
|
18
|
+
#define STR_NOEMBED FL_USER1
|
19
|
+
#define STR_SHARED FL_USER2 /* = ELTS_SHARED */
|
20
|
+
#define STR_CHILLED FL_USER3
|
21
|
+
|
22
|
+
enum ruby_rstring_private_flags {
|
23
|
+
RSTRING_CHILLED = STR_CHILLED,
|
24
|
+
};
|
25
|
+
|
26
|
+
#ifdef rb_fstring_cstr
|
27
|
+
# undef rb_fstring_cstr
|
28
|
+
#endif
|
29
|
+
|
30
|
+
/* string.c */
|
31
|
+
VALUE rb_fstring(VALUE);
|
32
|
+
VALUE rb_fstring_cstr(const char *str);
|
33
|
+
VALUE rb_fstring_enc_new(const char *ptr, long len, rb_encoding *enc);
|
34
|
+
int rb_str_buf_cat_escaped_char(VALUE result, unsigned int c, int unicode_p);
|
35
|
+
int rb_str_symname_p(VALUE);
|
36
|
+
VALUE rb_str_quote_unprintable(VALUE);
|
37
|
+
char *rb_str_fill_terminator(VALUE str, const int termlen);
|
38
|
+
void rb_str_change_terminator_length(VALUE str, const int oldtermlen, const int termlen);
|
39
|
+
VALUE rb_str_locktmp_ensure(VALUE str, VALUE (*func)(VALUE), VALUE arg);
|
40
|
+
VALUE rb_str_chomp_string(VALUE str, VALUE chomp);
|
41
|
+
VALUE rb_external_str_with_enc(VALUE str, rb_encoding *eenc);
|
42
|
+
VALUE rb_str_cat_conv_enc_opts(VALUE newstr, long ofs, const char *ptr, long len,
|
43
|
+
rb_encoding *from, int ecflags, VALUE ecopts);
|
44
|
+
VALUE rb_enc_str_scrub(rb_encoding *enc, VALUE str, VALUE repl);
|
45
|
+
VALUE rb_str_escape(VALUE str);
|
46
|
+
size_t rb_str_memsize(VALUE);
|
47
|
+
char *rb_str_to_cstr(VALUE str);
|
48
|
+
const char *ruby_escaped_char(int c);
|
49
|
+
void rb_str_make_independent(VALUE str);
|
50
|
+
int rb_enc_str_coderange_scan(VALUE str, rb_encoding *enc);
|
51
|
+
int rb_ascii8bit_appendable_encoding_index(rb_encoding *enc, unsigned int code);
|
52
|
+
VALUE rb_str_include(VALUE str, VALUE arg);
|
53
|
+
VALUE rb_str_byte_substr(VALUE str, VALUE beg, VALUE len);
|
54
|
+
|
55
|
+
static inline bool STR_EMBED_P(VALUE str);
|
56
|
+
static inline bool STR_SHARED_P(VALUE str);
|
57
|
+
static inline VALUE QUOTE(VALUE v);
|
58
|
+
static inline VALUE QUOTE_ID(ID v);
|
59
|
+
static inline bool is_ascii_string(VALUE str);
|
60
|
+
static inline bool is_broken_string(VALUE str);
|
61
|
+
static inline VALUE rb_str_eql_internal(const VALUE str1, const VALUE str2);
|
62
|
+
|
63
|
+
RUBY_SYMBOL_EXPORT_BEGIN
|
64
|
+
/* string.c (export) */
|
65
|
+
VALUE rb_str_tmp_frozen_acquire(VALUE str);
|
66
|
+
VALUE rb_str_tmp_frozen_no_embed_acquire(VALUE str);
|
67
|
+
void rb_str_tmp_frozen_release(VALUE str, VALUE tmp);
|
68
|
+
VALUE rb_setup_fake_str(struct RString *fake_str, const char *name, long len, rb_encoding *enc);
|
69
|
+
VALUE rb_str_upto_each(VALUE, VALUE, int, int (*each)(VALUE, VALUE), VALUE);
|
70
|
+
VALUE rb_str_upto_endless_each(VALUE, int (*each)(VALUE, VALUE), VALUE);
|
71
|
+
void rb_str_make_embedded(VALUE);
|
72
|
+
size_t rb_str_size_as_embedded(VALUE);
|
73
|
+
bool rb_str_reembeddable_p(VALUE);
|
74
|
+
RUBY_SYMBOL_EXPORT_END
|
75
|
+
|
76
|
+
VALUE rb_fstring_new(const char *ptr, long len);
|
77
|
+
VALUE rb_obj_as_string_result(VALUE str, VALUE obj);
|
78
|
+
VALUE rb_str_opt_plus(VALUE x, VALUE y);
|
79
|
+
VALUE rb_str_concat_literals(size_t num, const VALUE *strary);
|
80
|
+
VALUE rb_str_eql(VALUE str1, VALUE str2);
|
81
|
+
VALUE rb_id_quote_unprintable(ID);
|
82
|
+
VALUE rb_sym_proc_call(ID mid, int argc, const VALUE *argv, int kw_splat, VALUE passed_proc);
|
83
|
+
VALUE rb_enc_literal_str(const char *ptr, long len, rb_encoding *enc);
|
84
|
+
|
85
|
+
struct rb_execution_context_struct;
|
86
|
+
VALUE rb_ec_str_resurrect(struct rb_execution_context_struct *ec, VALUE str, bool chilled);
|
87
|
+
|
88
|
+
#define rb_fstring_lit(str) rb_fstring_new((str), rb_strlen_lit(str))
|
89
|
+
#define rb_fstring_literal(str) rb_fstring_lit(str)
|
90
|
+
#define rb_fstring_enc_lit(str, enc) rb_fstring_enc_new((str), rb_strlen_lit(str), (enc))
|
91
|
+
#define rb_fstring_enc_literal(str, enc) rb_fstring_enc_lit(str, enc)
|
92
|
+
|
93
|
+
static inline VALUE
|
94
|
+
QUOTE(VALUE v)
|
95
|
+
{
|
96
|
+
return rb_str_quote_unprintable(v);
|
97
|
+
}
|
98
|
+
|
99
|
+
static inline VALUE
|
100
|
+
QUOTE_ID(ID i)
|
101
|
+
{
|
102
|
+
return rb_id_quote_unprintable(i);
|
103
|
+
}
|
104
|
+
|
105
|
+
static inline bool
|
106
|
+
STR_EMBED_P(VALUE str)
|
107
|
+
{
|
108
|
+
return ! FL_TEST_RAW(str, STR_NOEMBED);
|
109
|
+
}
|
110
|
+
|
111
|
+
static inline bool
|
112
|
+
STR_SHARED_P(VALUE str)
|
113
|
+
{
|
114
|
+
return FL_ALL_RAW(str, STR_NOEMBED | STR_SHARED);
|
115
|
+
}
|
116
|
+
|
117
|
+
static inline bool
|
118
|
+
CHILLED_STRING_P(VALUE obj)
|
119
|
+
{
|
120
|
+
return RB_TYPE_P(obj, T_STRING) && FL_TEST_RAW(obj, STR_CHILLED);
|
121
|
+
}
|
122
|
+
|
123
|
+
static inline void
|
124
|
+
CHILLED_STRING_MUTATED(VALUE str)
|
125
|
+
{
|
126
|
+
FL_UNSET_RAW(str, STR_CHILLED);
|
127
|
+
rb_category_warn(RB_WARN_CATEGORY_DEPRECATED, "literal string will be frozen in the future");
|
128
|
+
}
|
129
|
+
|
130
|
+
static inline void
|
131
|
+
STR_CHILL_RAW(VALUE str)
|
132
|
+
{
|
133
|
+
FL_SET_RAW(str, STR_CHILLED);
|
134
|
+
}
|
135
|
+
|
136
|
+
static inline bool
|
137
|
+
is_ascii_string(VALUE str)
|
138
|
+
{
|
139
|
+
return rb_enc_str_coderange(str) == ENC_CODERANGE_7BIT;
|
140
|
+
}
|
141
|
+
|
142
|
+
static inline bool
|
143
|
+
is_broken_string(VALUE str)
|
144
|
+
{
|
145
|
+
return rb_enc_str_coderange(str) == ENC_CODERANGE_BROKEN;
|
146
|
+
}
|
147
|
+
|
148
|
+
static inline bool
|
149
|
+
at_char_boundary(const char *s, const char *p, const char *e, rb_encoding *enc)
|
150
|
+
{
|
151
|
+
return rb_enc_left_char_head(s, p, e, enc) == p;
|
152
|
+
}
|
153
|
+
|
154
|
+
static inline bool
|
155
|
+
at_char_right_boundary(const char *s, const char *p, const char *e, rb_encoding *enc)
|
156
|
+
{
|
157
|
+
RUBY_ASSERT(s <= p);
|
158
|
+
RUBY_ASSERT(p <= e);
|
159
|
+
|
160
|
+
return rb_enc_right_char_head(s, p, e, enc) == p;
|
161
|
+
}
|
162
|
+
|
163
|
+
/* expect tail call optimization */
|
164
|
+
// YJIT needs this function to never allocate and never raise
|
165
|
+
static inline VALUE
|
166
|
+
rb_str_eql_internal(const VALUE str1, const VALUE str2)
|
167
|
+
{
|
168
|
+
const long len = RSTRING_LEN(str1);
|
169
|
+
const char *ptr1, *ptr2;
|
170
|
+
|
171
|
+
if (len != RSTRING_LEN(str2)) return Qfalse;
|
172
|
+
if (!rb_str_comparable(str1, str2)) return Qfalse;
|
173
|
+
if ((ptr1 = RSTRING_PTR(str1)) == (ptr2 = RSTRING_PTR(str2)))
|
174
|
+
return Qtrue;
|
175
|
+
if (memcmp(ptr1, ptr2, len) == 0)
|
176
|
+
return Qtrue;
|
177
|
+
return Qfalse;
|
178
|
+
}
|
179
|
+
|
180
|
+
#if __has_builtin(__builtin_constant_p)
|
181
|
+
# define rb_fstring_cstr(str) \
|
182
|
+
(__builtin_constant_p(str) ? \
|
183
|
+
rb_fstring_new((str), (long)strlen(str)) : \
|
184
|
+
(rb_fstring_cstr)(str))
|
185
|
+
#endif
|
186
|
+
#endif /* INTERNAL_STRING_H */
|
@@ -0,0 +1,45 @@
|
|
1
|
+
#ifndef INTERNAL_SYMBOL_H /*-*-C-*-vi:se ft=c:*/
|
2
|
+
#define INTERNAL_SYMBOL_H
|
3
|
+
/**
|
4
|
+
* @author Ruby developers <ruby-core@ruby-lang.org>
|
5
|
+
* @copyright This file is a part of the programming language Ruby.
|
6
|
+
* Permission is hereby granted, to either redistribute and/or
|
7
|
+
* modify this file, provided that the conditions mentioned in the
|
8
|
+
* file COPYING are met. Consult the file for details.
|
9
|
+
* @brief Internal header for Symbol.
|
10
|
+
*/
|
11
|
+
#include "ruby/ruby.h" /* for VALUE */
|
12
|
+
#include "ruby/encoding.h" /* for rb_encoding */
|
13
|
+
#include "internal/compilers.h" /* for __has_builtin */
|
14
|
+
|
15
|
+
#ifdef rb_sym_intern_ascii_cstr
|
16
|
+
# undef rb_sym_intern_ascii_cstr
|
17
|
+
#endif
|
18
|
+
|
19
|
+
/* symbol.c */
|
20
|
+
VALUE rb_to_symbol_type(VALUE obj);
|
21
|
+
VALUE rb_sym_intern(const char *ptr, long len, rb_encoding *enc);
|
22
|
+
VALUE rb_sym_intern_ascii(const char *ptr, long len);
|
23
|
+
VALUE rb_sym_intern_ascii_cstr(const char *ptr);
|
24
|
+
int rb_is_const_name(VALUE name);
|
25
|
+
int rb_is_class_name(VALUE name);
|
26
|
+
int rb_is_instance_name(VALUE name);
|
27
|
+
int rb_is_local_name(VALUE name);
|
28
|
+
PUREFUNC(int rb_is_const_sym(VALUE sym));
|
29
|
+
PUREFUNC(int rb_is_attrset_sym(VALUE sym));
|
30
|
+
ID rb_make_internal_id(void);
|
31
|
+
ID rb_make_temporary_id(size_t n);
|
32
|
+
void rb_gc_free_dsymbol(VALUE);
|
33
|
+
int rb_static_id_valid_p(ID id);
|
34
|
+
|
35
|
+
/* vm.c */
|
36
|
+
void rb_free_static_symid_str(void);
|
37
|
+
|
38
|
+
#if __has_builtin(__builtin_constant_p)
|
39
|
+
#define rb_sym_intern_ascii_cstr(ptr) \
|
40
|
+
(__builtin_constant_p(ptr) ? \
|
41
|
+
rb_sym_intern_ascii((ptr), (long)strlen(ptr)) : \
|
42
|
+
rb_sym_intern_ascii_cstr(ptr))
|
43
|
+
#endif
|
44
|
+
|
45
|
+
#endif /* INTERNAL_SYMBOL_H */
|
@@ -0,0 +1,79 @@
|
|
1
|
+
#ifndef INTERNAL_THREAD_H /*-*-C-*-vi:se ft=c:*/
|
2
|
+
#define INTERNAL_THREAD_H
|
3
|
+
/**
|
4
|
+
* @author Ruby developers <ruby-core@ruby-lang.org>
|
5
|
+
* @copyright This file is a part of the programming language Ruby.
|
6
|
+
* Permission is hereby granted, to either redistribute and/or
|
7
|
+
* modify this file, provided that the conditions mentioned in the
|
8
|
+
* file COPYING are met. Consult the file for details.
|
9
|
+
* @brief Internal header for Thread.
|
10
|
+
*/
|
11
|
+
#include "ruby/ruby.h" /* for VALUE */
|
12
|
+
#include "ruby/intern.h" /* for rb_blocking_function_t */
|
13
|
+
#include "ccan/list/list.h" /* for list in rb_io_close_wait_list */
|
14
|
+
|
15
|
+
struct rb_thread_struct; /* in vm_core.h */
|
16
|
+
|
17
|
+
#define RB_VM_SAVE_MACHINE_CONTEXT(th) \
|
18
|
+
do { \
|
19
|
+
FLUSH_REGISTER_WINDOWS; \
|
20
|
+
setjmp((th)->ec->machine.regs); \
|
21
|
+
SET_MACHINE_STACK_END(&(th)->ec->machine.stack_end); \
|
22
|
+
} while (0)
|
23
|
+
|
24
|
+
/* thread.c */
|
25
|
+
#define COVERAGE_INDEX_LINES 0
|
26
|
+
#define COVERAGE_INDEX_BRANCHES 1
|
27
|
+
#define COVERAGE_TARGET_LINES 1
|
28
|
+
#define COVERAGE_TARGET_BRANCHES 2
|
29
|
+
#define COVERAGE_TARGET_METHODS 4
|
30
|
+
#define COVERAGE_TARGET_ONESHOT_LINES 8
|
31
|
+
#define COVERAGE_TARGET_EVAL 16
|
32
|
+
|
33
|
+
#define RUBY_FATAL_THREAD_KILLED INT2FIX(0)
|
34
|
+
#define RUBY_FATAL_THREAD_TERMINATED INT2FIX(1)
|
35
|
+
#define RUBY_FATAL_FIBER_KILLED RB_INT2FIX(2)
|
36
|
+
|
37
|
+
VALUE rb_obj_is_mutex(VALUE obj);
|
38
|
+
VALUE rb_suppress_tracing(VALUE (*func)(VALUE), VALUE arg);
|
39
|
+
void rb_thread_execute_interrupts(VALUE th);
|
40
|
+
VALUE rb_get_coverages(void);
|
41
|
+
int rb_get_coverage_mode(void);
|
42
|
+
VALUE rb_default_coverage(int);
|
43
|
+
VALUE rb_thread_shield_new(void);
|
44
|
+
bool rb_thread_shield_owned(VALUE self);
|
45
|
+
VALUE rb_thread_shield_wait(VALUE self);
|
46
|
+
VALUE rb_thread_shield_release(VALUE self);
|
47
|
+
VALUE rb_thread_shield_destroy(VALUE self);
|
48
|
+
int rb_thread_to_be_killed(VALUE thread);
|
49
|
+
void rb_mutex_allow_trap(VALUE self, int val);
|
50
|
+
VALUE rb_uninterruptible(VALUE (*b_proc)(VALUE), VALUE data);
|
51
|
+
VALUE rb_mutex_owned_p(VALUE self);
|
52
|
+
VALUE rb_exec_recursive_outer_mid(VALUE (*f)(VALUE g, VALUE h, int r), VALUE g, VALUE h, ID mid);
|
53
|
+
void ruby_mn_threads_params(void);
|
54
|
+
|
55
|
+
int rb_thread_wait_for_single_fd(int fd, int events, struct timeval * timeout);
|
56
|
+
|
57
|
+
struct rb_io_close_wait_list {
|
58
|
+
struct ccan_list_head pending_fd_users;
|
59
|
+
VALUE closing_thread;
|
60
|
+
VALUE wakeup_mutex;
|
61
|
+
};
|
62
|
+
int rb_notify_fd_close(int fd, struct rb_io_close_wait_list *busy);
|
63
|
+
void rb_notify_fd_close_wait(struct rb_io_close_wait_list *busy);
|
64
|
+
|
65
|
+
RUBY_SYMBOL_EXPORT_BEGIN
|
66
|
+
|
67
|
+
/* Temporary. This API will be removed (renamed). */
|
68
|
+
VALUE rb_thread_io_blocking_region(rb_blocking_function_t *func, void *data1, int fd);
|
69
|
+
VALUE rb_thread_io_blocking_call(rb_blocking_function_t *func, void *data1, int fd, int events);
|
70
|
+
|
71
|
+
/* thread.c (export) */
|
72
|
+
int ruby_thread_has_gvl_p(void); /* for ext/fiddle/closure.c */
|
73
|
+
|
74
|
+
RUBY_SYMBOL_EXPORT_END
|
75
|
+
|
76
|
+
int rb_threadptr_execute_interrupts(struct rb_thread_struct *th, int blocking_timing);
|
77
|
+
bool rb_thread_mn_schedulable(VALUE thread);
|
78
|
+
|
79
|
+
#endif /* INTERNAL_THREAD_H */
|
@@ -0,0 +1,72 @@
|
|
1
|
+
#ifndef INTERNAL_VARIABLE_H /*-*-C-*-vi:se ft=c:*/
|
2
|
+
#define INTERNAL_VARIABLE_H
|
3
|
+
/**
|
4
|
+
* @author Ruby developers <ruby-core@ruby-lang.org>
|
5
|
+
* @copyright This file is a part of the programming language Ruby.
|
6
|
+
* Permission is hereby granted, to either redistribute and/or
|
7
|
+
* modify this file, provided that the conditions mentioned in the
|
8
|
+
* file COPYING are met. Consult the file for details.
|
9
|
+
* @brief Internal header for variables.
|
10
|
+
*/
|
11
|
+
#include "ruby/internal/config.h"
|
12
|
+
#include <stddef.h> /* for size_t */
|
13
|
+
#include "constant.h" /* for rb_const_entry_t */
|
14
|
+
#include "ruby/internal/stdbool.h" /* for bool */
|
15
|
+
#include "ruby/ruby.h" /* for VALUE */
|
16
|
+
#include "shape.h" /* for rb_shape_t */
|
17
|
+
|
18
|
+
/* variable.c */
|
19
|
+
void rb_gc_mark_global_tbl(void);
|
20
|
+
void rb_gc_update_global_tbl(void);
|
21
|
+
size_t rb_generic_ivar_memsize(VALUE);
|
22
|
+
VALUE rb_search_class_path(VALUE);
|
23
|
+
VALUE rb_attr_delete(VALUE, ID);
|
24
|
+
void rb_autoload_str(VALUE mod, ID id, VALUE file);
|
25
|
+
VALUE rb_autoload_at_p(VALUE, ID, int);
|
26
|
+
NORETURN(VALUE rb_mod_const_missing(VALUE,VALUE));
|
27
|
+
rb_gvar_getter_t *rb_gvar_getter_function_of(ID);
|
28
|
+
rb_gvar_setter_t *rb_gvar_setter_function_of(ID);
|
29
|
+
void rb_gvar_readonly_setter(VALUE v, ID id, VALUE *_);
|
30
|
+
void rb_gvar_ractor_local(const char *name);
|
31
|
+
|
32
|
+
/**
|
33
|
+
* Sets the name of a module.
|
34
|
+
*
|
35
|
+
* Non-permanently named classes can have a temporary name assigned (or
|
36
|
+
* cleared). In that case the name will be used for `#inspect` and `#to_s`, and
|
37
|
+
* nested classes/modules will be named with the temporary name as a prefix.
|
38
|
+
*
|
39
|
+
* After the module is assigned to a constant, the temporary name will be
|
40
|
+
* discarded, and the name will be computed based on the nesting.
|
41
|
+
*
|
42
|
+
* @param[in] mod An instance of ::rb_cModule.
|
43
|
+
* @param[in] name An instance of ::rb_cString.
|
44
|
+
* @retval mod
|
45
|
+
*/
|
46
|
+
VALUE rb_mod_set_temporary_name(VALUE, VALUE);
|
47
|
+
|
48
|
+
struct gen_ivtbl;
|
49
|
+
int rb_gen_ivtbl_get(VALUE obj, ID id, struct gen_ivtbl **ivtbl);
|
50
|
+
void rb_obj_copy_ivs_to_hash_table(VALUE obj, st_table *table);
|
51
|
+
void rb_obj_convert_to_too_complex(VALUE obj, st_table *table);
|
52
|
+
void rb_evict_ivars_to_hash(VALUE obj);
|
53
|
+
|
54
|
+
RUBY_SYMBOL_EXPORT_BEGIN
|
55
|
+
/* variable.c (export) */
|
56
|
+
void rb_mark_generic_ivar(VALUE obj);
|
57
|
+
void rb_ref_update_generic_ivar(VALUE);
|
58
|
+
void rb_mv_generic_ivar(VALUE src, VALUE dst);
|
59
|
+
VALUE rb_const_missing(VALUE klass, VALUE name);
|
60
|
+
int rb_class_ivar_set(VALUE klass, ID vid, VALUE value);
|
61
|
+
void rb_iv_tbl_copy(VALUE dst, VALUE src);
|
62
|
+
RUBY_SYMBOL_EXPORT_END
|
63
|
+
|
64
|
+
VALUE rb_ivar_lookup(VALUE obj, ID id, VALUE undef);
|
65
|
+
VALUE rb_gvar_get(ID);
|
66
|
+
VALUE rb_gvar_set(ID, VALUE);
|
67
|
+
VALUE rb_gvar_defined(ID);
|
68
|
+
void rb_const_warn_if_deprecated(const rb_const_entry_t *, VALUE, ID);
|
69
|
+
void rb_ensure_iv_list_size(VALUE obj, uint32_t len, uint32_t newsize);
|
70
|
+
attr_index_t rb_obj_ivar_set(VALUE obj, ID id, VALUE val);
|
71
|
+
|
72
|
+
#endif /* INTERNAL_VARIABLE_H */
|
@@ -0,0 +1,137 @@
|
|
1
|
+
#ifndef INTERNAL_VM_H /*-*-C-*-vi:se ft=c:*/
|
2
|
+
#define INTERNAL_VM_H
|
3
|
+
/**
|
4
|
+
* @author Ruby developers <ruby-core@ruby-lang.org>
|
5
|
+
* @copyright This file is a part of the programming language Ruby.
|
6
|
+
* Permission is hereby granted, to either redistribute and/or
|
7
|
+
* modify this file, provided that the conditions mentioned in the
|
8
|
+
* file COPYING are met. Consult the file for details.
|
9
|
+
* @brief Internal header for RubyVM.
|
10
|
+
*/
|
11
|
+
#include "ruby/internal/stdbool.h" /* for bool */
|
12
|
+
#include "internal/serial.h" /* for rb_serial_t */
|
13
|
+
#include "internal/static_assert.h" /* for STATIC_ASSERT */
|
14
|
+
#include "ruby/ruby.h" /* for ID */
|
15
|
+
#include "ruby/st.h" /* for st_table */
|
16
|
+
|
17
|
+
#ifdef rb_funcallv
|
18
|
+
# undef rb_funcallv
|
19
|
+
#endif
|
20
|
+
|
21
|
+
#ifdef rb_method_basic_definition_p
|
22
|
+
# undef rb_method_basic_definition_p
|
23
|
+
#endif
|
24
|
+
|
25
|
+
struct rb_callable_method_entry_struct; /* in method.h */
|
26
|
+
struct rb_method_definition_struct; /* in method.h */
|
27
|
+
struct rb_execution_context_struct; /* in vm_core.h */
|
28
|
+
struct rb_control_frame_struct; /* in vm_core.h */
|
29
|
+
struct rb_callinfo; /* in vm_core.h */
|
30
|
+
|
31
|
+
enum method_missing_reason {
|
32
|
+
MISSING_NOENTRY = 0x00,
|
33
|
+
MISSING_PRIVATE = 0x01,
|
34
|
+
MISSING_PROTECTED = 0x02,
|
35
|
+
MISSING_FCALL = 0x04,
|
36
|
+
MISSING_VCALL = 0x08,
|
37
|
+
MISSING_SUPER = 0x10,
|
38
|
+
MISSING_MISSING = 0x20,
|
39
|
+
MISSING_NONE = 0x40
|
40
|
+
};
|
41
|
+
|
42
|
+
/* vm_insnhelper.h */
|
43
|
+
VALUE rb_vm_push_frame_fname(struct rb_execution_context_struct *ec, VALUE fname);
|
44
|
+
|
45
|
+
/* vm.c */
|
46
|
+
VALUE rb_obj_is_thread(VALUE obj);
|
47
|
+
void rb_vm_mark(void *ptr);
|
48
|
+
void rb_vm_register_global_object(VALUE obj);
|
49
|
+
void rb_vm_each_stack_value(void *ptr, void (*cb)(VALUE, void*), void *ctx);
|
50
|
+
PUREFUNC(VALUE rb_vm_top_self(void));
|
51
|
+
const void **rb_vm_get_insns_address_table(void);
|
52
|
+
VALUE rb_source_location(int *pline);
|
53
|
+
const char *rb_source_location_cstr(int *pline);
|
54
|
+
void rb_vm_pop_cfunc_frame(void);
|
55
|
+
void rb_vm_check_redefinition_by_prepend(VALUE klass);
|
56
|
+
int rb_vm_check_optimizable_mid(VALUE mid);
|
57
|
+
VALUE rb_yield_refine_block(VALUE refinement, VALUE refinements);
|
58
|
+
VALUE ruby_vm_special_exception_copy(VALUE);
|
59
|
+
PUREFUNC(st_table *rb_vm_fstring_table(void));
|
60
|
+
|
61
|
+
void rb_lastline_set_up(VALUE val, unsigned int up);
|
62
|
+
|
63
|
+
/* vm_eval.c */
|
64
|
+
VALUE rb_current_realfilepath(void);
|
65
|
+
VALUE rb_check_block_call(VALUE, ID, int, const VALUE *, rb_block_call_func_t, VALUE);
|
66
|
+
typedef void rb_check_funcall_hook(int, VALUE, ID, int, const VALUE *, VALUE);
|
67
|
+
VALUE rb_check_funcall_with_hook_kw(VALUE recv, ID mid, int argc, const VALUE *argv,
|
68
|
+
rb_check_funcall_hook *hook, VALUE arg, int kw_splat);
|
69
|
+
const char *rb_type_str(enum ruby_value_type type);
|
70
|
+
VALUE rb_check_funcall_default(VALUE, ID, int, const VALUE *, VALUE);
|
71
|
+
VALUE rb_check_funcall_basic_kw(VALUE, ID, VALUE, int, const VALUE*, int);
|
72
|
+
VALUE rb_yield_1(VALUE val);
|
73
|
+
VALUE rb_yield_force_blockarg(VALUE values);
|
74
|
+
VALUE rb_lambda_call(VALUE obj, ID mid, int argc, const VALUE *argv,
|
75
|
+
rb_block_call_func_t bl_proc, int min_argc, int max_argc,
|
76
|
+
VALUE data2);
|
77
|
+
void rb_check_stack_overflow(void);
|
78
|
+
#define RB_BLOCK_NO_USE_PACKED_ARGS 2
|
79
|
+
VALUE rb_block_call2(VALUE obj, ID mid, int argc, const VALUE *argv, rb_block_call_func_t bl_proc, VALUE data2, long flags);
|
80
|
+
|
81
|
+
#if USE_YJIT
|
82
|
+
/* vm_exec.c */
|
83
|
+
extern uint64_t rb_vm_insns_count;
|
84
|
+
#endif
|
85
|
+
|
86
|
+
extern bool rb_free_at_exit;
|
87
|
+
|
88
|
+
/* miniinit.c and builtin.c */
|
89
|
+
void rb_free_loaded_builtin_table(void);
|
90
|
+
|
91
|
+
/* vm_insnhelper.c */
|
92
|
+
VALUE rb_equal_opt(VALUE obj1, VALUE obj2);
|
93
|
+
VALUE rb_eql_opt(VALUE obj1, VALUE obj2);
|
94
|
+
|
95
|
+
struct rb_iseq_struct;
|
96
|
+
const struct rb_callcache *rb_vm_search_method_slowpath(const struct rb_callinfo *ci, VALUE klass);
|
97
|
+
|
98
|
+
/* vm_method.c */
|
99
|
+
struct rb_execution_context_struct;
|
100
|
+
int rb_ec_obj_respond_to(struct rb_execution_context_struct *ec, VALUE obj, ID id, int priv);
|
101
|
+
|
102
|
+
void rb_clear_constant_cache(void);
|
103
|
+
|
104
|
+
/* vm_dump.c */
|
105
|
+
void rb_print_backtrace(FILE *);
|
106
|
+
|
107
|
+
/* vm_backtrace.c */
|
108
|
+
VALUE rb_vm_thread_backtrace(int argc, const VALUE *argv, VALUE thval);
|
109
|
+
VALUE rb_vm_thread_backtrace_locations(int argc, const VALUE *argv, VALUE thval);
|
110
|
+
VALUE rb_vm_backtrace(int argc, const VALUE * argv, struct rb_execution_context_struct * ec);
|
111
|
+
VALUE rb_vm_backtrace_locations(int argc, const VALUE * argv, struct rb_execution_context_struct * ec);
|
112
|
+
VALUE rb_make_backtrace(void);
|
113
|
+
void rb_backtrace_print_as_bugreport(FILE*);
|
114
|
+
int rb_backtrace_p(VALUE obj);
|
115
|
+
VALUE rb_backtrace_to_str_ary(VALUE obj);
|
116
|
+
VALUE rb_backtrace_to_location_ary(VALUE obj);
|
117
|
+
VALUE rb_location_ary_to_backtrace(VALUE ary);
|
118
|
+
void rb_backtrace_each(VALUE (*iter)(VALUE recv, VALUE str), VALUE output);
|
119
|
+
int rb_frame_info_p(VALUE obj);
|
120
|
+
int rb_get_node_id_from_frame_info(VALUE obj);
|
121
|
+
const struct rb_iseq_struct *rb_get_iseq_from_frame_info(VALUE obj);
|
122
|
+
|
123
|
+
VALUE rb_ec_backtrace_object(const struct rb_execution_context_struct *ec);
|
124
|
+
void rb_backtrace_use_iseq_first_lineno_for_last_location(VALUE self);
|
125
|
+
|
126
|
+
#define RUBY_DTRACE_CREATE_HOOK(name, arg) \
|
127
|
+
RUBY_DTRACE_HOOK(name##_CREATE, arg)
|
128
|
+
#define RUBY_DTRACE_HOOK(name, arg) \
|
129
|
+
do { \
|
130
|
+
if (UNLIKELY(RUBY_DTRACE_##name##_ENABLED())) { \
|
131
|
+
int dtrace_line; \
|
132
|
+
const char *dtrace_file = rb_source_location_cstr(&dtrace_line); \
|
133
|
+
if (!dtrace_file) dtrace_file = ""; \
|
134
|
+
RUBY_DTRACE_##name(arg, dtrace_file, dtrace_line); \
|
135
|
+
} \
|
136
|
+
} while (0)
|
137
|
+
#endif /* INTERNAL_VM_H */
|
@@ -0,0 +1,16 @@
|
|
1
|
+
#ifndef INTERNAL_WARNINGS_H /*-*-C-*-vi:se ft=c:*/
|
2
|
+
#define INTERNAL_WARNINGS_H
|
3
|
+
/**
|
4
|
+
* @author Ruby developers <ruby-core@ruby-lang.org>
|
5
|
+
* @copyright This file is a part of the programming language Ruby.
|
6
|
+
* Permission is hereby granted, to either redistribute and/or
|
7
|
+
* modify this file, provided that the conditions mentioned in the
|
8
|
+
* file COPYING are met. Consult the file for details.
|
9
|
+
* @brief Internal header to suppress / mandate warnings.
|
10
|
+
*/
|
11
|
+
#include "ruby/internal/warning_push.h"
|
12
|
+
#define COMPILER_WARNING_PUSH RBIMPL_WARNING_PUSH()
|
13
|
+
#define COMPILER_WARNING_POP RBIMPL_WARNING_POP()
|
14
|
+
#define COMPILER_WARNING_ERROR(flag) RBIMPL_WARNING_ERROR(flag)
|
15
|
+
#define COMPILER_WARNING_IGNORED(flag) RBIMPL_WARNING_IGNORED(flag)
|
16
|
+
#endif /* INTERNAL_WARNINGS_H */
|
@@ -0,0 +1,108 @@
|
|
1
|
+
#ifndef RUBY_INTERNAL_H /*-*-C-*-vi:se ft=c:*/
|
2
|
+
#define RUBY_INTERNAL_H 1
|
3
|
+
/**
|
4
|
+
* @author $Author$
|
5
|
+
* @date Tue May 17 11:42:20 JST 2011
|
6
|
+
* @copyright Copyright (C) 2011 Yukihiro Matsumoto
|
7
|
+
* @copyright This file is a part of the programming language Ruby.
|
8
|
+
* Permission is hereby granted, to either redistribute and/or
|
9
|
+
* modify this file, provided that the conditions mentioned in the
|
10
|
+
* file COPYING are met. Consult the file for details.
|
11
|
+
*/
|
12
|
+
#include "ruby/internal/config.h"
|
13
|
+
|
14
|
+
#ifdef __cplusplus
|
15
|
+
# error not for C++
|
16
|
+
#endif
|
17
|
+
|
18
|
+
#define LIKELY(x) RB_LIKELY(x)
|
19
|
+
#define UNLIKELY(x) RB_UNLIKELY(x)
|
20
|
+
|
21
|
+
#define numberof(array) ((int)(sizeof(array) / sizeof((array)[0])))
|
22
|
+
#define roomof(x, y) (((x) + (y) - 1) / (y))
|
23
|
+
#define type_roomof(x, y) roomof(sizeof(x), sizeof(y))
|
24
|
+
|
25
|
+
/* Prevent compiler from reordering access */
|
26
|
+
#define ACCESS_ONCE(type,x) (*((volatile type *)&(x)))
|
27
|
+
|
28
|
+
#define UNDEF_P RB_UNDEF_P
|
29
|
+
#define NIL_OR_UNDEF_P RB_NIL_OR_UNDEF_P
|
30
|
+
|
31
|
+
#include "ruby/ruby.h"
|
32
|
+
|
33
|
+
/* Following macros were formerly defined in this header but moved to somewhere
|
34
|
+
* else. In order to detect them we undef here. */
|
35
|
+
|
36
|
+
/* internal/array.h */
|
37
|
+
#undef RARRAY_AREF
|
38
|
+
|
39
|
+
/* internal/class.h */
|
40
|
+
#undef RClass
|
41
|
+
#undef RCLASS_SUPER
|
42
|
+
|
43
|
+
/* internal/hash.h */
|
44
|
+
#undef RHASH_IFNONE
|
45
|
+
#undef RHASH_SIZE
|
46
|
+
#undef RHASH_TBL
|
47
|
+
#undef RHASH_EMPTY_P
|
48
|
+
|
49
|
+
/* internal/struct.h */
|
50
|
+
#undef RSTRUCT_LEN
|
51
|
+
#undef RSTRUCT_PTR
|
52
|
+
#undef RSTRUCT_SET
|
53
|
+
#undef RSTRUCT_GET
|
54
|
+
|
55
|
+
/* Also, we keep the following macros here. They are expected to be
|
56
|
+
* overridden in each headers. */
|
57
|
+
|
58
|
+
/* internal/array.h */
|
59
|
+
#define rb_ary_new_from_args(...) rb_nonexistent_symbol(__VA_ARGS__)
|
60
|
+
|
61
|
+
/* internal/io.h */
|
62
|
+
#define rb_io_fptr_finalize(...) rb_nonexistent_symbol(__VA_ARGS__)
|
63
|
+
|
64
|
+
/* internal/string.h */
|
65
|
+
#define rb_fstring_cstr(...) rb_nonexistent_symbol(__VA_ARGS__)
|
66
|
+
|
67
|
+
/* internal/symbol.h */
|
68
|
+
#define rb_sym_intern_ascii_cstr(...) rb_nonexistent_symbol(__VA_ARGS__)
|
69
|
+
|
70
|
+
/* internal/vm.h */
|
71
|
+
#define rb_funcallv(...) rb_nonexistent_symbol(__VA_ARGS__)
|
72
|
+
#define rb_method_basic_definition_p(...) rb_nonexistent_symbol(__VA_ARGS__)
|
73
|
+
|
74
|
+
|
75
|
+
/* MRI debug support */
|
76
|
+
|
77
|
+
/* gc.c */
|
78
|
+
void rb_obj_info_dump(VALUE obj);
|
79
|
+
void rb_obj_info_dump_loc(VALUE obj, const char *file, int line, const char *func);
|
80
|
+
|
81
|
+
/* debug.c */
|
82
|
+
|
83
|
+
RUBY_SYMBOL_EXPORT_BEGIN
|
84
|
+
void ruby_debug_breakpoint(void);
|
85
|
+
PRINTF_ARGS(void ruby_debug_printf(const char*, ...), 1, 2);
|
86
|
+
RUBY_SYMBOL_EXPORT_END
|
87
|
+
|
88
|
+
// show obj data structure without any side-effect
|
89
|
+
#define rp(obj) rb_obj_info_dump_loc((VALUE)(obj), __FILE__, __LINE__, RUBY_FUNCTION_NAME_STRING)
|
90
|
+
|
91
|
+
// same as rp, but add message header
|
92
|
+
#define rp_m(msg, obj) do { \
|
93
|
+
fputs((msg), stderr); \
|
94
|
+
rb_obj_info_dump((VALUE)(obj)); \
|
95
|
+
} while (0)
|
96
|
+
|
97
|
+
// `ruby_debug_breakpoint()` does nothing,
|
98
|
+
// but breakpoint is set in run.gdb, so `make gdb` can stop here.
|
99
|
+
#define bp() ruby_debug_breakpoint()
|
100
|
+
|
101
|
+
#define RBOOL(v) ((v) ? Qtrue : Qfalse)
|
102
|
+
#define RB_BIGNUM_TYPE_P(x) RB_TYPE_P((x), T_BIGNUM)
|
103
|
+
|
104
|
+
#ifndef __MINGW32__
|
105
|
+
#undef memcpy
|
106
|
+
#define memcpy ruby_nonempty_memcpy
|
107
|
+
#endif
|
108
|
+
#endif /* RUBY_INTERNAL_H */
|