Class: LLVM::Function

Inherits:
GlobalValue show all
Defined in:
lib/llvm/analysis.rb,
lib/llvm/core/value.rb

Defined Under Namespace

Classes: AttributeCollection, BasicBlockCollection, ParameterCollection

Instance Method Summary collapse

Methods inherited from GlobalValue

#alignment, #alignment=, #declaration?, #dll_storage_class, #dll_storage_class=, #linkage, #linkage=, #section, #section=, #unnamed_addr=, #unnamed_addr?, #visibility, #visibility=

Methods inherited from Constant

#bitcast_to, #gep, null, null_ptr, poison, #ptr_to_int, undef

Methods inherited from User

#operands

Methods inherited from Value

#allocated_type, #allocated_type?, #constant?, #dump, from_ptr, from_ptr_kind, #gep_source_element_type, #gep_source_element_type?, #global_parent, #kind, #name, #name=, #null?, #poison?, to_ptr, #to_s, type, #undef?

Methods included from PointerIdentity

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

Instance Method Details

#add_attribute(attr, index = -1)) ⇒ Object

Adds attr to this value’s attributes.



919
920
921
# File 'lib/llvm/core/value.rb', line 919

def add_attribute(attr, index = -1)
  AttributeCollection.new(self, index).add(attr)
end

#attribute_countObject



928
929
930
# File 'lib/llvm/core/value.rb', line 928

def attribute_count
  function_attributes.count
end

#attributesObject



932
933
934
# File 'lib/llvm/core/value.rb', line 932

def attributes
  function_attributes.to_a
end

#basic_blocksObject

Returns an Enumerable of the BasicBlocks in this function.



901
902
903
# File 'lib/llvm/core/value.rb', line 901

def basic_blocks
  @basic_block_collection ||= BasicBlockCollection.new(self)
end

#call_convObject

gets the calling convention of the function



881
882
883
# File 'lib/llvm/core/value.rb', line 881

def call_conv
  C.get_function_call_conv(self)
end

#call_conv=(conv) ⇒ Object

Sets the function’s calling convention and returns it.



876
877
878
# File 'lib/llvm/core/value.rb', line 876

def call_conv=(conv)
  C.set_function_call_conv(self, conv)
end

#function_attributesObject



948
949
950
# File 'lib/llvm/core/value.rb', line 948

def function_attributes
  AttributeCollection.new(self, -1)
end

#function_typeObject



905
906
907
# File 'lib/llvm/core/value.rb', line 905

def function_type
  Type.from_ptr(C.get_element_type(self), :function)
end

#gcObject



1130
1131
1132
# File 'lib/llvm/core/value.rb', line 1130

def gc
  C.get_gc(self)
end

#gc=(name) ⇒ Object



1126
1127
1128
# File 'lib/llvm/core/value.rb', line 1126

def gc=(name)
  C.set_gc(self, name)
end

#inspectObject



1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
# File 'lib/llvm/core/value.rb', line 1134

def inspect
  {
    signature: to_s.lines[attribute_count == 0 ? 0 : 1],
    type: type.to_s,
    attributes: attribute_count,
    valid: valid?,
    blocks: basic_blocks.size,
    lines: to_s.lines.size,
  }.to_s
end

#param_attributes(index) ⇒ Object



956
957
958
# File 'lib/llvm/core/value.rb', line 956

def param_attributes(index)
  AttributeCollection.new(self, index)
end

#paramsObject

Returns an Enumerable of the parameters in the function.



1093
1094
1095
# File 'lib/llvm/core/value.rb', line 1093

def params
  @parameter_collection ||= ParameterCollection.new(self)
end

#personality_functionObject

Note:

Experimental and unsupported

Get personality function of function

Returns:

  • LLVM::Function



888
889
890
891
# File 'lib/llvm/core/value.rb', line 888

def personality_function
  ptr = C.get_personality_fn(self)
  LLVM::Function.from_ptr(ptr)
end

#personality_function=(personality_function) ⇒ Object

Note:

Experimental and unsupported

Set personality function of function

Returns:

  • self



896
897
898
# File 'lib/llvm/core/value.rb', line 896

def personality_function=(personality_function)
  C.set_personality_fn(self, personality_function)
end

#readnone?Boolean

Returns:

  • (Boolean)


936
937
938
# File 'lib/llvm/core/value.rb', line 936

def readnone?
  attributes.detect(&:readnone?)
end

#readonly?Boolean

Returns:

  • (Boolean)


940
941
942
# File 'lib/llvm/core/value.rb', line 940

def readonly?
  attributes.detect(&:readonly?)
end

#remove_attribute(attr, index = -1)) ⇒ Object

Removes the given attribute from the function.



924
925
926
# File 'lib/llvm/core/value.rb', line 924

def remove_attribute(attr, index = -1)
  AttributeCollection.new(self, index).remove(attr)
end

#return_attributesObject



952
953
954
# File 'lib/llvm/core/value.rb', line 952

def return_attributes
  AttributeCollection.new(self, 0)
end

#return_typeObject



914
915
916
# File 'lib/llvm/core/value.rb', line 914

def return_type
  type.return_type
end

#typeObject

In LLVM 15, not overriding this yields a pointer type instead of a function type



910
911
912
# File 'lib/llvm/core/value.rb', line 910

def type
  function_type
end

#valid?Boolean

Returns:

  • (Boolean)


53
54
55
# File 'lib/llvm/analysis.rb', line 53

def valid?
  verify
end

#verifytrue, false

Verify that a function is valid.

Returns:

  • (true, false)


41
42
43
# File 'lib/llvm/analysis.rb', line 41

def verify
  do_verification(:return_status)
end

#verify!true, false

Verify that a function is valid, and abort the process if not.

Returns:

  • (true, false)


47
48
49
50
51
# File 'lib/llvm/analysis.rb', line 47

def verify!
  # :nocov:
  do_verification(:abort_process)
  # :nocov:
end

#writeonly?Boolean

Returns:

  • (Boolean)


944
945
946
# File 'lib/llvm/core/value.rb', line 944

def writeonly?
  attributes.detect(&:writeonly?)
end