Ruby 3.5.0dev (2025-02-22 revision 412997300569c1853c09813e4924b6df3d7e8669)
variable.h
Go to the documentation of this file.
1#ifndef RBIMPL_INTERN_VARIABLE_H /*-*-C++-*-vi:se ft=cpp:*/
2#define RBIMPL_INTERN_VARIABLE_H
26#include "ruby/internal/value.h"
27#include "ruby/st.h"
28
30
31/* variable.c */
32
33
41
50
59
69void rb_set_class_path(VALUE klass, VALUE space, const char *name);
70
80void rb_set_class_path_string(VALUE klass, VALUE space, VALUE name);
81
92
102VALUE rb_path2class(const char *path);
103
111
130VALUE rb_autoload_load(VALUE space, ID name);
131
140VALUE rb_autoload_p(VALUE space, ID name);
141
154VALUE rb_f_trace_var(int argc, const VALUE *argv);
155
169VALUE rb_f_untrace_var(int argc, const VALUE *argv);
170
181
201void rb_alias_variable(ID dst, ID src);
202
218
228VALUE rb_ivar_get(VALUE obj, ID name);
229
243VALUE rb_ivar_set(VALUE obj, ID name, VALUE val);
244
254VALUE rb_ivar_defined(VALUE obj, ID name);
255
263void rb_ivar_foreach(VALUE obj, int (*func)(ID name, VALUE val, st_data_t arg), st_data_t arg);
264
271st_index_t rb_ivar_count(VALUE obj);
272
285VALUE rb_attr_get(VALUE obj, ID name);
286
296
306
316void *rb_mod_const_at(VALUE, void*);
317
323void *rb_mod_const_of(VALUE, void*);
324
331VALUE rb_const_list(void*);
332
346VALUE rb_mod_constants(int argc, const VALUE *argv, VALUE recv);
347
361
375int rb_const_defined(VALUE space, ID name);
376
393int rb_const_defined_at(VALUE space, ID name);
394
411int rb_const_defined_from(VALUE space, ID name);
412
425VALUE rb_const_get(VALUE space, ID name);
426
441VALUE rb_const_get_at(VALUE space, ID name);
442
457VALUE rb_const_get_from(VALUE space, ID name);
458
473void rb_const_set(VALUE space, ID name, VALUE val);
474
488VALUE rb_const_remove(VALUE space, ID name);
489
490#if 0 /* EXPERIMENTAL: remove if no problem */
499VALUE rb_mod_const_missing(VALUE space, VALUE name);
500#endif
501
515VALUE rb_cvar_defined(VALUE klass, ID name);
516
529void rb_cvar_set(VALUE klass, ID name, VALUE val);
530
544VALUE rb_cvar_get(VALUE klass, ID name);
545
565VALUE rb_cvar_find(VALUE klass, ID name, VALUE *front);
566
576void rb_cv_set(VALUE klass, const char *name, VALUE val);
577
588VALUE rb_cv_get(VALUE klass, const char *name);
589
598void rb_define_class_variable(VALUE, const char*, VALUE);
599
614VALUE rb_mod_class_variables(int argc, const VALUE *argv, VALUE recv);
615
625
627
628#endif /* RBIMPL_INTERN_VARIABLE_H */
Tweaking visibility of C variables/functions.
#define RBIMPL_SYMBOL_EXPORT_END()
Counterpart of RBIMPL_SYMBOL_EXPORT_BEGIN.
Definition dllexport.h:74
#define RBIMPL_SYMBOL_EXPORT_BEGIN()
Shortcut macro equivalent to RUBY_SYMBOL_EXPORT_BEGIN extern "C" {.
Definition dllexport.h:65
VALUE rb_mod_remove_cvar(VALUE mod, VALUE name)
Resembles Module#remove_class_variable.
Definition variable.c:4162
VALUE rb_obj_instance_variables(VALUE obj)
Resembles Object#instance_variables.
Definition variable.c:2179
VALUE rb_f_untrace_var(int argc, const VALUE *argv)
Deletes the passed tracer from the passed global variable, or if omitted, deletes everything.
Definition variable.c:813
VALUE rb_const_get(VALUE space, ID name)
Identical to rb_const_defined(), except it returns the actual defined value.
Definition variable.c:3135
VALUE rb_const_list(void *)
This is another mysterious API that comes with no documents at all.
Definition variable.c:3369
VALUE rb_path2class(const char *path)
Resolves a Q::W::E::R-style path string to the actual class it points.
Definition variable.c:406
VALUE rb_autoload_p(VALUE space, ID name)
Queries if an autoload is defined at a point.
Definition variable.c:3008
void rb_set_class_path(VALUE klass, VALUE space, const char *name)
Names a class.
Definition variable.c:353
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.
Definition variable.c:1844
VALUE rb_mod_remove_const(VALUE space, VALUE name)
Resembles Module#remove_const.
Definition variable.c:3240
VALUE rb_class_path_cached(VALUE mod)
Just another name of rb_mod_name.
Definition variable.c:302
VALUE rb_f_trace_var(int argc, const VALUE *argv)
Traces a global variable.
Definition variable.c:767
void rb_cvar_set(VALUE klass, ID name, VALUE val)
Assigns a value to a class variable.
Definition variable.c:3927
VALUE rb_cvar_get(VALUE klass, ID name)
Obtains a value from a class variable.
Definition variable.c:3997
VALUE rb_mod_constants(int argc, const VALUE *argv, VALUE recv)
Resembles Module#constants.
Definition variable.c:3401
VALUE rb_cvar_find(VALUE klass, ID name, VALUE *front)
Identical to rb_cvar_get(), except it takes additional "front" pointer.
Definition variable.c:3982
VALUE rb_path_to_class(VALUE path)
Identical to rb_path2class(), except it accepts the path as Ruby's string instead of C's.
Definition variable.c:361
VALUE rb_ivar_get(VALUE obj, ID name)
Identical to rb_iv_get(), except it accepts the name as an ID instead of a C string.
Definition variable.c:1335
void rb_ivar_foreach(VALUE obj, int(*func)(ID name, VALUE val, st_data_t arg), st_data_t arg)
Iterates over an object's instance variables.
void rb_const_set(VALUE space, ID name, VALUE val)
Names a constant.
Definition variable.c:3604
VALUE rb_autoload_load(VALUE space, ID name)
Kicks the autoload procedure as if it was "touched".
Definition variable.c:2970
VALUE rb_mod_name(VALUE mod)
Queries the name of a module.
Definition variable.c:130
VALUE rb_class_name(VALUE obj)
Queries the name of the given object's class.
Definition variable.c:412
VALUE rb_const_get_at(VALUE space, ID name)
Identical to rb_const_defined_at(), except it returns the actual defined value.
Definition variable.c:3141
void rb_set_class_path_string(VALUE klass, VALUE space, VALUE name)
Identical to rb_set_class_path(), except it accepts the name as Ruby's string instead of C's.
Definition variable.c:336
void rb_alias_variable(ID dst, ID src)
Aliases a global variable.
Definition variable.c:999
void rb_define_class_variable(VALUE, const char *, VALUE)
Just another name of rb_cv_set.
Definition variable.c:4037
VALUE rb_obj_remove_instance_variable(VALUE obj, VALUE name)
Resembles Object#remove_instance_variable.
Definition variable.c:2233
void * rb_mod_const_of(VALUE, void *)
This is a variant of rb_mod_const_at().
Definition variable.c:3347
st_index_t rb_ivar_count(VALUE obj)
Number of instance variables defined on an object.
Definition variable.c:2127
void * rb_mod_const_at(VALUE, void *)
This API is mysterious.
Definition variable.c:3330
VALUE rb_const_remove(VALUE space, ID name)
Identical to rb_mod_remove_const(), except it takes the name as ID instead of VALUE.
Definition variable.c:3251
VALUE rb_const_get_from(VALUE space, ID name)
Identical to rb_const_defined_at(), except it returns the actual defined value.
Definition variable.c:3129
VALUE rb_ivar_defined(VALUE obj, ID name)
Queries if the instance variable is defined at the object.
Definition variable.c:1861
VALUE rb_cv_get(VALUE klass, const char *name)
Identical to rb_cvar_get(), except it accepts C's string instead of ID.
Definition variable.c:4030
int rb_const_defined_at(VALUE space, ID name)
Identical to rb_const_defined(), except it doesn't look for parent classes.
Definition variable.c:3463
void rb_cv_set(VALUE klass, const char *name, VALUE val)
Identical to rb_cvar_set(), except it accepts C's string instead of ID.
Definition variable.c:4023
VALUE rb_mod_class_variables(int argc, const VALUE *argv, VALUE recv)
Resembles Module#class_variables.
Definition variable.c:4127
VALUE rb_f_global_variables(void)
Queries the list of global variables.
Definition variable.c:967
VALUE rb_cvar_defined(VALUE klass, ID name)
Queries if the given class has the given class variable.
Definition variable.c:4004
VALUE rb_class_path(VALUE mod)
Identical to rb_mod_name(), except it returns #<Class: ...> style inspection for anonymous modules.
Definition variable.c:293
int rb_const_defined_from(VALUE space, ID name)
Identical to rb_const_defined(), except it returns false for private constants.
Definition variable.c:3451
int rb_const_defined(VALUE space, ID name)
Queries if the constant is defined at the namespace.
Definition variable.c:3457
void rb_free_generic_ivar(VALUE obj)
Frees the list of instance variables.
Definition variable.c:1140
Defines RBIMPL_ATTR_NONNULL.
#define RBIMPL_ATTR_NONNULL(list)
Wraps (or simulates) __attribute__((nonnull))
Definition nonnull.h:30
Defines RBIMPL_ATTR_NORETURN.
#define RBIMPL_ATTR_NORETURN()
Wraps (or simulates) [[noreturn]]
Definition noreturn.h:38
Defines VALUE and ID.
uintptr_t ID
Type that represents a Ruby identifier such as a variable name.
Definition value.h:52
uintptr_t VALUE
Type that represents a Ruby object.
Definition value.h:40