14#include "ruby/internal/config.h"
16#ifdef HAVE_SYS_PRCTL_H
20#include "eval_intern.h"
22#include "internal/class.h"
23#include "internal/cont.h"
24#include "internal/error.h"
25#include "internal/eval.h"
26#include "internal/gc.h"
27#include "internal/hash.h"
28#include "internal/inits.h"
29#include "internal/io.h"
30#include "internal/object.h"
31#include "internal/thread.h"
32#include "internal/variable.h"
36#include "probes_helper.h"
39#include "ractor_core.h"
42NORETURN(
static void rb_raise_jump(
VALUE,
VALUE));
52ID ruby_static_id_signo, ruby_static_id_status;
53extern ID ruby_static_id_cause;
54#define id_cause ruby_static_id_cause
56#define exception_error GET_VM()->special_exceptions[ruby_error_reenter]
58#include "eval_error.c"
61#define CLASS_OR_MODULE_P(obj) \
62 (!SPECIAL_CONST_P(obj) && \
63 (BUILTIN_TYPE(obj) == T_CLASS || BUILTIN_TYPE(obj) == T_MODULE))
68 enum ruby_tag_type state;
77#if defined(__linux__) && defined(PR_SET_THP_DISABLE)
78 prctl(PR_SET_THP_DISABLE, 1, 0, 0, 0);
81 rb_vm_encoded_insn_data_table_init();
87 EC_PUSH_TAG(GET_EC());
88 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
91 GET_VM()->running = 1;
105 rb_ec_error_print(ec, ec->errinfo);
112ruby_options(
int argc,
char **argv)
115 enum ruby_tag_type state;
116 void *
volatile iseq = 0;
119 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
123 rb_ec_clear_current_thread_trace_func(ec);
124 int exitcode = error_handle(ec, ec->errinfo, state);
126 iseq = (
void *)
INT2FIX(exitcode);
135 enum ruby_tag_type state;
138 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
142 state = error_handle(ec, ec->errinfo, state);
151 rb_ec_fiber_scheduler_finalize(ec);
154 if (EC_EXEC_TAG() == TAG_NONE) {
155 rb_vm_trap_exit(rb_ec_vm_ptr(ec));
158 rb_ec_exec_end_proc(ec);
159 rb_ec_clear_all_trace_func(ec);
167 rb_objspace_call_finalizer();
181 return rb_ec_cleanup(GET_EC(), (
enum ruby_tag_type)ex);
189 volatile int sysex = EXIT_SUCCESS;
190 volatile int signaled = 0;
193 volatile int step = 0;
197 rb_threadptr_interrupt(th);
198 rb_threadptr_check_signal(th);
201 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
202 RUBY_VM_CHECK_INTS(ec);
205 save_error = ec->errinfo;
206 if (THROW_DATA_P(ec->errinfo)) ec->errinfo =
Qnil;
213 VALUE err = ec->errinfo;
214 volatile int mode0 = 0, mode1 = 0;
215 if (err != save_error && !
NIL_P(err)) {
216 mode0 = exiting_split(err, &sysex, &signaled);
222 err = ATOMIC_VALUE_EXCHANGE(save_error,
Qnil);
224 if (!
NIL_P(err) && !THROW_DATA_P(err)) {
225 mode1 = exiting_split(err, (mode0 & EXITING_WITH_STATUS) ? NULL : &sysex, &signaled);
226 if (mode1 & EXITING_WITH_MESSAGE) {
228 rb_ec_error_print_detailed(ec, err, buf,
Qundef);
235 th->status = THREAD_KILLED;
237 rb_ractor_terminate_all();
240 if (!
NIL_P(buf = message)) {
243 else if (!NIL_OR_UNDEF_P(err = save_error) ||
244 (ex != TAG_NONE && !((mode0|mode1) & EXITING_WITH_STATUS))) {
245 sysex = error_handle(ec, err, ex);
261 rb_threadptr_unlock_all_locking_mutexes(th);
265 rb_thread_stop_timer_thread();
268 rb_jit_cont_finish();
283 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
284 rb_iseq_eval_main(iseq);
303 case Qtrue: s = EXIT_SUCCESS;
break;
304 case Qfalse: s = EXIT_FAILURE;
break;
309 if (status) *status = s;
314ruby_run_node(
void *n)
319 rb_ec_cleanup(ec, (
NIL_P(ec->errinfo) ? TAG_NONE : TAG_RAISE));
322 return rb_ec_cleanup(ec, rb_ec_exec_node(ec, n));
328 return rb_ec_exec_node(GET_EC(), n);
359 while (cref && CREF_NEXT(cref)) {
360 VALUE klass = CREF_CLASS(cref);
361 if (!CREF_PUSHED_BY_EVAL(cref) &&
365 cref = CREF_NEXT(cref);
393rb_mod_s_constants(
int argc,
VALUE *argv,
VALUE mod)
405 klass = CREF_CLASS(cref);
406 if (!CREF_PUSHED_BY_EVAL(cref) &&
413 cref = CREF_NEXT(cref);
436 rb_class_set_initialized(klass);
439 if (RCLASS_SINGLETON_P(klass)) {
440 klass = RCLASS_ATTACHED_OBJECT(klass);
447static VALUE get_errinfo(
void);
448#define get_ec_errinfo(ec) rb_ec_get_errinfo(ec)
456 CONST_ID(id_true_cause,
"true_cause");
458 cause = rb_attr_get(
rb_eFatal, id_true_cause);
467 if (!
NIL_P(cause) && cause != exc) {
484 if (INTERNAL_EXCEPTION_P(mesg)) EC_JUMP_TAG(ec, TAG_FATAL);
492 if (UNDEF_P(*cause)) {
498 *cause = get_ec_errinfo(ec);
508 if (!nocircular && !
NIL_P(*cause) && !UNDEF_P(*cause) && *cause != mesg) {
510 rb_exc_check_circular_cause(*cause);
515 rb_raise(rb_eArgError,
"circular causes");
517 if (THROW_DATA_P(c)) {
520 c = rb_attr_get(c, id_cause);
532 const char *file = rb_source_location_cstr(&line);
533 const char *
const volatile file0 = file;
535 if ((file && !
NIL_P(mesg)) || !UNDEF_P(cause)) {
536 volatile int state = 0;
539 if (EC_EXEC_TAG() == TAG_NONE && !(state = rb_ec_set_raised(ec))) {
540 VALUE bt = rb_get_backtrace(mesg);
541 if (!
NIL_P(bt) || UNDEF_P(cause)) {
546 if (!UNDEF_P(cause) && !THROW_DATA_P(cause)) {
547 exc_setup_cause(mesg, cause);
550 VALUE at = rb_ec_backtrace_object(ec);
552 set_backtrace(mesg, at);
554 rb_ec_reset_raised(ec);
558 if (state)
goto fatal;
567 enum ruby_tag_type state;
571 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
576 e = rb_sprintf(
"Exception '%"PRIsVALUE
"' at %s:%d - %"PRIsVALUE
"\n",
580 e = rb_sprintf(
"Exception '%"PRIsVALUE
"' at %s - %"PRIsVALUE
"\n",
584 e = rb_sprintf(
"Exception '%"PRIsVALUE
"' - %"PRIsVALUE
"\n",
590 if (state == TAG_FATAL && ec->errinfo == exception_error) {
594 rb_ec_reset_raised(ec);
595 EC_JUMP_TAG(ec, state);
599 if (rb_ec_set_raised(ec)) {
603 if (tag != TAG_FATAL) {
610 ec->errinfo = exception_error;
611 rb_ec_reset_raised(ec);
612 EC_JUMP_TAG(ec, TAG_FATAL);
619 if (UNDEF_P(cause)) {
620 cause = get_ec_errinfo(ec);
623 if (THROW_DATA_P(cause)) {
634 mesg = exc_setup_message(ec, mesg, &cause);
635 setup_exception(ec, tag, mesg, cause);
636 rb_ec_raised_clear(ec);
637 EC_JUMP_TAG(ec, tag);
640static VALUE make_exception(
int argc,
const VALUE *argv,
int isstr);
642NORETURN(
static void rb_exc_exception(
VALUE mesg,
enum ruby_tag_type tag,
VALUE cause));
645rb_exc_exception(
VALUE mesg,
enum ruby_tag_type tag,
VALUE cause)
648 mesg = make_exception(1, &mesg, FALSE);
650 rb_longjmp(GET_EC(), tag, mesg, cause);
663 rb_exc_exception(mesg, TAG_RAISE,
Qundef);
676 rb_exc_exception(mesg, TAG_FATAL,
Qnil);
686extract_raise_options(
int argc,
VALUE *argv,
VALUE *cause)
689 static ID keywords[1] = {0};
698 if (!
NIL_P(options)) {
721rb_exception_setup(
int argc,
VALUE *argv)
727 argc = extract_raise_options(argc, argv, &cause);
730 if (argc == 0 && !UNDEF_P(cause)) {
731 rb_raise(rb_eArgError,
"only cause is given with no arguments");
740 exception = rb_make_exception(argc, argv);
746 if (UNDEF_P(cause)) {
748 resolved_cause = rb_ec_get_errinfo(ec);
751 if (resolved_cause == exception) {
752 resolved_cause =
Qnil;
755 else if (
NIL_P(cause)) {
757 resolved_cause =
Qnil;
765 if (cause == exception) {
767 resolved_cause =
Qnil;
771 VALUE current_cause = cause;
772 while (!
NIL_P(current_cause)) {
774 if (current_cause == exception) {
775 rb_raise(rb_eArgError,
"circular causes");
777 if (THROW_DATA_P(current_cause)) {
780 current_cause = rb_attr_get(current_cause, id_cause);
782 resolved_cause = cause;
787 if (!UNDEF_P(resolved_cause)) {
798rb_f_raise(
int argc,
VALUE *argv)
801 argc = extract_raise_options(argc, argv, &cause);
808 if (!UNDEF_P(cause)) {
809 rb_raise(rb_eArgError,
"only cause is given with no arguments");
813 exception = get_errinfo();
814 if (!
NIL_P(exception)) {
820 rb_raise_jump(rb_make_exception(argc, argv), cause);
941 return rb_f_raise(c, v);
945make_exception(
int argc,
const VALUE *argv,
int isstr)
955 if (isstr &&!
NIL_P(exc)) {
966 rb_error_arity(argc, 0, 3);
978 set_backtrace(mesg, argv[2]);
985rb_make_exception(
int argc,
const VALUE *argv)
987 return make_exception(argc, argv, TRUE);
998 VALUE klass = me->owner;
999 VALUE self = cfp->self;
1000 ID mid = me->called_id;
1002 rb_vm_pop_frame(ec);
1005 rb_longjmp(ec, TAG_RAISE, mesg, cause);
1011 if (UNLIKELY(tag < TAG_RETURN || tag > TAG_FATAL)) {
1012 unknown_longjmp_status(tag);
1014 EC_JUMP_TAG(GET_EC(), tag);
1020 if (rb_vm_frame_block_handler(GET_EC()->cfp) == VM_BLOCK_HANDLER_NONE) {
1033 return rb_vm_cframe_keyword_p(GET_EC()->cfp);
1042 rb_vm_localjump_error(
"no block given",
Qnil, 0);
1051 va_start(ap, data2);
1062 enum ruby_tag_type state;
1066 volatile VALUE e_info = ec->errinfo;
1069 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
1071 result = (*b_proc) (data1);
1075 if (state == TAG_RETRY) {
1083 rb_vm_rewind_cfp(ec, cfp);
1085 if (state == TAG_RAISE) {
1093 while ((eclass = va_arg(ap,
VALUE)) != 0) {
1104 result = (*r_proc) (data2, ec->errinfo);
1106 ec->errinfo = e_info;
1112 EC_JUMP_TAG(ec, state);
1129 volatile enum ruby_tag_type state;
1134 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
1135 result = (*proc)(data);
1138 rb_vm_rewind_cfp(ec, cfp);
1142 if (pstate != NULL) *pstate = state;
1149 enum ruby_tag_type state;
1153 if ((state = EC_EXEC_TAG()) == TAG_NONE) {
1154 result = (*b_proc) (data1);
1157 errinfo = ec->errinfo;
1162 ec->errinfo = errinfo;
1164 EC_JUMP_TAG(ec, state);
1171 return rb_ec_ensure(GET_EC(), b_proc, data1, e_proc, data2);
1180 return me->def->original_id;
1193 return me->called_id;
1201rb_frame_this_func(
void)
1203 return frame_func_id(GET_EC()->cfp);
1207rb_frame_callee(
void)
1209 return frame_called_id(GET_EC()->cfp);
1217 if ((
void *)(ec->vm_stack + ec->vm_stack_size) == (
void *)(prev_cfp)) {
1224prev_frame_callee(
void)
1227 if (!prev_cfp)
return 0;
1228 return frame_called_id(prev_cfp);
1232prev_frame_func(
void)
1235 if (!prev_cfp)
return 0;
1236 return frame_func_id(prev_cfp);
1246rb_frame_last_func(
void)
1252 while (!(mid = frame_func_id(cfp)) &&
1253 (cfp = RUBY_VM_PREVIOUS_CONTROL_FRAME(cfp),
1254 !RUBY_VM_CONTROL_FRAME_STACK_OVERFLOW_P(ec, cfp)));
1271rb_mod_append_features(
VALUE module,
VALUE include)
1273 if (!CLASS_OR_MODULE_P(include)) {
1281static VALUE refinement_import_methods(
int argc,
VALUE *argv,
VALUE refinement);
1291rb_mod_include(
int argc,
VALUE *argv,
VALUE module)
1294 ID id_append_features, id_included;
1296 CONST_ID(id_append_features,
"append_features");
1300 rb_raise(
rb_eTypeError,
"Refinement#include has been removed");
1304 for (i = 0; i < argc; i++) {
1306 if (
FL_TEST(argv[i], RMODULE_IS_REFINEMENT)) {
1311 rb_funcall(argv[argc], id_append_features, 1, module);
1312 rb_funcall(argv[argc], id_included, 1, module);
1330rb_mod_prepend_features(
VALUE module,
VALUE prepend)
1332 if (!CLASS_OR_MODULE_P(prepend)) {
1348rb_mod_prepend(
int argc,
VALUE *argv,
VALUE module)
1351 ID id_prepend_features, id_prepended;
1354 rb_raise(
rb_eTypeError,
"Refinement#prepend has been removed");
1357 CONST_ID(id_prepend_features,
"prepend_features");
1358 CONST_ID(id_prepended,
"prepended");
1361 for (i = 0; i < argc; i++) {
1363 if (
FL_TEST(argv[i], RMODULE_IS_REFINEMENT)) {
1368 rb_funcall(argv[argc], id_prepend_features, 1, module);
1369 rb_funcall(argv[argc], id_prepended, 1, module);
1375ensure_class_or_module(
VALUE obj)
1379 "wrong argument type %"PRIsVALUE
" (expected Class or Module)",
1385hidden_identity_hash_new(
void)
1387 VALUE hash = rb_ident_hash_new();
1389 RBASIC_CLEAR_CLASS(hash);
1394refinement_superclass(
VALUE superclass)
1398 return rb_include_class_new(RCLASS_ORIGIN(superclass),
rb_cBasicObject);
1411 VALUE iclass, c, superclass = klass;
1413 ensure_class_or_module(klass);
1415 if (
NIL_P(CREF_REFINEMENTS(cref))) {
1416 CREF_REFINEMENTS_SET(cref, hidden_identity_hash_new());
1419 if (CREF_OMOD_SHARED(cref)) {
1420 CREF_REFINEMENTS_SET(cref, rb_hash_dup(CREF_REFINEMENTS(cref)));
1421 CREF_OMOD_SHARED_UNSET(cref);
1423 if (!
NIL_P(c = rb_hash_lookup(CREF_REFINEMENTS(cref), klass))) {
1426 if (
RBASIC(c)->klass == module) {
1434 superclass = refinement_superclass(superclass);
1435 c = iclass = rb_include_class_new(module, superclass);
1436 RCLASS_SET_REFINED_CLASS(c, klass);
1438 RCLASS_WRITE_M_TBL(c, RCLASS_M_TBL(module));
1440 rb_class_subclass_add(klass, iclass);
1442 rb_hash_aset(CREF_REFINEMENTS(cref), klass, iclass);
1450 rb_using_refinement(cref, klass, module);
1458 VALUE super, module, refinements;
1462 using_module_recursive(cref, super);
1470 module = RBASIC(klass)->klass;
1474 rb_raise(
rb_eTypeError,
"wrong argument type %s (expected Module)",
1478 CONST_ID(id_refinements,
"__refinements__");
1479 refinements = rb_attr_get(module, id_refinements);
1480 if (
NIL_P(refinements))
return;
1491 using_module_recursive(cref, module);
1492 rb_clear_all_refinement_method_cache();
1496rb_vm_using_module(
VALUE module)
1498 rb_using_module(rb_vm_cref_replace_with_duplicated_cref(), module);
1515rb_refinement_module_get_refined_class(
VALUE module)
1517 ID id_refined_class;
1519 CONST_ID(id_refined_class,
"__refined_class__");
1520 return rb_attr_get(module, id_refined_class);
1524add_activated_refinement(
VALUE activated_refinements,
1527 VALUE iclass, c, superclass = klass;
1529 if (!
NIL_P(c = rb_hash_lookup(activated_refinements, klass))) {
1532 if (
RBASIC(c)->klass == refinement) {
1539 superclass = refinement_superclass(superclass);
1540 c = iclass = rb_include_class_new(refinement, superclass);
1541 RCLASS_SET_REFINED_CLASS(c, klass);
1542 rb_class_subclass_add(klass, iclass);
1544 while (refinement && refinement != klass) {
1545 c = rb_class_set_super(c, rb_include_class_new(refinement,
RCLASS_SUPER(c)));
1546 RCLASS_SET_REFINED_CLASS(c, klass);
1547 rb_class_subclass_add(klass, c);
1550 rb_hash_aset(activated_refinements, klass, iclass);
1557 ID id_refinements, id_activated_refinements,
1558 id_refined_class, id_defined_at;
1559 VALUE refinements, activated_refinements;
1561 CONST_ID(id_refinements,
"__refinements__");
1562 refinements = rb_attr_get(module, id_refinements);
1563 if (
NIL_P(refinements)) {
1564 refinements = hidden_identity_hash_new();
1567 CONST_ID(id_activated_refinements,
"__activated_refinements__");
1568 activated_refinements = rb_attr_get(module, id_activated_refinements);
1569 if (
NIL_P(activated_refinements)) {
1570 activated_refinements = hidden_identity_hash_new();
1572 activated_refinements);
1574 refinement = rb_hash_lookup(refinements, klass);
1575 if (
NIL_P(refinement)) {
1576 VALUE superclass = refinement_superclass(klass);
1578 rb_class_set_super(refinement, superclass);
1580 FL_SET(refinement, RMODULE_IS_REFINEMENT);
1581 CONST_ID(id_refined_class,
"__refined_class__");
1583 CONST_ID(id_defined_at,
"__defined_at__");
1585 rb_hash_aset(refinements, klass, refinement);
1586 add_activated_refinement(activated_refinements, klass, refinement);
1589 data->refinement = refinement;
1590 data->refinements = activated_refinements;
1607 VALUE block_handler = rb_vm_frame_block_handler(th->ec->cfp);
1610 if (block_handler == VM_BLOCK_HANDLER_NONE) {
1611 rb_raise(rb_eArgError,
"no block given");
1613 if (vm_block_handler_type(block_handler) != block_handler_type_iseq) {
1614 rb_raise(rb_eArgError,
"can't pass a Proc as a block to Module#refine");
1617 ensure_class_or_module(klass);
1619 rb_refinement_setup(&data, module, klass);
1621 rb_yield_refine_block(data.refinement, data.refinements);
1622 return data.refinement;
1626ignored_block(
VALUE module,
const char *klass)
1628 const char *anon =
"";
1630 if (!
RTEST(rb_search_class_path(module))) {
1631 anon =
", maybe for Module.new";
1633 rb_warn(
"%s""using doesn't call the given block""%s.", klass, anon);
1649 if (prev_frame_func()) {
1651 "Module#using is not permitted in methods");
1653 if (prev_cfp && prev_cfp->self != self) {
1657 ignored_block(module,
"Module#");
1659 rb_using_module(rb_vm_cref_replace_with_duplicated_cref(), module);
1685mod_refinements(
VALUE self)
1690 CONST_ID(id_refinements,
"__refinements__");
1691 refinements = rb_attr_get(self, id_refinements);
1692 if (
NIL_P(refinements)) {
1695 return rb_hash_values(refinements);
1702 CONST_ID(id_defined_at,
"__defined_at__");
1736rb_mod_s_used_modules(
VALUE _)
1742 if (!
NIL_P(CREF_REFINEMENTS(cref))) {
1745 cref = CREF_NEXT(cref);
1748 return rb_funcall(ary, rb_intern(
"uniq"), 0);
1787rb_mod_s_used_refinements(
VALUE _)
1793 if (!
NIL_P(CREF_REFINEMENTS(cref))) {
1796 cref = CREF_NEXT(cref);
1811static enum rb_id_table_iterator_result
1812refinement_import_methods_i(
ID key,
VALUE value,
void *data)
1817 if (me->def->type != VM_METHOD_TYPE_ISEQ) {
1818 rb_raise(rb_eArgError,
"Can't import method which is not defined with Ruby code: %"PRIsVALUE
"#%"PRIsVALUE,
rb_class_path(arg->module), rb_id2str(key));
1820 rb_cref_t *new_cref = rb_vm_cref_dup_without_refinements(me->def->body.iseq.
cref);
1821 CREF_REFINEMENTS_SET(new_cref, CREF_REFINEMENTS(arg->cref));
1822 rb_add_method_iseq(arg->refinement, key, me->def->body.iseq.
iseqptr, new_cref, METHOD_ENTRY_VISI(me));
1823 return ID_TABLE_CONTINUE;
1831refinement_import_methods(
int argc,
VALUE *argv,
VALUE refinement)
1837 for (i = 0; i < argc; i++) {
1840 rb_warn(
"%"PRIsVALUE
" has ancestors, but Refinement#import_methods doesn't import their methods",
rb_class_path(argv[i]));
1843 arg.cref = rb_vm_cref_replace_with_duplicated_cref();
1844 arg.refinement = refinement;
1845 for (i = 0; i < argc; i++) {
1846 arg.module = argv[i];
1847 struct rb_id_table *m_tbl = RCLASS_M_TBL(argv[i]);
1848 if (!m_tbl)
continue;
1849 rb_id_table_foreach(m_tbl, refinement_import_methods_i, &arg);
1861rb_obj_call_init_kw(
VALUE obj,
int argc,
const VALUE *argv,
int kw_splat)
1863 PASS_PASSED_BLOCK_HANDLER();
1933rb_obj_extend(
int argc,
VALUE *argv,
VALUE obj)
1936 ID id_extend_object, id_extended;
1938 CONST_ID(id_extend_object,
"extend_object");
1942 for (i = 0; i < argc; i++) {
1944 if (
FL_TEST(argv[i], RMODULE_IS_REFINEMENT)) {
1945 rb_raise(
rb_eTypeError,
"Cannot extend object with refinement");
1949 rb_funcall(argv[argc], id_extend_object, 1, obj);
1956rb_top_main_class(
const char *method)
1958 VALUE klass = GET_THREAD()->top_wrapper;
1961 rb_warning(
"main.%s in the wrapped load is effective only in wrapper module", method);
1975top_include(
int argc,
VALUE *argv,
VALUE self)
1977 return rb_mod_include(argc, argv, rb_top_main_class(
"include"));
1991 const rb_cref_t *cref = CREF_NEXT(rb_vm_cref());
1995 if ((th->top_wrapper ? CREF_NEXT(cref) : cref) ||
1996 (prev_cfp && rb_vm_frame_method_entry(prev_cfp))) {
2000 ignored_block(module,
"main.");
2002 rb_using_module(rb_vm_cref_replace_with_duplicated_cref(), module);
2012 while (RUBY_VM_VALID_CONTROL_FRAME_P(cfp, end_cfp)) {
2013 if (VM_FRAME_RUBYFRAME_P(cfp)) {
2014 if (ISEQ_BODY(CFP_ISEQ(cfp))->
type == ISEQ_TYPE_RESCUE) {
2015 return &cfp->ep[VM_ENV_INDEX_LAST_LVAR];
2017 else if (ISEQ_BODY(CFP_ISEQ(cfp))->
type == ISEQ_TYPE_ENSURE &&
2018 !THROW_DATA_P(cfp->ep[VM_ENV_INDEX_LAST_LVAR]) &&
2019 !
FIXNUM_P(cfp->ep[VM_ENV_INDEX_LAST_LVAR])) {
2020 return &cfp->ep[VM_ENV_INDEX_LAST_LVAR];
2023 cfp = RUBY_VM_PREVIOUS_CONTROL_FRAME(cfp);
2031 const VALUE *ptr = errinfo_place(ec);
2043 return get_ec_errinfo(GET_EC());
2049 return get_errinfo();
2055 return GET_EC()->errinfo;
2064 GET_EC()->errinfo = err;
2070 VALUE err = get_errinfo();
2072 return rb_get_backtrace(err);
2082 VALUE err = get_errinfo();
2084 rb_raise(rb_eArgError,
"$! not set");
2086 set_backtrace(err, val);
2102 ID fname = prev_frame_func();
2124 ID fname = prev_frame_callee();
2145f_current_dirname(
VALUE _)
2147 VALUE base = rb_current_realfilepath();
2151 base = rb_file_dirname(base);
2168f_global_variables(
VALUE _)
2224 rb_gvar_ractor_local(
"$@");
2225 rb_gvar_ractor_local(
"$!");
2246 rb_mod_s_used_modules, 0);
2248 rb_mod_s_used_refinements, 0);
2265 "include", top_include, -1);
2267 "using", top_using, 1);
2274 rb_vm_register_special_exception(ruby_error_reenter,
rb_eFatal,
"exception reentered");
2275 rb_vm_register_special_exception(ruby_error_stackfatal,
rb_eFatal,
"machine stack overflow in critical region");
#define RUBY_ASSERT(...)
Asserts that the given expression is truthy if and only if RUBY_DEBUG is truthy.
#define rb_define_method(klass, mid, func, arity)
Defines klass#mid.
#define rb_define_singleton_method(klass, mid, func, arity)
Defines klass.mid.
#define rb_define_private_method(klass, mid, func, arity)
Defines klass#mid and makes it private.
#define rb_define_global_function(mid, func, arity)
Defines rb_mKernel #mid.
#define RUBY_EVENT_RAISE
Encountered a raise statement.
#define RUBY_EVENT_C_RETURN
Return from a method, written in C.
void rb_include_module(VALUE klass, VALUE module)
Includes a module to a class.
VALUE rb_refinement_new(void)
Creates a new, anonymous refinement.
void rb_extend_object(VALUE obj, VALUE module)
Extend the object with the module.
void rb_prepend_module(VALUE klass, VALUE module)
Identical to rb_include_module(), except it "prepends" the passed module to the klass,...
VALUE rb_singleton_class(VALUE obj)
Finds or creates the singleton class of the passed object.
void rb_class_modify_check(VALUE klass)
Asserts that klass is not a frozen class.
void rb_need_block(void)
Declares that the current method needs a block.
void rb_undef_method(VALUE klass, const char *name)
Defines an undef of a method.
int rb_scan_args(int argc, const VALUE *argv, const char *fmt,...)
Retrieves argument from argc and argv to given VALUE references according to the format string.
int rb_keyword_given_p(void)
Determines if the current method is given a keyword argument.
int rb_block_given_p(void)
Determines if the current method is given a block.
int rb_get_kwargs(VALUE keyword_hash, const ID *table, int required, int optional, VALUE *values)
Keyword argument deconstructor.
#define Qundef
Old name of RUBY_Qundef.
#define INT2FIX
Old name of RB_INT2FIX.
#define OBJ_FROZEN
Old name of RB_OBJ_FROZEN.
#define ID2SYM
Old name of RB_ID2SYM.
#define SPECIAL_CONST_P
Old name of RB_SPECIAL_CONST_P.
#define OBJ_FREEZE
Old name of RB_OBJ_FREEZE.
#define UNREACHABLE_RETURN
Old name of RBIMPL_UNREACHABLE_RETURN.
#define FIX2INT
Old name of RB_FIX2INT.
#define T_MODULE
Old name of RUBY_T_MODULE.
#define T_ICLASS
Old name of RUBY_T_ICLASS.
#define FL_SET
Old name of RB_FL_SET.
#define rb_exc_new3
Old name of rb_exc_new_str.
#define Qtrue
Old name of RUBY_Qtrue.
#define Qnil
Old name of RUBY_Qnil.
#define Qfalse
Old name of RUBY_Qfalse.
#define T_OBJECT
Old name of RUBY_T_OBJECT.
#define NIL_P
Old name of RB_NIL_P.
#define T_CLASS
Old name of RUBY_T_CLASS.
#define BUILTIN_TYPE
Old name of RB_BUILTIN_TYPE.
#define FL_TEST
Old name of RB_FL_TEST.
#define FIXNUM_P
Old name of RB_FIXNUM_P.
#define CONST_ID
Old name of RUBY_CONST_ID.
void ruby_stop(int ex)
Calls ruby_cleanup() and exits the process.
int ruby_exec_node(void *n)
Identical to ruby_run_node(), except it returns an opaque execution status.
int ruby_setup(void)
Initializes the VM and builtin libraries.
void ruby_finalize(void)
Runs the VM finalization processes.
int ruby_cleanup(int ex)
Destructs the VM.
void * ruby_process_options(int argc, char **argv)
Identical to ruby_options(), except it raises ruby-level exceptions on failure.
void ruby_prog_init(void)
Defines built-in variables.
void ruby_sig_finalize(void)
Clear signal handlers.
#define ruby_debug
This variable controls whether the interpreter is in debug mode.
VALUE rb_eLocalJumpError
LocalJumpError exception.
VALUE rb_rescue2(VALUE(*b_proc)(VALUE), VALUE data1, VALUE(*r_proc)(VALUE, VALUE), VALUE data2,...)
An equivalent of rescue clause.
void rb_exc_raise(VALUE mesg)
Raises an exception in the current thread.
VALUE rb_eSystemExit
SystemExit exception.
VALUE rb_eStandardError
StandardError exception.
VALUE rb_eTypeError
TypeError exception.
VALUE rb_vrescue2(VALUE(*b_proc)(VALUE), VALUE data1, VALUE(*r_proc)(VALUE, VALUE), VALUE data2, va_list args)
Identical to rb_rescue2(), except it takes va_list instead of variadic number of arguments.
VALUE rb_eFatal
fatal exception.
VALUE rb_eInterrupt
Interrupt exception.
void rb_exc_fatal(VALUE mesg)
Raises a fatal error in the current thread.
VALUE rb_eRuntimeError
RuntimeError exception.
void rb_warn(const char *fmt,...)
Identical to rb_warning(), except it reports unless $VERBOSE is nil.
VALUE rb_exc_new(VALUE etype, const char *ptr, long len)
Creates an instance of the passed exception class.
void rb_error_frozen_object(VALUE frozen_obj)
Identical to rb_error_frozen(), except it takes arbitrary Ruby object instead of C's string.
VALUE rb_eException
Mother of all exceptions.
VALUE rb_rescue(VALUE(*b_proc)(VALUE), VALUE data1, VALUE(*r_proc)(VALUE, VALUE), VALUE data2)
Identical to rb_rescue2(), except it does not take a list of exception classes.
VALUE rb_ensure(VALUE(*b_proc)(VALUE), VALUE data1, VALUE(*e_proc)(VALUE), VALUE data2)
An equivalent to ensure clause.
VALUE rb_errinfo(void)
This is the same as $! in Ruby.
VALUE rb_eSysStackError
SystemStackError exception.
VALUE rb_eThreadError
ThreadError exception.
void rb_warning(const char *fmt,...)
Issues a warning.
VALUE rb_cClass
Class class.
VALUE rb_mKernel
Kernel module.
VALUE rb_cObject
Object class.
VALUE rb_cRefinement
Refinement class.
static VALUE rb_class_of(VALUE obj)
Object to class mapping function.
VALUE rb_obj_class(VALUE obj)
Queries the class of an object.
VALUE rb_obj_dup(VALUE obj)
Duplicates the given object.
VALUE rb_cBasicObject
BasicObject class.
VALUE rb_cModule
Module class.
VALUE rb_obj_is_kind_of(VALUE obj, VALUE klass)
Queries if the given object is an instance (of possibly descendants) of the given class.
void ruby_init(void)
Calls ruby_setup() and check error.
int ruby_executable_node(void *n, int *status)
Checks the return value of ruby_options().
VALUE rb_funcall(VALUE recv, ID mid, int n,...)
Calls a method.
VALUE rb_funcallv_kw(VALUE recv, ID mid, int argc, const VALUE *argv, int kw_splat)
Identical to rb_funcallv(), except you can specify how to handle the last element of the given array.
VALUE rb_ary_new(void)
Allocates a new, empty array.
VALUE rb_ary_push(VALUE ary, VALUE elem)
Special case of rb_ary_cat() that it adds only one element.
#define UNLIMITED_ARGUMENTS
This macro is used in conjunction with rb_check_arity().
static int rb_check_arity(int argc, int min, int max)
Ensures that the passed integer is in the passed range.
void ruby_default_signal(int sig)
Pretends as if there was no custom signal handler.
#define rb_str_new(str, len)
Allocates an instance of rb_cString.
#define rb_exc_new_cstr(exc, str)
Identical to rb_exc_new(), except it assumes the passed pointer is a pointer to a C string.
VALUE rb_check_string_type(VALUE obj)
Try converting an object to its stringised representation using its to_str method,...
VALUE rb_obj_as_string(VALUE obj)
Try converting an object to its stringised representation using its to_s method, if any.
VALUE rb_f_untrace_var(int argc, const VALUE *argv)
Deletes the passed tracer from the passed global variable, or if omitted, deletes everything.
VALUE rb_const_list(void *)
This is another mysterious API that comes with no documents at all.
VALUE rb_ivar_set(VALUE obj, ID name, VALUE val)
Identical to rb_iv_set(), except it accepts the name as an ID instead of a C string.
VALUE rb_f_trace_var(int argc, const VALUE *argv)
Traces a global variable.
VALUE rb_mod_constants(int argc, const VALUE *argv, VALUE recv)
Resembles Module#constants.
void * rb_mod_const_of(VALUE, void *)
This is a variant of rb_mod_const_at().
void * rb_mod_const_at(VALUE, void *)
This API is mysterious.
VALUE rb_ivar_defined(VALUE obj, ID name)
Queries if the instance variable is defined at the object.
VALUE rb_f_global_variables(void)
Queries the list of global variables.
VALUE rb_class_path(VALUE mod)
Identical to rb_mod_name(), except it returns #<Class: ...> style inspection for anonymous modules.
VALUE rb_check_funcall(VALUE recv, ID mid, int argc, const VALUE *argv)
Identical to rb_funcallv(), except it returns RUBY_Qundef instead of raising rb_eNoMethodError.
static ID rb_intern_const(const char *str)
This is a "tiny optimisation" over rb_intern().
int ruby_vm_destruct(ruby_vm_t *vm)
Destructs the passed VM.
VALUE type(ANYARGS)
ANYARGS-ed function type.
void rb_hash_foreach(VALUE q, int_type *w, VALUE e)
Iteration over the given hash.
void rb_define_virtual_variable(const char *q, type *w, void_type *e)
Define a function-backended global variable.
#define RBASIC(obj)
Convenient casting macro.
#define RCLASS_SUPER
Just another name of rb_class_get_superclass.
#define RHASH_EMPTY_P(h)
Checks if the hash is empty.
const char * rb_obj_classname(VALUE obj)
Queries the name of the class of the passed object.
static int * rb_orig_errno_ptr(void)
Not sure if it is necessary for extension libraries but this is where the "bare" errno is located.
#define RB_NO_KEYWORDS
Do not pass keywords.
VALUE rb_fiber_scheduler_set(VALUE scheduler)
Destructively assigns the passed scheduler to that of the current thread that is calling this functio...
#define RTEST
This is an old name of RB_TEST.
#define _(args)
This was a transition path from K&R to ANSI.
rb_cref_t * cref
class reference, should be marked
const rb_iseq_t * iseqptr
iseq pointer, should be separated from iseqval
uintptr_t ID
Type that represents a Ruby identifier such as a variable name.
uintptr_t VALUE
Type that represents a Ruby object.
static void Check_Type(VALUE v, enum ruby_value_type t)
Identical to RB_TYPE_P(), except it raises exceptions on predication failure.
static bool RB_TYPE_P(VALUE obj, enum ruby_value_type t)
Queries if the given object is of given type.