52 #if OPT_CALL_CFUNC_WITHOUT_FRAME 64 int len = cfunc->
argc;
73 if (reg_cfp == th->
cfp) {
75 rb_bug(
"vm_call0_cfunc: passed_ci error (ci: %p, passed_ci: %p)", ci, th->
passed_ci);
80 if (reg_cfp != th->
cfp + 1) {
81 rb_bug(
"vm_call0_cfunc: cfp consistency error");
99 int len = cfunc->
argc;
120 rb_bug(
"vm_call0_cfunc_with_frame: cfp consistency error");
163 *reg_cfp->
sp++ = ci->
recv;
164 for (
i = 0;
i < ci->
argc;
i++) {
217 case OPTIMIZED_METHOD_TYPE_SEND:
220 case OPTIMIZED_METHOD_TYPE_CALL:
259 rb_bug(
"vm_call_super: should not be reached");
293 #define NOEX_OK NOEX_NOSUPER 368 if (arity < 1) arity = 2;
451 #define type_case(t) case t: return #t; 478 default:
return NULL;
492 "method `%"PRIsVALUE"' called on unexpected immediate object (%p)",
498 "method `%"PRIsVALUE"' called on terminated object" 507 "method `%"PRIsVALUE"' called on hidden %s object" 512 "method `%"PRIsVALUE"' called on unexpected %s object" 517 "method `%"PRIsVALUE"' called on broken T_???" "(0x%02x) object" 539 if (oid != idMethodMissing) {
548 VALUE defined_class = klass;
551 defined_class =
RBASIC(defined_class)->klass;
588 VALUE obj,
int call_status));
631 #define NOEX_MISSING 0x80 641 format =
"undefined method `%s' for %s";
659 int last_call_status)
662 const char *format = 0;
671 format =
"private method `%s' called for %s";
674 format =
"protected method `%s' called for %s";
677 format =
"undefined local variable or method `%s' for %s";
681 format =
"super: no superclass method `%s' for %s";
703 if (
id == idMethodMissing) {
729 VALUE obj,
int call_status)
785 for (
i = 0;
i < n;
i++) {
835 if (!
NIL_P(pass_procval)) {
841 block = &pass_proc->
block;
956 for (
i=0;
i<n;
i++) {
1050 blockptr->
iseq = (
void *)node;
1058 retval = (*it_proc) (data1);
1066 if (cep == escape_ep) {
1082 if (cep == escape_ep) {
1169 volatile int parse_in_eval;
1170 volatile int mild_compile_error;
1183 volatile VALUE iseqval;
1188 absolute_path = file;
1191 if (!
NIL_P(scope)) {
1203 "wrong argument type %s (expected Binding)",
1207 base_block = &
env->block;
1214 base_block = █
1215 base_block->
self =
self;
1223 if ((fname = file) ==
Qundef) {
1260 VALUE mesg, errat, bt2;
1315 VALUE src, scope, vfile, vline;
1324 "Insecure: can't modify trusted binding");
1515 block.
self = refinement;
1520 cref->nd_refinements = refinements;
1885 while (cfp->
ep != ep) {
VALUE rb_f_public_send(int argc, VALUE *argv, VALUE recv)
const rb_block_t * passed_block
struct rb_block_struct * blockptr
VALUE rb_ary_unshift(VALUE ary, VALUE item)
#define UNDEFINED_METHOD_ENTRY_P(me)
VALUE rb_vm_call(rb_thread_t *th, VALUE recv, VALUE id, int argc, const VALUE *argv, const rb_method_entry_t *me, VALUE defined_class)
#define RUBY_VM_CHECK_INTS(th)
static int check_funcall_respond_to(rb_thread_t *th, VALUE klass, VALUE recv, ID mid)
VALUE rb_ary_new4(long n, const VALUE *elts)
static int vm_collect_local_variables_in_heap(rb_thread_t *th, VALUE *dfp, VALUE ary)
#define RUBY_EVENT_C_RETURN
void rb_bug(const char *fmt,...)
static NODE * vm_cref_push(rb_thread_t *th, VALUE klass, int noex, rb_block_t *blockptr)
static VALUE iterate_method(VALUE obj)
static VALUE rb_call0(VALUE recv, ID mid, int argc, const VALUE *argv, call_type scope, VALUE self)
static rb_control_frame_t * vm_get_ruby_level_caller_cfp(rb_thread_t *th, rb_control_frame_t *cfp)
VALUE rb_current_realfilepath(void)
VALUE rb_mod_module_eval(int argc, VALUE *argv, VALUE mod)
#define VM_FRAME_FLAG_FINISH
VALUE rb_yield_values(int n,...)
static void stack_check(void)
static VALUE * VM_CF_PREV_EP(rb_control_frame_t *cfp)
#define VM_FRAME_MAGIC_CFUNC
static VALUE send_internal(int argc, const VALUE *argv, VALUE recv, call_type scope)
void rb_throw(const char *tag, VALUE val)
#define RUBY_VM_PREVIOUS_CONTROL_FRAME(cfp)
#define GetProcPtr(obj, ptr)
VALUE rb_eval_string_protect(const char *str, int *state)
Evaluates the given string in an isolated binding.
VALUE rb_yield_splat(VALUE values)
VALUE rb_ary_subseq(VALUE ary, long beg, long len)
VALUE rb_str_cat(VALUE, const char *, long)
VALUE rb_call_super(int argc, const VALUE *argv)
static void vm_set_eval_stack(rb_thread_t *th, VALUE iseqval, const NODE *cref, rb_block_t *base_block)
#define GET_THROWOBJ_CATCH_POINT(obj)
struct rb_method_entry_struct * orig_me
void rb_check_funcall_hook(int, VALUE, ID, int, VALUE *, VALUE)
#define new_args(f, o, r, p, t)
static void raise_method_missing(rb_thread_t *th, int argc, const VALUE *argv, VALUE obj, int last_call_status)
void rb_define_private_method(VALUE klass, const char *name, VALUE(*func)(ANYARGS), int argc)
ID rb_frame_this_func(void)
VALUE rb_f_eval(int argc, VALUE *argv, VALUE self)
VALUE rb_name_err_mesg_new(VALUE obj, VALUE mesg, VALUE recv, VALUE method)
#define TH_JUMP_TAG(th, st)
static VALUE check_funcall_failed(struct rescue_funcall_args *args, VALUE e)
VALUE rb_ary_push(VALUE ary, VALUE item)
SSL_METHOD *(* func)(void)
VALUE rb_ary_tmp_new(long capa)
VALUE rb_iseq_compile_with_option(VALUE src, VALUE file, VALUE absolute_path, VALUE line, rb_block_t *base_block, VALUE opt)
#define RUBY_VM_GET_BLOCK_PTR_IN_CFP(cfp)
#define VM_ENVVAL_BLOCK_PTR(v)
VALUE rb_catch_obj(VALUE tag, VALUE(*func)(), VALUE data)
VALUE rb_protect(VALUE(*proc)(VALUE), VALUE data, int *state)
union rb_method_definition_struct::@90 body
static VALUE vm_call0_cfunc_with_frame(rb_thread_t *th, rb_call_info_t *ci, const VALUE *argv)
void rb_raise(VALUE exc, const char *fmt,...)
static VALUE rb_yield_0(int argc, const VALUE *argv)
void rb_str_update(VALUE, long, long, VALUE)
VALUE rb_ary_clear(VALUE ary)
VALUE rb_obj_is_kind_of(VALUE, VALUE)
static VALUE vm_yield(rb_thread_t *th, int argc, const VALUE *argv)
VALUE rb_catch(const char *tag, VALUE(*func)(), VALUE data)
static VALUE catch_i(VALUE tag, VALUE data)
#define GetEnvPtr(obj, ptr)
void rb_define_global_function(const char *name, VALUE(*func)(ANYARGS), int argc)
Defines a global function.
VALUE rb_vm_invoke_proc(rb_thread_t *th, rb_proc_t *proc, int argc, const VALUE *argv, const rb_block_t *blockptr)
static VALUE * VM_CF_LEP(rb_control_frame_t *cfp)
ID rb_check_id(volatile VALUE *namep)
Returns ID for the given name if it is interned already, or 0.
VALUE rb_eval_string_wrap(const char *str, int *state)
Evaluates the given string under a module binding in an isolated binding.
VALUE ruby_eval_string_from_file(const char *str, const char *filename)
static int check_funcall_callable(rb_thread_t *th, const rb_method_entry_t *me)
int ruby_stack_check(void)
const char * rb_obj_classname(VALUE)
#define RUBY_DTRACE_CMETHOD_ENTRY_HOOK(th, klass, id)
static VALUE check_funcall_missing(rb_thread_t *th, VALUE klass, VALUE recv, ID mid, int argc, VALUE *argv)
VALUE rb_check_funcall(VALUE recv, ID mid, int argc, VALUE *argv)
void rb_exc_raise(VALUE mesg)
static VALUE vm_call0_cfunc(rb_thread_t *th, rb_call_info_t *ci, const VALUE *argv)
VALUE rb_singleton_class(VALUE obj)
Returns the singleton class of obj.
#define RB_TYPE_P(obj, type)
RUBY_EXTERN VALUE rb_cBinding
unsigned short first_lineno
static VALUE make_no_method_exception(VALUE exc, const char *format, VALUE obj, int argc, const VALUE *argv)
VALUE rb_class_new_instance(int, VALUE *, VALUE)
static VALUE rb_f_local_variables(void)
union rb_call_info_struct::@129 aux
int rb_block_given_p(void)
static VALUE rb_f_catch(int argc, VALUE *argv)
rb_control_frame_t * rb_vm_get_ruby_level_next_cfp(rb_thread_t *th, const rb_control_frame_t *cfp)
VALUE rb_mod_module_exec(int argc, VALUE *argv, VALUE mod)
void rb_raise_method_missing(rb_thread_t *th, int argc, VALUE *argv, VALUE obj, int call_status)
RUBY_EXTERN VALUE rb_cObject
VALUE rb_special_singleton_class(VALUE obj)
#define GetBindingPtr(obj, ptr)
RUBY_EXTERN VALUE rb_cBasicObject
VALUE rb_funcall(VALUE recv, ID mid, int n,...)
Calls a method.
VALUE rb_funcall2(VALUE recv, ID mid, int argc, const VALUE *argv)
Calls a method.
static int rb_method_call_status(rb_thread_t *th, const rb_method_entry_t *me, call_type scope, VALUE self)
RUBY_EXTERN VALUE rb_mKernel
#define PASS_PASSED_BLOCK()
static VALUE iterate_check_method(VALUE obj)
VALUE rb_get_backtrace(VALUE info)
static const char * rb_type_str(enum ruby_value_type type)
int rb_method_entry_arity(const rb_method_entry_t *me)
#define ALLOCA_N(type, n)
#define RUBY_DTRACE_CMETHOD_RETURN_HOOK(th, klass, id)
RUBY_EXTERN VALUE rb_cModule
static VALUE eval_under(VALUE under, VALUE self, VALUE src, VALUE file, int line)
#define MEMCPY(p1, p2, type, n)
VALUE rb_obj_alloc(VALUE)
#define RUBY_EVENT_C_CALL
VALUE rb_vm_make_env_object(rb_thread_t *th, rb_control_frame_t *cfp)
static VALUE rb_f_loop(VALUE self)
void rb_throw_obj(VALUE tag, VALUE value)
static rb_control_frame_t * vm_push_frame(rb_thread_t *th, const rb_iseq_t *iseq, VALUE type, VALUE self, VALUE klass, VALUE specval, const VALUE *pc, VALUE *sp, int local_size, const rb_method_entry_t *me)
rb_method_entry_t * rb_method_entry(VALUE klass, ID id, VALUE *define_class_ptr)
VALUE rb_const_get(VALUE, ID)
static rb_block_t * VM_CF_BLOCK_PTR(rb_control_frame_t *cfp)
VALUE(* invoker)(VALUE(*func)(ANYARGS), VALUE recv, int argc, const VALUE *argv)
static VALUE vm_exec(rb_thread_t *th)
rb_method_entry_t * rb_add_method(VALUE klass, ID mid, rb_method_type_t type, void *option, rb_method_flag_t noex)
VALUE rb_eval_string(const char *str)
Evaluates the given string in an isolated binding.
VALUE rb_iterate(VALUE(*it_proc)(VALUE), VALUE data1, VALUE(*bl_proc)(ANYARGS), VALUE data2)
int rb_scan_args(int argc, const VALUE *argv, const char *fmt,...)
#define rb_thread_raised_set(th, f)
VALUE rb_ivar_set(VALUE, ID, VALUE)
VALUE rb_f_send(int argc, VALUE *argv, VALUE recv)
void rb_vm_pop_cfunc_frame(void)
static VALUE rb_f_throw(int argc, VALUE *argv)
static void vm_pop_frame(rb_thread_t *th)
#define RETURN_SIZED_ENUMERATOR(obj, argc, argv, size_fn)
VALUE rb_funcall3(VALUE recv, ID mid, int argc, const VALUE *argv)
Calls a method.
void rb_extend_object(VALUE obj, VALUE module)
VALUE rb_check_funcall_with_hook(VALUE recv, ID mid, int argc, VALUE *argv, rb_check_funcall_hook *hook, VALUE arg)
VALUE rb_obj_instance_eval(int argc, VALUE *argv, VALUE self)
static VALUE vm_yield_with_cref(rb_thread_t *th, int argc, const VALUE *argv, const NODE *cref)
static VALUE vm_call_super(rb_thread_t *th, int argc, const VALUE *argv)
VALUE rb_rescue2(VALUE(*b_proc)(ANYARGS), VALUE data1, VALUE(*r_proc)(ANYARGS), VALUE data2,...)
rb_iseq_location_t location
VALUE rb_str_new_cstr(const char *)
static VALUE vm_call_bmethod_body(rb_thread_t *th, rb_call_info_t *ci, const VALUE *argv)
#define RARRAY_LENINT(ary)
VALUE rb_block_call(VALUE obj, ID mid, int argc, VALUE *argv, VALUE(*bl_proc)(ANYARGS), VALUE data2)
static VALUE vm_call0(rb_thread_t *th, VALUE recv, ID id, int argc, const VALUE *argv, const rb_method_entry_t *me, VALUE defined_class)
VALUE rb_yield_refine_block(VALUE refinement, VALUE refinements)
#define NEW_THROW_OBJECT(val, pt, st)
int rb_respond_to(VALUE, ID)
void rb_set_safe_level_force(int)
#define va_init_list(a, b)
static VALUE loop_i(void)
static VALUE eval_string_from_file_helper(void *data)
#define rb_check_arity(argc, min, max)
VALUE rb_obj_instance_exec(int argc, VALUE *argv, VALUE self)
VALUE rb_module_new(void)
int mild_compile_error
Thread-local state of compiling context.
VALUE rb_funcall_with_block(VALUE recv, ID mid, int argc, const VALUE *argv, VALUE pass_procval)
rb_method_definition_t * def
const rb_method_entry_t * me
VALUE rb_check_array_type(VALUE ary)
static VALUE yield_under(VALUE under, VALUE self, VALUE values)
VALUE ruby_eval_string_from_file_protect(const char *str, const char *filename, int *state)
int rb_method_basic_definition_p(VALUE, ID)
VALUE rb_apply(VALUE recv, ID mid, VALUE args)
Calls a method.
static VALUE vm_call_iseq_setup(rb_thread_t *th, rb_control_frame_t *cfp, rb_call_info_t *ci)
static VALUE rb_call(VALUE recv, ID mid, int argc, const VALUE *argv, call_type scope)
VALUE rb_yield_values2(int argc, const VALUE *argv)
VALUE rb_funcall_passing_block(VALUE recv, ID mid, int argc, const VALUE *argv)
static VALUE specific_eval(int argc, VALUE *argv, VALUE klass, VALUE self)
#define rb_thread_raised_p(th, f)
#define SafeStringValue(v)
VALUE rb_f_block_given_p(void)
rb_call_info_t * passed_ci
#define EXEC_EVENT_HOOK(th_, flag_, self_, id_, klass_, data_)
NORETURN(static void raise_method_missing(rb_thread_t *th, int argc, const VALUE *argv, VALUE obj, int call_status))
#define GetISeqPtr(obj, ptr)
VALUE rb_yield(VALUE val)
const char * rb_id2name(ID id)
static VALUE rb_f_loop_size(VALUE self, VALUE args)
#define StringValuePtr(v)
static rb_method_entry_t * rb_search_method_entry(VALUE recv, ID mid, VALUE *defined_class_ptr)
#define PASS_PASSED_BLOCK_TH(th)
void rb_vm_rewind_cfp(rb_thread_t *th, rb_control_frame_t *cfp)
static VALUE rb_method_missing(int argc, const VALUE *argv, VALUE obj)
static VALUE eval_string_with_cref(VALUE self, VALUE src, VALUE scope, NODE *cref, volatile VALUE file, volatile int line)
#define CONST_ID(var, str)
VALUE vm_backtrace_str_ary(rb_thread_t *th, int lev, int n)
#define SPECIAL_CONST_P(x)
#define CHECK_VM_STACK_OVERFLOW(cfp, margin)
static VALUE eval_string(VALUE self, VALUE src, VALUE scope, VALUE file, int line)
VALUE rb_eval_cmd(VALUE cmd, VALUE arg, int level)
int method_missing_reason
enum rb_method_definition_struct::@90::method_optimized_type optimize_type
static rb_thread_t * GET_THREAD(void)
void rb_define_method(VALUE klass, const char *name, VALUE(*func)(ANYARGS), int argc)
VALUE rb_str_append(VALUE, VALUE)
VALUE rb_iseq_disasm(VALUE self)
VALUE rb_str_new2(const char *)
static VALUE method_missing(VALUE obj, ID id, int argc, const VALUE *argv, int call_status)
#define GET_THROWOBJ_VAL(obj)
VALUE rb_check_block_call(VALUE obj, ID mid, int argc, VALUE *argv, VALUE(*bl_proc)(ANYARGS), VALUE data2)
VALUE rb_obj_clone(VALUE)
static VALUE check_funcall_exec(struct rescue_funcall_args *args)
VALUE rb_sourcefilename(void)
static VALUE vm_call0_body(rb_thread_t *th, rb_call_info_t *ci, const VALUE *argv)
VALUE rb_attr_get(VALUE, ID)
VALUE rb_usascii_str_new_cstr(const char *)
const rb_method_entry_t * me
int parse_in_eval
Thread-local state of evaluation context.
void rb_ary_set_len(VALUE ary, long len)
#define NODE_FL_CREF_PUSHED_BY_EVAL