Class: FFI::StructByValue
Relationships & Source Files | |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
Type
|
|
Instance Chain:
self,
Type
|
|
Inherits: | FFI::Type |
Defined in: | ext/ffi_c/StructByValue.c |
Constant Summary
Class Method Summary
Instance Method Summary
Constructor Details
.new(rbStructClass)
[ GitHub ]# File 'ext/ffi_c/StructByValue.c', line 92
static VALUE sbv_initialize(VALUE self, VALUE rbStructClass) { StructByValue* sbv = NULL; StructLayout* layout = NULL; VALUE rbLayout = Qnil; rbLayout = rb_ivar_get(rbStructClass, rb_intern("@layout")); if (!rb_obj_is_instance_of(rbLayout, rbffi_StructLayoutClass)) { rb_raise(rb_eTypeError, "wrong type in @layout ivar (expected FFI::StructLayout)"); } TypedData_Get_Struct(rbLayout, StructLayout, &rbffi_struct_layout_data_type, layout); TypedData_Get_Struct(self, StructByValue, &sbv_type_data_type, sbv); RB_OBJ_WRITE(self, &sbv->rbStructClass, rbStructClass); RB_OBJ_WRITE(self, &sbv->rbStructLayout, rbLayout); /* We can just use everything from the ffi_type directly */ *sbv->base.ffiType = *layout->base.ffiType; return self; }
Instance Method Details
#layout
[ GitHub ]# File 'ext/ffi_c/StructByValue.c', line 146
static VALUE sbv_layout(VALUE self) { StructByValue* sbv; TypedData_Get_Struct(self, StructByValue, &sbv_type_data_type, sbv); return sbv->rbStructLayout; }
#struct_class
[ GitHub ]# File 'ext/ffi_c/StructByValue.c', line 155
static VALUE sbv_struct_class(VALUE self) { StructByValue* sbv; TypedData_Get_Struct(self, StructByValue, &sbv_type_data_type, sbv); return sbv->rbStructClass; }