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;
}