Module: GirFFI::InfoExt::ITypeInfo
- Included in:
- ErrorTypeInfo, ReceiverTypeInfo, UserDataTypeInfo
- Defined in:
- lib/gir_ffi/info_ext/i_type_info.rb
Overview
Extensions for GObjectIntrospection::ITypeInfo needed by GirFFI
Constant Summary collapse
- TAG_TO_WRAPPER_CLASS_MAP =
{ array: 'GLib::Array', byte_array: 'GLib::ByteArray', c: 'GirFFI::SizedArray', error: 'GLib::Error', ghash: 'GLib::HashTable', glist: 'GLib::List', gslist: 'GLib::SList', ptr_array: 'GLib::PtrArray', strv: 'GLib::Strv', utf8: 'GirFFI::InPointer', void: 'GirFFI::InPointer', zero_terminated: 'GirFFI::ZeroTerminated' }
- TAGS_NEEDING_RUBY_TO_C_CONVERSION =
[ :array, :c, :callback, :error, :ghash, :glist, :gslist, :object, :ptr_array, :struct, :strv, :utf8, :void, :zero_terminated ]
- TAGS_NEEDING_C_TO_RUBY_CONVERSION =
[ :array, :byte_array, :c, :error, :filename, :ghash, :glist, :gslist, :interface, :object, :ptr_array, :struct, :strv, :union, :utf8, :zero_terminated ]
- GOBJECT_VALUE_NAME =
'GObject::Value'
Class Method Summary collapse
Instance Method Summary collapse
-
#argument_class_name ⇒ Object
TODO: Use class rather than class name.
- #element_type ⇒ Object
- #extra_conversion_arguments ⇒ Object
- #flattened_tag ⇒ Object
- #gtype ⇒ Object
- #gvalue? ⇒ Boolean
- #interface_type ⇒ Object
- #make_g_value ⇒ Object
- #needs_c_to_ruby_conversion_for_callbacks? ⇒ Boolean
- #needs_c_to_ruby_conversion_for_closures? ⇒ Boolean
- #needs_c_to_ruby_conversion_for_functions? ⇒ Boolean
- #needs_ruby_to_c_conversion_for_callbacks? ⇒ Boolean
- #needs_ruby_to_c_conversion_for_closures? ⇒ Boolean
- #needs_ruby_to_c_conversion_for_functions? ⇒ Boolean
- #tag_or_class ⇒ Object
- #to_callback_ffi_type ⇒ Object
- #to_ffi_type ⇒ Object
Class Method Details
.flattened_tag_to_gtype_map ⇒ Object
7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 7 def self.flattened_tag_to_gtype_map @flattened_tag_to_gtype_map ||= { array: GObject::TYPE_ARRAY, c: GObject::TYPE_POINTER, gboolean: GObject::TYPE_BOOLEAN, ghash: GObject::TYPE_HASH_TABLE, gint32: GObject::TYPE_INT, gint64: GObject::TYPE_INT64, guint64: GObject::TYPE_UINT64, strv: GObject::TYPE_STRV, utf8: GObject::TYPE_STRING, void: GObject::TYPE_NONE } end |
Instance Method Details
#argument_class_name ⇒ Object
TODO: Use class rather than class name
92 93 94 95 96 97 98 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 92 def argument_class_name if tag == :interface interface.full_type_name else TAG_TO_WRAPPER_CLASS_MAP[flattened_tag] end end |
#element_type ⇒ Object
36 37 38 39 40 41 42 43 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 36 def element_type case tag when :glist, :gslist, :array, :c enumerable_element_type when :ghash dictionary_element_type end end |
#extra_conversion_arguments ⇒ Object
170 171 172 173 174 175 176 177 178 179 180 181 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 170 def extra_conversion_arguments case flattened_tag when :utf8, :void [flattened_tag] when :c [element_type, array_fixed_size] when :array, :ghash, :glist, :gslist, :ptr_array, :zero_terminated [element_type] else [] end end |
#flattened_tag ⇒ Object
45 46 47 48 49 50 51 52 53 54 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 45 def flattened_tag case tag when :interface interface_type when :array flattened_array_type else tag end end |
#gtype ⇒ Object
22 23 24 25 26 27 28 29 30 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 22 def gtype if tag == :interface return interface.gtype elsif (type = ITypeInfo.flattened_tag_to_gtype_map[flattened_tag]) return type else raise "Can't find GType for #{flattened_tag} pointer? = #{pointer?}" end end |
#gvalue? ⇒ Boolean
185 186 187 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 185 def gvalue? argument_class_name == GOBJECT_VALUE_NAME end |
#interface_type ⇒ Object
56 57 58 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 56 def interface_type tag == :interface && interface.info_type end |
#make_g_value ⇒ Object
32 33 34 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 32 def make_g_value GObject::Value.for_gtype gtype end |
#needs_c_to_ruby_conversion_for_callbacks? ⇒ Boolean
157 158 159 160 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 157 def needs_c_to_ruby_conversion_for_callbacks? [:callback, :enum].include?(flattened_tag) || needs_c_to_ruby_conversion_for_functions? end |
#needs_c_to_ruby_conversion_for_closures? ⇒ Boolean
162 163 164 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 162 def needs_c_to_ruby_conversion_for_closures? [:array, :c, :ghash, :struct, :strv].include?(flattened_tag) end |
#needs_c_to_ruby_conversion_for_functions? ⇒ Boolean
148 149 150 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 148 def needs_c_to_ruby_conversion_for_functions? TAGS_NEEDING_C_TO_RUBY_CONVERSION.include?(flattened_tag) end |
#needs_ruby_to_c_conversion_for_callbacks? ⇒ Boolean
152 153 154 155 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 152 def needs_ruby_to_c_conversion_for_callbacks? [:enum].include?(flattened_tag) || needs_ruby_to_c_conversion_for_functions? end |
#needs_ruby_to_c_conversion_for_closures? ⇒ Boolean
166 167 168 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 166 def needs_ruby_to_c_conversion_for_closures? [:array].include?(flattened_tag) end |
#needs_ruby_to_c_conversion_for_functions? ⇒ Boolean
144 145 146 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 144 def needs_ruby_to_c_conversion_for_functions? TAGS_NEEDING_RUBY_TO_C_CONVERSION.include?(flattened_tag) end |
#tag_or_class ⇒ Object
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 60 def tag_or_class base = case tag when:interface Builder.build_class interface when :ghash [tag, *element_type] else flattened_tag end if pointer? && tag != :utf8 && tag != :filename [:pointer, base] else base end end |
#to_callback_ffi_type ⇒ Object
113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 113 def to_callback_ffi_type return :pointer if pointer? case tag when :interface # TODO: Move this logic into interface case interface.info_type when :enum, :flags :int32 else :pointer end when :gboolean # TODO: Move this logic into TypeMap :bool else TypeMap.map_basic_type tag end end |
#to_ffi_type ⇒ Object
100 101 102 103 104 105 106 107 108 109 110 111 |
# File 'lib/gir_ffi/info_ext/i_type_info.rb', line 100 def to_ffi_type return :pointer if pointer? case tag when :interface interface.to_ffi_type when :array [subtype_ffi_type(0), array_fixed_size] else TypeMap.map_basic_type tag end end |