52 #if OPT_CALL_CFUNC_WITHOUT_FRAME
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;
117 val = (*cfunc->
invoker)(cfunc->
func, recv, argc, argv);
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++) {
165 *reg_cfp->
sp++ = argv[
i];
217 case OPTIMIZED_METHOD_TYPE_SEND:
220 case OPTIMIZED_METHOD_TYPE_CALL:
246 return vm_call0(th, recv,
id, argc, argv, me, defined_class);
259 rb_bug(
"vm_call_super: should not be reached");
269 return vm_call0(th, recv,
id, argc, argv, me, klass);
293 #define NOEX_OK NOEX_NOSUPER
324 return vm_call0(th, recv, mid, argc, argv, me, defined_class);
368 if (arity < 1) arity = 2;
374 if (!
RTEST(result)) {
423 return vm_call0(th, recv, mid, argc, argv, me, defined_class);
445 return vm_call0(th, recv, mid, argc, argv, me, defined_class);
451 #define type_case(t) case t: return #t;
478 default:
return NULL;
492 "method `%s' called on unexpected immediate object (%p)",
495 flags =
RBASIC(recv)->flags;
496 klass =
RBASIC(recv)->klass;
499 "method `%s' called on terminated object"
508 "method `%s' called on hidden %s object"
510 rb_id2name(mid), typestr, (
void *)recv, flags, klass);
513 "method `%s' called on unexpected %s object"
514 " (%p flags=0x%"PRIxVALUE
" klass=0x%"PRIxVALUE
")",
515 rb_id2name(mid), typestr, (
void *)recv, flags, klass);
518 "method `%s' called on broken T_???" "(0x%02x) object"
519 " (%p flags=0x%"PRIxVALUE
" klass=0x%"PRIxVALUE
")",
520 rb_id2name(mid), type, (
void *)recv, flags, klass);
540 if (oid != idMethodMissing) {
552 defined_class =
RBASIC(defined_class)->klass;
632 #define NOEX_MISSING 0x80
642 format =
"undefined method `%s' for %s";
660 int last_call_status)
663 const char *format = 0;
665 if (argc == 0 || !
SYMBOL_P(argv[0])) {
672 format =
"private method `%s' called for %s";
675 format =
"protected method `%s' called for %s";
678 format =
"undefined local variable or method `%s' for %s";
682 format =
"super: no superclass method `%s' for %s";
704 if (
id == idMethodMissing) {
723 result =
rb_funcall2(obj, idMethodMissing, argc + 1, nargv);
786 for (i = 0; i <
n; i++) {
787 argv[
i] = va_arg(ar,
VALUE);
836 if (!
NIL_P(pass_procval)) {
842 block = &pass_proc->
block;
869 vid = *argv++; argc--;
875 recv, ++argc, --argv);
881 return rb_call0(recv,
id, argc, argv, scope,
self);
957 for (i=0; i<
n; i++) {
958 argv[
i] = va_arg(args,
VALUE);
1050 blockptr->
iseq = (
void *)node;
1058 retval = (*it_proc) (data1);
1066 if (cep == escape_ep) {
1073 while (th->
cfp != cfp) {
1075 printf(
"skipped frame: %s\n", vm_frametype_name(th->
cfp));
1094 if (cep == escape_ep) {
1180 volatile int parse_in_eval;
1181 volatile int mild_compile_error;
1194 volatile VALUE iseqval;
1197 if (scope !=
Qnil) {
1201 if (strcmp(file,
"(eval)") == 0 && bind->
path !=
Qnil) {
1209 "wrong argument type %s (expected Binding)",
1213 base_block = &env->
block;
1220 base_block = &
block;
1221 base_block->
self =
self;
1260 if (strcmp(file,
"(eval)") == 0) {
1261 VALUE mesg, errat, bt2;
1317 const char *file =
"(eval)";
1320 rb_scan_args(argc, argv,
"13", &src, &scope, &vfile, &vline);
1325 "Insecure: can't modify trusted binding");
1515 block.
self = refinement;
1520 cref->nd_refinements = refinements;
1552 const char *file =
"(eval)";
1567 return eval_under(klass,
self, argv[0], file, line);
1726 if (tt->
tag == tag) {
1829 th->
cfp = saved_cfp;
1884 while (cfp->
ep != ep) {
VALUE rb_f_public_send(int argc, VALUE *argv, VALUE recv)
const rb_block_t * passed_block
#define RB_TYPE_P(obj, type)
struct rb_block_struct * blockptr
VALUE rb_ary_unshift(VALUE ary, VALUE item)
#define UNDEFINED_METHOD_ENTRY_P(me)
#define RUBY_VM_CHECK_INTS(th)
static int check_funcall_respond_to(rb_thread_t *th, VALUE klass, VALUE recv, ID mid)
int register char * block
RUBY_EXTERN VALUE rb_cBasicObject
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)
void rb_bug(const char *fmt,...)
VALUE rb_obj_instance_exec(int, VALUE *, VALUE)
static NODE * vm_cref_push(rb_thread_t *th, VALUE klass, int noex, rb_block_t *blockptr)
RUBY_EXTERN VALUE rb_cModule
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_class_new_instance(int, VALUE *, VALUE)
#define VM_FRAME_FLAG_FINISH
const char * rb_obj_classname(VALUE)
VALUE rb_mod_module_eval(int, VALUE *, VALUE)
static void stack_check(void)
VALUE rb_eval_cmd(VALUE, VALUE, int)
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_ary_subseq(VALUE ary, long beg, long len)
SSL_METHOD *(* func)(void)
VALUE rb_eval_string_wrap(const char *, int *)
Evaluates the given string under a module binding in an isolated binding.
VALUE rb_const_get(VALUE, ID)
static void vm_set_eval_stack(rb_thread_t *th, VALUE iseqval, const NODE *cref, rb_block_t *base_block)
#define RUBY_EVENT_C_RETURN
#define GET_THROWOBJ_CATCH_POINT(obj)
void rb_check_funcall_hook(int, VALUE, ID, int, VALUE *, VALUE)
struct rb_method_entry_struct * orig_me
RUBY_EXTERN VALUE rb_cBinding
#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_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)
VALUE rb_yield_values2(int n, const VALUE *argv)
VALUE rb_yield_values(int n,...)
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_protect(VALUE(*proc)(VALUE), VALUE data, int *state)
static VALUE vm_call0_cfunc_with_frame(rb_thread_t *th, rb_call_info_t *ci, const VALUE *argv)
VALUE rb_funcall(VALUE, ID, int,...)
Calls a method.
void rb_raise(VALUE exc, const char *fmt,...)
VALUE rb_funcall_with_block(VALUE, ID, int, const VALUE *, VALUE)
#define VM_FRAME_TYPE(cfp)
static VALUE rb_yield_0(int argc, const VALUE *argv)
VALUE rb_ary_clear(VALUE ary)
#define SafeStringValue(v)
union rb_method_definition_struct::@112 body
static VALUE vm_yield(rb_thread_t *th, int argc, const VALUE *argv)
static VALUE catch_i(VALUE tag, VALUE data)
#define GetEnvPtr(obj, ptr)
VALUE rb_catch_obj(VALUE, VALUE(*)(ANYARGS), VALUE)
void rb_define_global_function(const char *name, VALUE(*func)(ANYARGS), int argc)
Defines a global function.
VALUE rb_funcall_passing_block(VALUE, ID, int, const VALUE *)
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_catch(const char *, VALUE(*)(ANYARGS), VALUE)
VALUE ruby_eval_string_from_file(const char *str, const char *filename)
VALUE rb_iterate(VALUE(*)(VALUE), VALUE, VALUE(*)(ANYARGS), VALUE)
static int check_funcall_callable(rb_thread_t *th, const rb_method_entry_t *me)
VALUE rb_str_append(VALUE, VALUE)
int ruby_stack_check(void)
#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_vm_call(rb_thread_t *th, VALUE recv, VALUE id, int argc, const VALUE *argv, const rb_method_entry_t *me, VALUE defined_class)
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.
VALUE rb_obj_instance_eval(int, VALUE *, VALUE)
void rb_str_update(VALUE, long, long, VALUE)
unsigned short first_lineno
static VALUE make_no_method_exception(VALUE exc, const char *format, VALUE obj, int argc, const VALUE *argv)
VALUE rb_check_funcall_with_hook(VALUE recv, ID mid, int argc, VALUE *argv, rb_check_funcall_hook *hook, VALUE arg)
static VALUE rb_f_local_variables(void)
int rb_block_given_p(void)
static VALUE rb_f_catch(int argc, VALUE *argv)
#define StringValuePtr(v)
rb_control_frame_t * rb_vm_get_ruby_level_next_cfp(rb_thread_t *th, const rb_control_frame_t *cfp)
VALUE rb_yield_splat(VALUE)
void rb_raise_method_missing(rb_thread_t *th, int argc, VALUE *argv, VALUE obj, int call_status)
VALUE rb_special_singleton_class(VALUE obj)
VALUE rb_eval_string_protect(const char *, int *)
Evaluates the given string in an isolated binding.
RUBY_EXTERN VALUE rb_mKernel
#define GetBindingPtr(obj, ptr)
VALUE rb_yield_refine_block(VALUE refinement, VALUE refinements)
static int rb_method_call_status(rb_thread_t *th, const rb_method_entry_t *me, call_type scope, VALUE self)
static VALUE vm_call0(rb_thread_t *th, VALUE recv, VALUE id, int argc, const VALUE *argv, const rb_method_entry_t *me, VALUE defined_class)
#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)
VALUE rb_call_super(int, const VALUE *)
#define RUBY_DTRACE_CMETHOD_RETURN_HOOK(th, klass, id)
VALUE rb_vm_make_env_object(rb_thread_t *th, rb_control_frame_t *cfp)
static VALUE rb_f_loop(VALUE self)
#define ALLOCA_N(type, n)
enum rb_method_definition_struct::@112::method_optimized_type optimize_type
void rb_throw_obj(VALUE tag, VALUE value)
VALUE rb_check_funcall(VALUE, ID, int, 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_eval_string(const char *)
Evaluates the given string in an isolated binding.
VALUE vm_backtrace_str_ary(rb_thread_t *th, long lev, long n)
VALUE rb_obj_clone(VALUE)
static rb_block_t * VM_CF_BLOCK_PTR(rb_control_frame_t *cfp)
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)
#define CONST_ID(var, str)
int rb_scan_args(int argc, const VALUE *argv, const char *fmt,...)
#define rb_thread_raised_set(th, f)
VALUE rb_block_call(VALUE, ID, int, VALUE *, VALUE(*)(ANYARGS), VALUE)
VALUE rb_f_send(int argc, VALUE *argv, VALUE recv)
static VALUE eval_under(VALUE under, VALUE self, VALUE src, const char *file, int line)
static VALUE rb_f_throw(int argc, VALUE *argv)
static void vm_pop_frame(rb_thread_t *th)
void rb_set_safe_level_force(int)
void rb_extend_object(VALUE obj, VALUE module)
static VALUE vm_yield_with_cref(rb_thread_t *th, int argc, const VALUE *argv, const NODE *cref)
VALUE rb_check_block_call(VALUE, ID, int, VALUE *, VALUE(*)(ANYARGS), VALUE)
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_attr_get(VALUE, ID)
static VALUE vm_call_bmethod_body(rb_thread_t *th, rb_call_info_t *ci, const VALUE *argv)
VALUE(* invoker)(VALUE(*func)(ANYARGS), VALUE recv, int argc, const VALUE *argv)
#define NEW_THROW_OBJECT(val, pt, st)
#define MEMCPY(p1, p2, type, n)
#define va_init_list(a, b)
static VALUE loop_i(void)
VALUE rb_ivar_set(VALUE, ID, VALUE)
VALUE rb_str_cat(VALUE, const char *, long)
#define RETURN_SIZED_ENUMERATOR(obj, argc, argv, size_fn)
static VALUE eval_string_from_file_helper(void *data)
VALUE rb_module_new(void)
VALUE rb_obj_is_kind_of(VALUE, VALUE)
int rb_method_basic_definition_p(VALUE, ID)
int mild_compile_error
Thread-local state of compiling context.
rb_method_definition_t * def
VALUE rb_funcall3(VALUE, ID, int, const VALUE *)
Calls a method.
const rb_method_entry_t * me
VALUE rb_check_array_type(VALUE ary)
static VALUE eval_string_with_cref(VALUE self, VALUE src, VALUE scope, NODE *cref, const char *volatile file, volatile int line)
static VALUE yield_under(VALUE under, VALUE self, VALUE values)
RUBY_EXTERN VALUE rb_cObject
VALUE ruby_eval_string_from_file_protect(const char *str, const char *filename, int *state)
#define RARRAY_LENINT(ary)
int rb_respond_to(VALUE, ID)
static VALUE eval_string(VALUE self, VALUE src, VALUE scope, const char *file, int line)
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_apply(VALUE, ID, VALUE)
Calls a method.
static VALUE specific_eval(int argc, VALUE *argv, VALUE klass, VALUE self)
#define rb_thread_raised_p(th, f)
VALUE rb_f_block_given_p(void)
rb_call_info_t * passed_ci
#define EXEC_EVENT_HOOK(th_, flag_, self_, id_, klass_, data_)
VALUE rb_f_eval(int argc, VALUE *argv, VALUE self)
#define GetISeqPtr(obj, ptr)
VALUE rb_obj_alloc(VALUE)
const char * rb_id2name(ID id)
static VALUE rb_f_loop_size(VALUE self, VALUE args)
#define rb_check_arity(argc, min, max)
static rb_method_entry_t * rb_search_method_entry(VALUE recv, ID mid, VALUE *defined_class_ptr)
VALUE rb_funcall2(VALUE, ID, int, const VALUE *)
Calls a method.
#define PASS_PASSED_BLOCK_TH(th)
static VALUE rb_method_missing(int argc, const VALUE *argv, VALUE obj)
VALUE rb_current_realfilepath(void)
#define CHECK_VM_STACK_OVERFLOW(cfp, margin)
#define SPECIAL_CONST_P(x)
#define NODE_FL_CREF_PUSHED_BY_EVAL
int method_missing_reason
union rb_call_info_struct::@151 aux
static rb_thread_t * GET_THREAD(void)
void rb_define_method(VALUE klass, const char *name, VALUE(*func)(ANYARGS), int argc)
#define RUBY_EVENT_C_CALL
VALUE rb_iseq_disasm(VALUE self)
static VALUE method_missing(VALUE obj, ID id, int argc, const VALUE *argv, int call_status)
#define GET_THROWOBJ_VAL(obj)
static VALUE check_funcall_exec(struct rescue_funcall_args *args)
static VALUE vm_call0_body(rb_thread_t *th, rb_call_info_t *ci, const VALUE *argv)
VALUE rb_mod_module_exec(int, VALUE *, VALUE)
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)