Module: Fiddle::CStructBuilder
| Relationships & Source Files | |
| Defined in: | ext/fiddle/lib/fiddle/struct.rb | 
Overview
Used to construct C classes (CUnion, CStruct, etc)
Importer#struct and Importer#union wrap this functionality in an easy-to-use manner.
Class Method Summary
- 
    
      .create(klass, types, members)  
    
    mod_func
    Construct a new class given a C: * class klass(CUnion, CStruct, or other that provide an.
Class Method Details
.create(klass, types, members) (mod_func)
Construct a new class given a C:
- 
class klass(CUnion, CStruct, or other that provide an #entity_class)
- 
types(Fiddle::TYPE_INT, TYPE_SIZE_T, etc., see the C types constants)
- 
corresponding members
Importer#struct and Importer#union wrap this functionality in an easy-to-use manner.
Example:
require 'fiddle/struct'
require 'fiddle/cparser'
include Fiddle::CParser
types, members = parse_struct_signature(['int i','char c'])
MyStruct = Fiddle::CStructBuilder.create(Fiddle::CUnion, types, members)
obj = MyStruct.allocate# File 'ext/fiddle/lib/fiddle/struct.rb', line 50
def create(klass, types, members) new_class = Class.new(klass){ define_method(:initialize){|addr| @entity = klass.entity_class.new(addr, types) @entity.assign_names(members) } define_method(:to_ptr){ @entity } define_method(:to_i){ @entity.to_i } members.each{|name| define_method(name){ @entity[name] } define_method(name + "="){|val| @entity[name] = val } } } size = klass.entity_class.size(types) new_class.module_eval(<<-EOS, __FILE__, __LINE__+1) def new_class.size() #{size} end def new_class.malloc() addr = Fiddle.malloc(#{size}) new(addr) end EOS return new_class end