Module: Fiddle::CStructBuilder
- Defined in:
- lib/fiddle/struct.rb
Overview
Used to construct C classes (CUnion, CStruct, etc)
Fiddle::Importer#struct and Fiddle::Importer#union wrap this functionality in an easy-to-use manner.
Class Method Summary collapse
-
.create(klass, types, members) ⇒ Object
Construct a new class given a C: * class
klass
(CUnion, CStruct, or other that provide an #entity_class) *types
(Fiddle::TYPE_INT, Fiddle::TYPE_SIZE_T, etc., see the C types constants) * correspondingmembers
.
Class Method Details
.create(klass, types, members) ⇒ Object
Construct a new class given a C:
-
class
klass
(CUnion, CStruct, or other that provide an #entity_class) -
types
(Fiddle::TYPE_INT, Fiddle::TYPE_SIZE_T, etc., see the C types constants) -
corresponding
members
Fiddle::Importer#struct and Fiddle::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
50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File '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 |