Ruby 4.1.0dev (2026-03-01 revision 19b636d3ecc8a824437e0d6abd7fe0c24b594ce0)
rdata.h
Go to the documentation of this file.
1#ifndef RBIMPL_RDATA_H /*-*-C++-*-vi:se ft=cpp:*/
2#define RBIMPL_RDATA_H
23#include "ruby/internal/config.h"
24
25#ifdef STDC_HEADERS
26# include <stddef.h>
27#endif
28
31#include "ruby/internal/cast.h"
35#include "ruby/internal/value.h"
37#include "ruby/defines.h"
38
40#ifndef RUBY_UNTYPED_DATA_WARNING
41#define RUBY_UNTYPED_DATA_WARNING 1
42#endif
43
44#define RBIMPL_DATA_FUNC(f) RBIMPL_CAST((void (*)(void *))(f))
45#define RBIMPL_ATTRSET_UNTYPED_DATA_FUNC() \
46 RBIMPL_ATTR_WARNING(("untyped Data is unsafe; use TypedData instead")) \
47 RBIMPL_ATTR_DEPRECATED(("by TypedData"))
48
49#define RBIMPL_MACRO_SELECT(x, y) x ## y
50#define RUBY_MACRO_SELECT(x, y) RBIMPL_MACRO_SELECT(x, y)
59#define RDATA(obj) RBIMPL_CAST((struct RData *)(obj))
60
67#define DATA_PTR(obj) RDATA(obj)->data
68
78#define RUBY_DEFAULT_FREE RBIMPL_DATA_FUNC(-1)
79
85#define RUBY_NEVER_FREE RBIMPL_DATA_FUNC(0)
86
94#define RUBY_UNTYPED_DATA_FUNC(f) f RBIMPL_ATTRSET_UNTYPED_DATA_FUNC()
95
96/*
97#define RUBY_DATA_FUNC(func) ((void (*)(void*))(func))
98*/
99
104typedef void (*RUBY_DATA_FUNC)(void*);
105
120struct RData {
121
123 struct RBasic basic;
124
135
144
149 void *data;
150};
151
153
154
166
182
184
196#define Data_Wrap_Struct(klass, mark, free, sval) \
197 rb_data_object_wrap( \
198 (klass), \
199 (sval), \
200 RBIMPL_DATA_FUNC(mark), \
201 RBIMPL_DATA_FUNC(free))
202
217#define Data_Make_Struct0(result, klass, type, size, mark, free, sval) \
218 VALUE result = rb_data_object_zalloc( \
219 (klass), \
220 (size), \
221 RBIMPL_DATA_FUNC(mark), \
222 RBIMPL_DATA_FUNC(free)); \
223 (sval) = RBIMPL_CAST((type *)DATA_PTR(result)); \
224 RBIMPL_CAST(/*suppress unused variable warnings*/(void)(sval))
225
241#ifdef HAVE_STMT_AND_DECL_IN_EXPR
242#define Data_Make_Struct(klass, type, mark, free, sval) \
243 RB_GNUC_EXTENSION({ \
244 Data_Make_Struct0( \
245 data_struct_obj, \
246 klass, \
247 type, \
248 sizeof(type), \
249 mark, \
250 free, \
251 sval); \
252 data_struct_obj; \
253 })
254#else
255#define Data_Make_Struct(klass, type, mark, free, sval) \
256 rb_data_object_make( \
257 (klass), \
258 RBIMPL_DATA_FUNC(mark), \
259 RBIMPL_DATA_FUNC(free), \
260 RBIMPL_CAST((void **)&(sval)), \
261 sizeof(type))
262#endif
263
272#define Data_Get_Struct(obj, type, sval) \
273 ((sval) = RBIMPL_CAST((type*)rb_data_object_get(obj)))
274
275RBIMPL_ATTRSET_UNTYPED_DATA_FUNC()
290static inline VALUE
291rb_data_object_wrap_warning(VALUE klass, void *ptr, RUBY_DATA_FUNC mark, RUBY_DATA_FUNC free)
292{
293 return rb_data_object_wrap(klass, ptr, mark, free);
294}
295
305static inline void *
306rb_data_object_get(VALUE obj)
307{
309 return DATA_PTR(obj);
310}
311
312RBIMPL_ATTRSET_UNTYPED_DATA_FUNC()
322static inline void *
323rb_data_object_get_warning(VALUE obj)
324{
325 return rb_data_object_get(obj);
326}
327
342static inline VALUE
343rb_data_object_make(VALUE klass, RUBY_DATA_FUNC mark_func, RUBY_DATA_FUNC free_func, void **datap, size_t size)
344{
345 Data_Make_Struct0(result, klass, void, size, mark_func, free_func, *datap);
346 return result;
347}
348
350#define rb_data_object_wrap_0 rb_data_object_wrap
351#define rb_data_object_wrap_1 rb_data_object_wrap_warning
352#define rb_data_object_wrap_2 rb_data_object_wrap_ /* Used here vvvv */
353#define rb_data_object_wrap RUBY_MACRO_SELECT(rb_data_object_wrap_2, RUBY_UNTYPED_DATA_WARNING)
354#define rb_data_object_get_0 rb_data_object_get
355#define rb_data_object_get_1 rb_data_object_get_warning
356#define rb_data_object_get_2 rb_data_object_get_ /* Used here vvvv */
357#define rb_data_object_get RUBY_MACRO_SELECT(rb_data_object_get_2, RUBY_UNTYPED_DATA_WARNING)
358#define rb_data_object_make_0 rb_data_object_make
359#define rb_data_object_make_1 rb_data_object_make_warning
360#define rb_data_object_make_2 rb_data_object_make_ /* Used here vvvv */
361#define rb_data_object_make RUBY_MACRO_SELECT(rb_data_object_make_2, RUBY_UNTYPED_DATA_WARNING)
363#endif /* RBIMPL_RDATA_H */
Defines RBIMPL_ATTR_WARNING.
Defines RBIMPL_ATTR_DEPRECATED.
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
Defines enum ruby_fl_type.
#define inline
Old Visual Studio versions do not support the inline keyword, so we need to define it to be __inline.
Definition defines.h:91
Defines struct RBasic.
VALUE rb_data_object_wrap(VALUE klass, void *datap, RUBY_DATA_FUNC dmark, RUBY_DATA_FUNC dfree)
This is the primitive way to wrap an existing C struct into RData.
Definition gc.c:1089
static VALUE rb_data_object_make(VALUE klass, RUBY_DATA_FUNC mark_func, RUBY_DATA_FUNC free_func, void **datap, size_t size)
This is an implementation detail of Data_Make_Struct.
Definition rdata.h:343
#define DATA_PTR(obj)
Convenient getter macro.
Definition rdata.h:67
VALUE rb_data_object_zalloc(VALUE klass, size_t size, RUBY_DATA_FUNC dmark, RUBY_DATA_FUNC dfree)
Identical to rb_data_object_wrap(), except it allocates a new data region internally instead of takin...
Definition gc.c:1106
void(* RUBY_DATA_FUNC)(void *)
This is the type of callbacks registered to RData.
Definition rdata.h:104
#define Data_Make_Struct0(result, klass, type, size, mark, free, sval)
This is an implementation detail of Data_Make_Struct.
Definition rdata.h:217
Ruby object's base components.
Definition rbasic.h:69
const VALUE klass
Class of an object.
Definition rbasic.h:92
Definition rdata.h:120
RUBY_DATA_FUNC dfree
This function is called when the object is no longer used.
Definition rdata.h:143
RUBY_DATA_FUNC dmark
This function is called when the object is experiencing GC marks.
Definition rdata.h:134
void * data
Pointer to the actual C level struct that you want to wrap.
Definition rdata.h:149
struct RBasic basic
Basic part, including flags and class.
Definition rdata.h:123
Defines VALUE and ID.
uintptr_t VALUE
Type that represents a Ruby object.
Definition value.h:40
Defines enum ruby_value_type.
static void Check_Type(VALUE v, enum ruby_value_type t)
Identical to RB_TYPE_P(), except it raises exceptions on predication failure.
Definition value_type.h:433
@ RUBY_T_DATA
Definition value_type.h:127