Ruby 3.5.0dev (2025-01-09 revision 841555245d770df88a0c8079fc97a51ffa7ef8e9)
|
Public APIs related to rb_cRubyVM. More...
#include "ruby/internal/attr/nonnull.h"
#include "ruby/internal/attr/noreturn.h"
#include "ruby/internal/dllexport.h"
#include "ruby/internal/value.h"
Go to the source code of this file.
Macros | |
#define | HAVE_RB_DEFINE_ALLOC_FUNC 1 |
Typedefs | |
typedef VALUE(* | rb_alloc_func_t) (VALUE klass) |
This is the type of functions that ruby calls when trying to allocate an object. | |
Functions | |
int | rb_sourceline (void) |
Resembles __LINE__ . | |
const char * | rb_sourcefile (void) |
Resembles __FILE__ . | |
int | rb_frame_method_id_and_class (ID *idp, VALUE *klassp) |
Resembles __method__ . | |
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. | |
VALUE | rb_check_funcall_kw (VALUE recv, ID mid, int argc, const VALUE *argv, int kw_splat) |
Identical to rb_check_funcall(), except you can specify how to handle the last element of the given array. | |
VALUE | rb_eval_cmd_kw (VALUE cmd, VALUE arg, int kw_splat) |
This API is practically a variant of rb_proc_call_kw() now. | |
VALUE | rb_apply (VALUE recv, ID mid, VALUE args) |
Identical to rb_funcallv(), except it takes Ruby's array instead of C's. | |
VALUE | rb_obj_instance_eval (int argc, const VALUE *argv, VALUE recv) |
Evaluates a string containing Ruby source code, or the given block, within the context of the receiver. | |
VALUE | rb_obj_instance_exec (int argc, const VALUE *argv, VALUE recv) |
Executes the given block within the context of the receiver. | |
VALUE | rb_mod_module_eval (int argc, const VALUE *argv, VALUE mod) |
Identical to rb_obj_instance_eval(), except it evaluates within the context of module. | |
VALUE | rb_mod_module_exec (int argc, const VALUE *argv, VALUE mod) |
Identical to rb_obj_instance_exec(), except it evaluates within the context of module. | |
void | rb_define_alloc_func (VALUE klass, rb_alloc_func_t func) |
Sets the allocator function of a class. | |
void | rb_undef_alloc_func (VALUE klass) |
Deletes the allocator function of a class. | |
rb_alloc_func_t | rb_get_alloc_func (VALUE klass) |
Queries the allocator function of a class. | |
void | rb_clear_constant_cache_for_id (ID id) |
Clears the inline constant caches associated with a particular ID. | |
void | rb_alias (VALUE klass, ID dst, ID src) |
Resembles alias . | |
void | rb_attr (VALUE klass, ID name, int need_reader, int need_writer, int honour_visibility) |
This function resembles now-deprecated Module#attr . | |
void | rb_remove_method (VALUE klass, const char *name) |
Removes a method. | |
void | rb_remove_method_id (VALUE klass, ID mid) |
Identical to rb_remove_method(), except it accepts the method name as ID. | |
int | rb_method_boundp (VALUE klass, ID id, int ex) |
Queries if the klass has this method. | |
int | rb_method_basic_definition_p (VALUE klass, ID mid) |
Well... Let us hesitate from describing what a "basic definition" is. | |
int | rb_obj_respond_to (VALUE obj, ID mid, int private_p) |
Identical to rb_respond_to(), except it additionally takes the visibility parameter. | |
int | rb_respond_to (VALUE obj, ID mid) |
Queries if the object responds to the method. | |
VALUE | rb_f_notimplement (int argc, const VALUE *argv, VALUE obj, VALUE marker) |
Raises rb_eNotImpError. | |
void | rb_backtrace (void) |
Prints the backtrace out to the standard error. | |
VALUE | rb_make_backtrace (void) |
Creates the good old fashioned array-of-strings style backtrace info. | |
Public APIs related to rb_cRubyVM.
RBIMPL
or rbimpl
are implementation details. Don't take them as canon. They could rapidly appear then vanish. The name (path) of this header file is also an implementation detail. Do not expect it to persist at the place it is now. Developers are free to move it anywhere anytime at will. __VA_ARGS__
is always available. We assume C99 for ruby itself but we don't assume languages of extension libraries. They could be written in C++98. Definition in file vm.h.
#define HAVE_RB_DEFINE_ALLOC_FUNC 1 |
This is the type of functions that ruby calls when trying to allocate an object.
It is sometimes necessary to allocate extra memory regions for an object. When you define a class that uses RTypedData, it is typically the case. On such situations define a function of this type and pass it to rb_define_alloc_func().
[in] | klass | The class that this function is registered. |
klass
. Resembles alias
.
[out] | klass | Where to define an alias. |
[in] | dst | New name. |
[in] | src | Existing name. |
rb_eTypeError | `klass` is not a class. |
rb_eFrozenError | `klass` is frozen. |
rb_eNameError | No such method named `src`. |
klass
has a method named dst
, which is the identical to its method named src
. Definition at line 2289 of file vm_method.c.
Referenced by rb_define_alias().
Identical to rb_funcallv(), except it takes Ruby's array instead of C's.
[in,out] | recv | Receiver of the method. |
[in] | mid | Name of the method to call. |
[in] | args | An instance of RArray. |
rb_eNoMethodError | No such method. |
rb_eException | Any exceptions happen inside. |
args
must be an RArray. Call to_ary
beforehand when necessary. This function resembles now-deprecated Module#attr
.
[out] | klass | Where to define an attribute. |
[in] | name | Name of an instance variable. |
[in] | need_reader | Whether attr_reader is needed. |
[in] | need_writer | Whether attr_writer is needed. |
[in] | honour_visibility | Whether to use the current visibility. |
rb_eTypeError | `klass` is not a class. |
rb_eFrozenError | `klass` is frozen. |
need_reader
is set klass
has a method named name
. need_writer
is set klass
has a method named name=
. Definition at line 1869 of file vm_method.c.
Referenced by rb_define_attr().
void rb_backtrace | ( | void | ) |
Prints the backtrace out to the standard error.
This just confuses people for no reason. Evil souls must only use it.
Definition at line 1149 of file vm_backtrace.c.
Referenced by rb_backtrace().
Identical to rb_funcallv(), except it returns RUBY_Qundef instead of raising rb_eNoMethodError.
[in,out] | recv | Receiver of the method. |
[in] | mid | Name of the method to call. |
[in] | argc | Number of arguments. |
[in] | argv | Arbitrary number of method arguments. |
RUBY_Qundef | recv doesn't respond to mid . |
otherwise | What the method evaluates to. |
Definition at line 668 of file vm_eval.c.
Referenced by rb_check_funcall(), rb_fiber_scheduler_address_resolve(), rb_fiber_scheduler_blocking_operation_wait(), rb_fiber_scheduler_close(), rb_fiber_scheduler_io_close(), rb_fiber_scheduler_io_pread(), rb_fiber_scheduler_io_pwrite(), rb_fiber_scheduler_io_read(), rb_fiber_scheduler_io_selectv(), rb_fiber_scheduler_io_write(), rb_fiber_scheduler_process_wait(), rb_io_descriptor(), and rb_range_values().
Identical to rb_check_funcall(), except you can specify how to handle the last element of the given array.
It can also be seen as a routine identical to rb_funcallv_kw(), except it returns RUBY_Qundef instead of raising rb_eNoMethodError.
[in,out] | recv | Receiver of the method. |
[in] | mid | Name of the method to call. |
[in] | argc | Number of arguments. |
[in] | argv | Arbitrary number of method arguments. |
[in] | kw_splat | Handling of keyword parameters:
|
RUBY_Qundef | recv doesn't respond to mid . |
otherwise | What the method evaluates to. |
Definition at line 662 of file vm_eval.c.
Referenced by rb_check_funcall_kw().
void rb_clear_constant_cache_for_id | ( | ID | id | ) |
Clears the inline constant caches associated with a particular ID.
Extension libraries should not bother with such things. Just forget about this API (or even, the presence of constant caches).
Definition at line 140 of file vm_method.c.
Referenced by rb_const_remove().
void rb_define_alloc_func | ( | VALUE | klass, |
rb_alloc_func_t | func | ||
) |
Sets the allocator function of a class.
[out] | klass | The class to modify. |
[in] | func | An allocator function for the class. |
klass
must be an instance of Class. Referenced by rb_undef_alloc_func().
This API is practically a variant of rb_proc_call_kw() now.
Historically when there still was a concept called $SAFE
, this was an API for that. But we no longer have that. This function basically ended its role. It just remains here because of no harm.
[in] | cmd | A string, or something callable. |
[in] | arg | Argument passed to the call. |
[in] | kw_splat | Handling of keyword parameters:
|
Definition at line 2065 of file vm_eval.c.
Referenced by rb_eval_cmd_kw().
Raises rb_eNotImpError.
This function is used as an argument to rb_define_method() etc.
argc | Unused parameter. |
argv | Unused parameter. |
obj | Unused parameter. |
marker | Unused parameter. |
rb_eNotImpError | Always. |
Definition at line 481 of file vm_method.c.
Resembles __method__
.
[out] | idp | Return buffer for method id. |
[out] | klassp | Return buffer for class. |
0 | Current execution context not in a method. |
1 | Successful return. |
*idp
and *klassp
are updated to have the current method name and its defined class respectively. NULL
. rb_alloc_func_t rb_get_alloc_func | ( | VALUE | klass | ) |
Queries the allocator function of a class.
[in] | klass | The class in question. |
klass
must be an instance of Class. 0 | No allocator function is registered. |
otherwise | The allocator function. |
Definition at line 1297 of file vm_method.c.
Referenced by rb_get_alloc_func().
VALUE rb_make_backtrace | ( | void | ) |
Creates the good old fashioned array-of-strings style backtrace info.
Thread::Backtrace::Location
. But it seems there is no way for C extensions to use that API. Definition at line 1192 of file vm_backtrace.c.
Well... Let us hesitate from describing what a "basic definition" is.
This nuanced concept should have been kept private. Just please. Don't touch it. This function is a badly distributed random number generator. Right?
[in] | klass | The class in question. |
[in] | mid | The method name in question. |
1 | It is. |
0 | It isn't. |
Definition at line 2838 of file vm_method.c.
Queries if the klass has this method.
This function has only one line of document in the implementation that states "// deprecated". Don't know what that means though.
[in] | klass | The class in question. |
[in] | id | The method name to query. |
[in] | ex | Undocumented magic value. |
false | Method not found. |
true | There is a method. |
klass
must be a module. Definition at line 1830 of file vm_method.c.
Identical to rb_obj_instance_eval(), except it evaluates within the context of module.
[in] | argc | Number of objects in argv |
[in] | argv | C array of 0 up to 3 elements. |
[in] | mod | The module in question. |
mod
must be a Module. Identical to rb_obj_instance_exec(), except it evaluates within the context of module.
[in] | argc | Number of objects in argv |
[in] | argv | Arbitrary parameters to be passed to the block. |
[in] | mod | The module in question. |
mod
must be a Module. Evaluates a string containing Ruby source code, or the given block, within the context of the receiver.
In order to set the context, the variable self
is set to recv
while the code is executing, giving the code access to recv
's instance variables and private methods.
When given a block, recv
is also passed in as the block's only argument.
When given a string, the optional second and third parameters supply a filename and starting line number that are used when reporting compilation errors.
[in] | argc | Number of objects in argv |
[in] | argv | C array of 0 up to 3 elements. |
[in] | recv | The object in question. |
Executes the given block within the context of the receiver.
In order to set the context, the variable self
is set to recv
while the code is executing, giving the code access to recv
's instance variables. Arguments are passed as block parameters.
[in] | argc | Number of objects in argv |
[in] | argv | Arbitrary parameters to be passed to the block. |
[in] | recv | The object in question. |
Identical to rb_respond_to(), except it additionally takes the visibility parameter.
This does not make difference unless the object has respond_to?
undefined, but has respond_to_missing?
defined. That case the passed argument becomes the second argument of respond_to_missing?
.
[in] | obj | The object in question. |
[in] | mid | The method name in question. |
[in] | private_p | This is the second argument of obj 's respond_to_missing? . |
1 | Yes it does. |
0 | No it doesn't. |
Definition at line 2944 of file vm_method.c.
Referenced by rb_respond_to().
void rb_remove_method | ( | VALUE | klass, |
const char * | name | ||
) |
Removes a method.
Don't confuse this to rb_undef_method(), which doesn't remove a method. This one resembles Module#remove_method
.
[out] | klass | The class to remove a method. |
[in] | name | Name of a method to be removed. |
rb_eTypeError | `klass` is a non-module. |
rb_eFrozenError | `klass` is frozen. |
rb_eNameError | No such method. |
Definition at line 1718 of file vm_method.c.
Identical to rb_remove_method(), except it accepts the method name as ID.
[out] | klass | The class to remove a method. |
[in] | mid | Name of a method to be removed. |
rb_eTypeError | `klass` is a non-module. |
rb_eFrozenError | `klass` is frozen. |
rb_eNameError | No such method. |
Definition at line 1712 of file vm_method.c.
Queries if the object responds to the method.
This involves calling the object's respond_to?
method.
[in] | obj | The object in question. |
[in] | mid | The method name in question. |
1 | Yes it does. |
0 | No it doesn't. |
Definition at line 2960 of file vm_method.c.
Referenced by rb_econv_prepare_options(), and rb_str_equal().
const char * rb_sourcefile | ( | void | ) |
int rb_sourceline | ( | void | ) |
void rb_undef_alloc_func | ( | VALUE | klass | ) |
Deletes the allocator function of a class.
It is sometimes desirable to restrict creation of an instance of a class. For example it rarely makes sense for a DB adaptor class to allow programmers creating DB row objects without querying the DB itself. You can kill sporadic creation of such objects then, by nullifying the allocator function using this API.
[out] | klass | The class to modify. |
klass
must be an instance of Class. Definition at line 1291 of file vm_method.c.
Referenced by rb_undef_alloc_func().