Class: LLVM::Type

Inherits:
Object
  • Object
show all
Includes:
PointerIdentity
Defined in:
lib/llvm/core/type.rb

Direct Known Subclasses

FunctionType, IntType, StructType

Class Method Summary collapse

Instance Method Summary collapse

Methods included from PointerIdentity

#==, #eql?, #hash, #to_ptr

Class Method Details

.array(ty, sz = 0) ⇒ Object

Creates an array type of Type with the given size.



83
84
85
# File 'lib/llvm/core/type.rb', line 83

def self.array(ty, sz = 0)
  from_ptr(C.array_type(LLVM::Type(ty), sz), :array)
end

.from_ptr(ptr, kind = nil) ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# File 'lib/llvm/core/type.rb', line 8

def self.from_ptr(ptr, kind = nil)
  return if ptr.null?
  kind ||= C.get_type_kind(ptr)
  ty = case kind
  when :integer
    IntType.allocate
  when :function
    FunctionType.allocate
  when :struct
    StructType.allocate
  else
    allocate
  end
  ty.instance_variable_set(:@ptr, ptr)
  ty.instance_variable_set(:@kind, kind)
  ty
end

.function(arg_types, result_type, options = {}) ⇒ Object

Creates a function type. Takes an array of argument Types and the result Type. The only option is :varargs, which when set to true makes the function type take a variable number of args.



99
100
101
102
103
104
# File 'lib/llvm/core/type.rb', line 99

def self.function(arg_types, result_type, options = {})
  arg_types.map! { |ty| LLVM::Type(ty) }
  arg_types_ptr = FFI::MemoryPointer.new(FFI.type_size(:pointer) * arg_types.size)
  arg_types_ptr.write_array_of_pointer(arg_types)
  from_ptr(C.function_type(LLVM::Type(result_type), arg_types_ptr, arg_types.size, options[:varargs] ? 1 : 0), :function)
end

.labelObject



125
126
127
# File 'lib/llvm/core/type.rb', line 125

def self.label
  from_ptr(C.label_type, :label)
end

.pointer(ty, address_space = 0) ⇒ Object

Creates the pointer type of Type with the given address space.



88
89
90
# File 'lib/llvm/core/type.rb', line 88

def self.pointer(ty, address_space = 0)
  from_ptr(C.pointer_type(LLVM::Type(ty), address_space), :pointer)
end

.recObject

def self.opaque_pointer

from_ptr(C.opaque_type, :pointer)

end



140
141
142
143
144
145
# File 'lib/llvm/core/type.rb', line 140

def self.rec
  h = opaque
  ty = yield h
  h.refine(ty)
  ty
end

.struct(elt_types, is_packed, name = nil) ⇒ Object

Creates a struct type with the given array of element types.



107
108
109
110
111
112
113
114
115
116
117
118
# File 'lib/llvm/core/type.rb', line 107

def self.struct(elt_types, is_packed, name = nil)
  elt_types.map! { |ty| LLVM::Type(ty) }
  elt_types_ptr = FFI::MemoryPointer.new(FFI.type_size(:pointer) * elt_types.size)
  elt_types_ptr.write_array_of_pointer(elt_types)
  if name
    struct = from_ptr(C.struct_create_named(Context.global, name), :struct)
    C.struct_set_body(struct, elt_types_ptr, elt_types.size, is_packed ? 1 : 0) unless elt_types.empty?
    struct
  else
    from_ptr(C.struct_type(elt_types_ptr, elt_types.size, is_packed ? 1 : 0), :struct)
  end
end

.vector(ty, element_count) ⇒ Object

Creates a vector type of Type with the given element count.



93
94
95
# File 'lib/llvm/core/type.rb', line 93

def self.vector(ty, element_count)
  from_ptr(C.vector_type(LLVM::Type(ty), element_count), :vector)
end

.voidObject

Creates a void type.



121
122
123
# File 'lib/llvm/core/type.rb', line 121

def self.void
  from_ptr(C.void_type, :void)
end

.x86_amxObject



133
134
135
# File 'lib/llvm/core/type.rb', line 133

def self.x86_amx
  from_ptr(C.x86amx_type, :x86amx)
end

.x86_mmxObject



129
130
131
# File 'lib/llvm/core/type.rb', line 129

def self.x86_mmx
  from_ptr(C.x86mmx_type, :x86mmx)
end

Instance Method Details

#aggregate?Boolean

Returns:

  • (Boolean)


78
79
80
# File 'lib/llvm/core/type.rb', line 78

def aggregate?
  [:struct, :array].include?(kind)
end

#alignObject



36
37
38
# File 'lib/llvm/core/type.rb', line 36

def align
  LLVM::Int64.from_ptr(C.align_of(self))
end

#dumpObject

Print the type’s representation to stdout.



69
70
71
# File 'lib/llvm/core/type.rb', line 69

def dump
  C.dump_type(self)
end

#element_typeObject

Returns the type of this types elements (works only for Pointer, Vector, and Array types.)



41
42
43
44
45
46
47
48
49
50
51
# File 'lib/llvm/core/type.rb', line 41

def element_type
  case kind
  when :vector, :array
    element_type = C.get_element_type(self)
    Type.from_ptr(element_type)
  when :pointer
    LLVM.Void
  else
    raise "element_type not supported for kind: #{kind}"
  end
end

#kindObject

Returns a symbol representation of the types kind (ex. :pointer, :vector, :array.)



27
28
29
# File 'lib/llvm/core/type.rb', line 27

def kind
  @kind
end

#nullObject

Returns a null ConstantExpr of this type.



59
60
61
# File 'lib/llvm/core/type.rb', line 59

def null
  ConstantExpr.from_ptr(C.const_null(self))
end

#null_pointerObject

Returns a null pointer ConstantExpr of this type.



54
55
56
# File 'lib/llvm/core/type.rb', line 54

def null_pointer
  ConstantExpr.from_ptr(C.const_pointer_null(self))
end

#pointer(address_space = 0) ⇒ Object

Creates a pointer type with this type and the given address space.



64
65
66
# File 'lib/llvm/core/type.rb', line 64

def pointer(address_space = 0)
  Type.pointer(self, address_space)
end

#sizeObject

Returns the size of the type.



32
33
34
# File 'lib/llvm/core/type.rb', line 32

def size
  LLVM::Int64.from_ptr(C.size_of(self))
end

#to_sObject

Build string of LLVM type representation.



74
75
76
# File 'lib/llvm/core/type.rb', line 74

def to_s
  C.print_type_to_string(self)
end